1.使用JDK方式:
需要使用注解的方式配置提供服务的接口,然后使用Endpoint的publish(String address,Object implementor);
address:提供服务的wsdl地址,
implementor:提供服务的类或者接口
这是一个java程序,run会将服务发布出去以供客户端访问。客户端访问的方式有两种,1.通过wsdl地址来访问,2.生成本地代理客户端来访问
2.使用spring的httpInvoker发布服务:
因为有多种方式,我只选一种方式的配置。
1.web.xml 配置:
配置spring的核心控制器:DispatcherServlet(springmvc就是使用这个控制器来控制整个框架的运转。(最好在这里指定spring配置文件的位置。)
2.配置applicationContext.xml配置文件:
使用这个类 org.springframework.remoting.httpinvoker.HttpInvokerServiceExporter 将提供服务的类和接口绑定到一个bean上,再配置适配器 :1.使用SimpleUrlHandlerMapping类需要显式的将刚才绑定的bean与一个地址相结合;2.使用BeanNameUrlHandlerMapping,隐式的将服务发布出去,发布的地址为/bean名。
然后开启服务器,webService服务就可以被客户端访问了,这种方式的访问时需要给客户端提供接口的,没有wsdl文件,客户端只可以访问接口中的方法,客户端也要使用spring的httpInvoker框架才能正常访问,可以传输基本类型数据和对象(对象需要实现Serializable接口,因为会将其序列化和反序列化,并且对象的包名必须和服务器端的保持一致。)
3.xfire:分为xfire和 xfire与spring整合 两种方式
先说xfire的方式,
一般只需要在web.xml文件中配置一个xfire的控制器:XFireConfigurableServlet,然后在
WEB-INF\classes\META-INF\xfire\services.xml路径配置services.xml文件:
1.<service>
2. <name>HelloWorldService</name>
3. <namespace>http://vivianj.org/HelloWorldService</namespace> 这个只是个标识,Web 服务发布时所使用的命名空间。
4. <serviceClass>
5. org.vivianj.xfire.pojo.HelloWorldService
6. </serviceClass>
7. <implementationClass>
8. org.vivianj.xfire.pojo.HelloWorldServiceImpl
9. </implementationClass>
10.</service>
然后启动服务器,访问的是wsdl文件,客户端访问的方式和jdk访问方式相同。
再来谈下XFire与spring的整合:
spring与xfire整合:这个是完整配置的链接(最后发布的服务可以生成wsdl文件),因为有多种配置方式,我就不再这里详写了,
只写一下客户端访问的方式,客户端可以使用xfire的方式访问,
Client client = new Client( new URL("wsdl地址"));
Object[] value = client.invoke(string opreation,Object [] params);
opreation指要操作的方法名,
params是这个方法的参数值,按顺序进行填充。
这个方法返回的是Object类型的数组,数组的第一个值是第三方接口返回的值,但这种方式不能解析第三方接口返回的对象数据,
4.还有cxf框架发布webSerivce可以看我的 webService,在后半段有cxf发布和与spring集成发布的方式