Web Service(WEB服务)可以快捷和方便地综合结合各类系统、商务和任何应用平台。利用最新的Web Service 标准可以使任何软件系统和系统之间的应用互通互联,方便,并且更加廉价。java
(1)跨越防火墙通讯程序员
客户端和服务器端之间通讯都会有防火墙或者代理服务器。传统的实现互相通讯的方法是在分布式对象,如DCOM、CORBA之间进行相互的远程过程调用(TCP/IP),但在这种场合下HTTP协议的特性没有获得应用,所以在Internet环境下的远程过程调用不是一件容易的事情,同时在Internet上使用远程过程调用还存在安全问题,防火墙和代理服务器还有可能阻挡这种类型的数据传输。HTTP是在Internet上发送消息的标准协议。Web服务使用基于XML消息处理做为基本的数据通讯方式,应用程序可使用HTTP和XML消息等标准在基于Web的应用程序之间交换信息,从而跨越防火墙。web
(2)应用程序集成安全
企业里常常要把不一样语言写成的在不一样平台上运行的各类程序集成起来。大型公司经常有不少部门,每一个部门都使用最适合本身特定须要的应用程序和平台。为了可以让公司各部门之间进行通讯,首先应该将公司内部的应用程序和商业过程集成在一块儿。Web服务的开放标准使组织建立可重用的应用程序接口。当被包装成一个或一组Web服务以后,任何应用程序理论上均可以经过SOAP消息与任何其余应用程序进行通讯。服务器
(3)软件复用并发
软件复用是在软件开发中避免重复劳动的解决方案。Web服务实现了业务级别的软件复用,例如在B2B的集成中,各企业之间经过互相调用Web服务,实现了Web服务的共享,Web服务的使用企业不须要再从新开发其余企业中已经存在的服务。框架
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
public
class
WeatherClient{
public
static
void
main(String[] args)
throws
UnknownHostException, IOException{
//1.建立Socket对象,和服务端创建链接
Socket socket =
new
Socket(
"127.0.0.1"
,
12345
);
//2.发送城市名称
DataOutputStream dos =
new
DataOutputStream(socket.getOutputStream());
dos.writeUTF(
"北京"
);
System.out.println(
"请求查询天气: 北京"
);
//3.接受返回结果使用输入流
DataInputStream dis =
new
DataInputStream(socket.getInputStream());
String result = dis.readUTF();
System.out.println(
"北京的天气: "
+ result);
//4.关闭流
dis.close();
dos.close();
}
}
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
/*
* 天气服务端
*/
public
class
WeatherServer{
public
static
void
main(String[] args)
throws
IOException{
// 1.建立ServerSocket对象
ServerSocket serverSocket =
new
ServerSocket(
12345
);
while
(
true
){
// 2.等待客户端链接,阻塞的方法
final
Socket socket = serverSocket.accept();
Runnable runnable =
new
Runnable(){
@Override
public
void
run(){
try
{
// 3.使用输入流接受客户端发送的请求
DataInputStream dis =
new
DataInputStream(socket.getInputStream());
String cityName = dis.readUTF();
System.out.println(
"接收到客户端发送的请求: "
+ cityName);
Thread.sleep(
1000
);
// 4.根据城市名查询天气
String result =
"今每天气很热"
;
System.out.println(
"返回天气信息: "
+ result);
// 5.返回查询结果,使用输出流。
DataOutputStream dos =
new
DataOutputStream(socket.getOutputStream());
dos.writeUTF(result);
// 6.关闭流
dis.close();
dos.close();
}
catch
(Exception e){
e.printStackTrace();
}
}
};
//启动线程
new
Thread(runnable).start();
}
}
}
|
结果:socket
请求查询天气: 北京
北京的天气: 今每天气很热tcp
接收到客户端发送的请求: 北京
返回天气信息: 今每天气很热分布式
第一步: 建立一个java工程,不须要导入jar包。
第二步: 建立接口。在Webservice中叫作SEI(wsdl中叫作PortType)。
第三步: 建立实现类。须要在实现类上加一个@Webservice注解。
第四步: 发布服务。EndPoint.publish发布服务。
WeatherInterface.java
WeatherInterfaceImpl.java
WeatherServer.java
a: 在地址栏输入(注意后面的参数?wsdl)
http://127.0.0.1:12345/weather?wsdl
b: Wsdl不是webService,只是获取一个用于描述WebService的说明文件
第1步:建立服务视图对象。
第2步: 从服务视图中得到PortType对象。
第3步: 调用PortType的方法(能够实现远程通讯)
第4步: 接收方法的返回值(服务端响应的结果)。
(1)Socket是基于TCP/IP的传输层协议。
Webservice是基于HTTP协议传输数据,http是基于tcp的应用层协议。
Webservice采用了基于http的soap协议传输数据。
(2)Socket接口经过流传输,不支持面向对象。
Webservice 接口支持面向对象,最终webservice将对象进行序列化后经过流传输。
Webservice采用soap协议进行通讯,不需专门针对数据流的发送和接收进行处理,是一种跨平台的面向对象远程调用技术。(3)Socket适用于高性能大数据的传输,传输的数据须要手动处理,socket通讯的接口协议须要自定义。
好比:自定义一种字符串拼接的格式,好比自定义的xml数据,自定义麻烦之处在接口调用方和接口服务端须要互相讨论肯定接口的协议内容,不方便。
缺点程序员须要本身去解析输入、输出流,解析发送和接收的数据。数据传输的格式不固定,须要程序员开发socket接口时自定义接口协议。
优势
若是要传输大数据量,socket能够知足,若是存在大并发使用socket也能够实现,程序用socket灵活性更大,好比能够socket的高并发框架mina开发。
Webservcie因为是遵循标准的soap协议,soap 协议的内容格式固定,soap协议传递的内容是xml数据,因为webservice是基于http的,因此简单理解为soap=http+xml,适用于没有性能要求状况下且数据传输量小,推荐在公开接口上使用webservice,由于soap协议的标准的。
优势
jaxws能够经过面向对象开发webservice,程序员不须要解析输入、输出流。
因为webservice传输数据使用标准的soap协议(基于http传输xml),soap协议已经被w3c管理了。
缺点
若是传输大数据量,webservice不适用。若是webservice开发大并发的应用,webservice依靠web容器提升并发数。