7、Web Service-IDEA-jaxws规范下的 服务端/客户端 开发
前提简介:这里之后即使基于IDEA进行开发的,风格与之前有些不同之处!
1、服务端的开发
1、创建新的项目
2、pom.xml
添加开发时所需要的依赖
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.cr</groupId> <artifactId>jaxws_server</artifactId> <version>1.0-SNAPSHOT</version> <name>jaxws_server</name> <!-- FIXME change it to the project's website --> <url>http://www.example.com</url> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <maven.compiler.source>1.7</maven.compiler.source> <maven.compiler.target>1.7</maven.compiler.target> </properties>
<dependencies> <dependency> <groupId>org.apache.cxf</groupId> <artifactId>cxf-rt-frontend-jaxws</artifactId> <version>3.0.1</version> </dependency>
<!-- 内置jetty服务器 --> <dependency> <groupId>org.apache.cxf</groupId> <artifactId>cxf-rt-transports-http-jetty</artifactId> <version>3.0.1</version> </dependency> <!--日志--> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>1.7.12</version> <scope>test</scope> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.11</version> <scope>test</scope> </dependency> </dependencies> <build> <pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) --> <plugins> <!-- clean lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#clean_Lifecycle --> <plugin> <artifactId>maven-clean-plugin</artifactId> <version>3.1.0</version> </plugin> <!-- default lifecycle, jar packaging: see https://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_jar_packaging --> <plugin> <artifactId>maven-resources-plugin</artifactId> <version>3.0.2</version> </plugin> <plugin> <artifactId>maven-compiler-plugin</artifactId> <version>3.8.0</version> </plugin> <plugin> <artifactId>maven-surefire-plugin</artifactId> <version>2.22.1</version> </plugin> <plugin> <artifactId>maven-jar-plugin</artifactId> <version>3.0.2</version> </plugin> <plugin> <artifactId>maven-install-plugin</artifactId> <version>2.5.2</version> </plugin> <plugin> <artifactId>maven-deploy-plugin</artifactId> <version>2.8.2</version> </plugin> <!-- site lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#site_Lifecycle --> <plugin> <artifactId>maven-site-plugin</artifactId> <version>3.7.1</version> </plugin> <plugin> <artifactId>maven-project-info-reports-plugin</artifactId> <version>3.0.0</version> </plugin> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.2</version> <configuration> <source>1.8</source> <target>1.8</target> <encoding>UTF-8</encoding> <showWarnings>true</showWarnings> </configuration> </plugin> </plugins> </pluginManagement> </build> </project>
3、工程目录:
4、类的设计
接口类:在客户端的接口类需要和服务端的接口类再同一个包中
helloService.java
package com.cr.service; import javax.jws.WebService; //对外发布的接口 @WebService public interface helloService { //对外发布服务接口的方法 public String sayHello(String name); }
接口实现类
helloSericeImpl.java
package com.cr.service.impl; import com.cr.service.helloService; public class helloSericeImpl implements helloService { @Override public String sayHello(String name) { return "欢迎"+name; } }
发布服务:
package com.cr; import com.cr.service.impl.helloSericeImpl; import org.apache.cxf.jaxws.JaxWsServerFactoryBean; public class serverTest { public static void main(String[] args) { //发布服务的工厂 JaxWsServerFactoryBean factory = new JaxWsServerFactoryBean(); //设置服务地址 factory.setAddress("http://localhost:8000/ws/hello"); //设置服务类、 factory.setServiceBean(new helloSericeImpl()); //发布服务 factory.create(); System.out.println("发布服务成功...."); } }
此时的控制台的输出情况:
5、查看wsdl地址内容
浏览器输入地址+ ?wsdl
阅读顺序自下向上
此时若需要读懂wsdl文件方向是自下向上
2、客户端的开发
1、创建项目(同上,以及pom文件的依赖)
2、工程结构
3、类的实现
接口类:这里的接口的包名需要和服务端的接口类报名保持一致
helloService.java
package com.cr.service; import javax.jws.WebService;
//对外发布服务的接口
@WebService
public interface helloService {
//对外发布服务接口的方法
public String sayHello(String name);
}
测试类:
package com.cr.test; import com.cr.service.helloService; import org.apache.cxf.jaxws.JaxWsProxyFactoryBean; public class Client { public static void main(String[] args) { //服务接口访问地址http://localhost:8000/ws/hello //创建cxf代理工厂 JaxWsProxyFactoryBean factory= new JaxWsProxyFactoryBean(); //设置服务的地址 factory.setAddress("http://localhost:8000/ws/hello"); //设置接口类型 factory.setServiceClass(helloService.class); //对接口生成代理对象 helloService helloService = factory.create(helloService.class); System.out.println(helloService.getClass()); //远程访问服务端方法 String qq = helloService.sayHello("qq"); System.out.println(qq); } }
这里的代理时时JDK代理class com.sun.proxy.$Proxy34
java中的代理:
1、静态代理
2、动态代理
动态代理包括:
1、jdk接口代理:$Proxy34
2、cglib代理:¥CGLIB123
问题:我们想要知道数据交互的格式:
在服务的添加log4j日志文件
log4j.appender.Stdout=org.apache.log4j.ConsoleAppender log4j.appender.Stdout.layout=org.apache.log4j.PatternLayout log4j.appender.Stdout.layout.conversionPattern=%-5p - %-26.26c{1} - %m\n log4j.rootLogger=INFO,Stdout log4j.logger.org.apache.wicket=INFO log4j.logger.org.apache.wicket.protocol.http.HttpSessionStore=INFO log4j.logger.org.apache.wicket.version=INFO log4j.logger.org.apache.wicket.RequestCycle=INFO log4j.appender.LOGFILE=org.apache.log4j.FileAppender log4j.appender.LOGFILE.File=d:\file.log log4j.appender.LOGFILE.Append=true log4j.appender.LOGFILE.layout=org.apache.log4j.PatternLayout
在测试的代码中:
package com.cr; import com.cr.service.impl.helloSericeImpl; import org.apache.cxf.interceptor.LoggingInInterceptor; import org.apache.cxf.interceptor.LoggingOutInterceptor; import org.apache.cxf.jaxws.JaxWsServerFactoryBean; public class serverTest { public static void main(String[] args) { //发布服务的工厂 JaxWsServerFactoryBean factory = new JaxWsServerFactoryBean(); //设置服务地址 factory.setAddress("http://localhost:8000/ws/hello"); //设置服务类、 factory.setServiceBean(new helloSericeImpl()); //设置日志输入、输出拦截器、观察soap请求的相应内容 factory.getInInterceptors().add(new LoggingInInterceptor()); factory.getOutInterceptors().add(new LoggingOutInterceptor()); //发布服务 factory.create(); System.out.println("发布服务成功...."); } }
此时再次请求Client
控制台中
ID: 1 Address: http://localhost:8000/ws/hello Encoding: UTF-8 Http-Method: POST Content-Type: text/xml; charset=UTF-8 Headers: {Accept=[*/*], Cache-Control=[no-cache], connection=[keep-alive], Content-Length=[188], content-type=[text/xml; charset=UTF-8], Host=[localhost:8000], Pragma=[no-cache], SOAPAction=[""], User-Agent=[Apache CXF 3.0.1]} Payload: <soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"><soap:Body><ns2:sayHello xmlns:ns2="http://service.cr.com/"><arg0>qq</arg0></ns2:sayHello></soap:Body></soap:Envelope> -------------------------------------- INFO - helloService - Outbound Message --------------------------- ID: 1 Response-Code: 200 Encoding: UTF-8 Content-Type: text/xml Headers: {} Payload: <soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"><soap:Body><ns2:sayHelloResponse xmlns:ns2="http://service.cr.com/"><return>欢迎qq</return></ns2:sayHelloResponse></soap:Body></soap:Envelope> --------------------------------------
此时可以看出请求与响应的相关消息!!