[CXF REST标准实战系列] 二、Spring4.0 整合 CXF3.0,实现测试接口

简介:

Reprint it anywhere u want.

文章Points:

1、介绍RESTful架构风格

2、Spring配置CXF

3、三层初设计,实现WebService接口层

4、撰写HTTPClient 客户端,并实现简单调用

 

介绍RESTful架构风格

    REST是REST之父Roy Thomas创造的,当时提出来了REST的6个特点:客户端-服务器的、无状态的、可缓存的、统一接口、分层系统和按需编码。其具有跨语言和跨平台的优势。

    REST是一种架构风格。其描述性的状态包括资源数据的内容和表达格式(XML,JSON等)。请求其中一个资源:方为一个指定性和描述性的URI,经由HTTP将资源的表达从服务器转移到客户端,或者相反方向。

    REST不是一种技术,也不是一个标准或者协议,它拥有标准:HTTP+URI+XML(JSON),来实现其要求的架构风格。

   

    泥瓦匠的记忆宫殿:“REST其实就像万能规则一样。如果你遵循它的规则的话,就能得她提供给你的资源数据。”

 

Spring配置CXF

    泥瓦匠用的是Spring4.0.x和CXF3.0.x版本。有兄长说过让我用其他的轻量级的Web Service框架,我最后考虑了下还是用CXF。

 

1、第一步配置所需的依赖包jars

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
< dependency >
     < groupId >org.apache.cxf</ groupId >
     < artifactId >cxf-rt-frontend-jaxws</ artifactId >
     < version >3.0.3</ version >
</ dependency >
< dependency >
     < groupId >org.apache.cxf</ groupId >
     < artifactId >cxf-rt-transports-http</ artifactId >
     < version >3.0.3</ version >
</ dependency >
< dependency >
     < groupId >org.apache.cxf</ groupId >
     < artifactId >cxf-rt-frontend-jaxrs</ artifactId >
     < version >3.0.3</ version >
</ dependency >

在以前2.x的CXF上,bug和配置上很复杂。3.0以后很方便,用了MAVEN后,就是直接拷贝下上面的代码放到pom.xml即可。

 

2、配置Spring文件

    首先配置CXF所需的XSD地址,表死我们引用了这个结构定义。

    然后泥瓦匠用配置核心的配置。在<beans></beans>直接加入所需要的cxf配置。

?
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
< bean id = "regUser" class = "com.xidian.wq.imaopay.controller.webservice.UserInfoController" ></ bean >
     
     <!-- CXF 拦截器 <ref bean="tokenInterceptor" />
     <bean id="tokenInterceptor" class="com.xidian.wq.imaopay.interceptor.cxf.TokenInterceptor" />
      -->
      
     <!-- address-请求路径 -->
     < jaxrs:server id = "imaoPayService" address = "/ipservice" >
         <!-- 输入拦截器设置 -->
         < jaxrs:inInterceptors >
         </ jaxrs:inInterceptors >
         
         <!-- 输出拦截器设置 -->
         < jaxrs:outInterceptors >
         </ jaxrs:outInterceptors >
          
         <!-- serviceBeans-暴露的WebService服务类 -->
         < jaxrs:serviceBeans
             < ref bean = "regUser" />
         </ jaxrs:serviceBeans >
           
         <!-- 支持的协议 -->
         < jaxrs:extensionMappings
             < entry key = "json" value = "application/json" /> 
             < entry key = "xml"  value = "application/xml" /> 
         </ jaxrs:extensionMappings
         
         <!-- 编码格式 -->
         < jaxrs:languageMappings >
                < entry key = "en" value = "en-gb" />
         </ jaxrs:languageMappings >
         
     </ jaxrs:server >

    根据代码的备注,泥瓦匠想让大家记住几点重要性的点。

address=”/ipservice” 表示我们以后用此地址访问所提供的地址。

<jaxrs:serviceBeans><jaxrs:serviceBeans/> 之间加入我们要暴露出去的服务类。这里泥瓦匠以一个简单的注册类来提供。

jaxrs:extensionMappings 是表示我们需要支持的协议。

 

3、UserInfoController是我们需要完成的暴露服务类。下面泥瓦匠说一下初设计(这点请大家指点指点)。

 

三层初设计,实现WebService接口层

    初设计:

    按着原来的SpringMVC的三层架构,我这边把原来的Controller层转为暴露在出来的接口服务类。自然View层也就没了。

 

UserInfoController的代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
@Path("/user")// 访问路径
@Produces("*/*")
public class UserInfoController
{
     @POST
     @Path("/doTest")// 访问路径
     @Produces({MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON})// 响应内容 MIME 类型
     public String doTest(String requestXml)//@QueryParam("regRequestXml")
     {
         System.out.println("服务端获取到客户端的报文如下:\n"+requestXml);
         
         /* 构造响应报文 */
         String responseXml = "响应的报文内容";//构造报文 XML 格式的字符串
         
         return responseXml;
     }
}

暴露的接口层,也可以用inteface类加实现类来完成。泥瓦匠觉得多此一举,兴许我大言不惭。

    泥瓦匠总结如下:

    @POST 表示HTTP的访问模式

    @Path 表示访问路径

    @Produces({MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON}) 响应内容 MIME 类型

 

    泥瓦匠还在上一篇写过了对报文的处理:JAXB xml与javaBean的转换。具体请查阅。

 

HTTPClient 客户端,并实现简单调用

    “实践出真理。”拿出来遛一遛即可。泥瓦匠简单的用HTTPClient访问

核心代码如下:

?
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
50
51
52
53
54
55
/**
     * 注册报文发送案例
     */ 
    private void doRegXml() throws Exception
   
        /** 构造测试报文头对象 */
        String randNum = RandomStringUtils.randomNumeric(8);//八位
        String timeStr = TimeUtil.getTimeSimple();
        DataBean dataBean = new DataBean();
        dataBean.setBatch_no("N20150204");
        dataBean.setData_type("000001");
        dataBean.setVersion("v1.0");
        dataBean.setUser_name("13957706713");
        dataBean.setMsg_sign("未知");
        dataBean.setRd_num(randNum);
        dataBean.setRd_time(timeStr);
        dataBean.setK_sign(TokenCheckUtil.getSignature(null, timeStr, randNum));
 
        /** 构造测试报文体对象 */
        RegBean regBean = new RegBean();
        regBean.setReg_sn("REG20150204");
        regBean.setUser_id(15);
        regBean.setReg_no("33");
        regBean.setReg_way("pc");
        regBean.setSet_time(TimeUtil.getTimeAll());
        regBean.setRet_url("未知");
        regBean.setRemarks("无备注");
        
        RegBean regBean2 = new RegBean();
        regBean2.setReg_sn("REG20150203");
        regBean2.setUser_id(13);
        regBean2.setReg_no("44");
        regBean2.setReg_way("mobile");
        regBean2.setSet_time(TimeUtil.getTimeAll());
        regBean2.setRet_url("未知");
        regBean2.setRemarks("无备注");
        
        List< RegBean > regBeans = new ArrayList< RegBean >();
        regBeans.add(regBean);
        regBeans.add(regBean2);
        
        MsgRegBean msgRegBean = new MsgRegBean();
        msgRegBean.setDataBean(dataBean);
        msgRegBean.setRegBeans(regBeans);
        
        String regRequestXml = JaxbObjectAndXmlUtil.object2Xml(msgRegBean);//构造报文 XML 格式的字符串
        
        System.out.println("\n 请求报文XML: \n"+regRequestXml);
        
        /** 获取的Result报文,然后客户端处理业务。 */
        String resultString = HttpUtil.doPost("http://localhost:8080/imaopay/pay/ipservice/user/doTest",regRequestXml);
        
        System.out.println("\n 获取的Result报文: \n"+resultString);
        
    }

运行后,控制台打印出如下结果:

客户端打印如下:

image

服务端获取结果如下:

image


相关文章
|
2月前
|
测试技术 持续交付 UED
软件测试的艺术:确保质量的实战策略
在软件开发的舞台上,测试是那把确保每个功能如交响乐般和谐奏响的指挥棒。本文将深入探讨软件测试的重要性、基本类型以及如何设计高效的测试策略。我们将通过一个实际的代码示例,展示如何运用这些策略来提升软件质量和用户体验。
|
26天前
|
XML Java 数据格式
探索Spring之利剑:ApplicationContext接口
本文深入介绍了Spring框架中的核心接口ApplicationContext,解释了其作为应用容器的功能,包括事件发布、国际化支持等,并通过基于XML和注解的配置示例展示了如何使用ApplicationContext管理Bean实例。
53 6
|
2月前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
71 3
|
2月前
|
缓存 测试技术 Apache
告别卡顿!Python性能测试实战教程,JMeter&Locust带你秒懂性能优化💡
告别卡顿!Python性能测试实战教程,JMeter&Locust带你秒懂性能优化💡
65 1
|
2月前
|
前端开发 数据管理 测试技术
前端自动化测试:Jest与Cypress的实战应用与最佳实践
【10月更文挑战第27天】本文介绍了前端自动化测试中Jest和Cypress的实战应用与最佳实践。Jest适合React应用的单元测试和快照测试,Cypress则擅长端到端测试,模拟用户交互。通过结合使用这两种工具,可以有效提升代码质量和开发效率。最佳实践包括单元测试与集成测试结合、快照测试、并行执行、代码覆盖率分析、测试环境管理和测试数据管理。
80 2
|
2月前
|
前端开发 JavaScript 数据可视化
前端自动化测试:Jest与Cypress的实战应用与最佳实践
【10月更文挑战第26天】前端自动化测试在现代软件开发中至关重要,Jest和Cypress分别是单元测试和端到端测试的流行工具。本文通过解答一系列问题,介绍Jest与Cypress的实战应用与最佳实践,帮助开发者提高测试效率和代码质量。
56 2
|
3月前
|
存储 安全 Java
|
3月前
|
自然语言处理 Java API
Spring Boot 接入大模型实战:通义千问赋能智能应用快速构建
【10月更文挑战第23天】在人工智能(AI)技术飞速发展的今天,大模型如通义千问(阿里云推出的生成式对话引擎)等已成为推动智能应用创新的重要力量。然而,对于许多开发者而言,如何高效、便捷地接入这些大模型并构建出功能丰富的智能应用仍是一个挑战。
369 6
|
3月前
|
缓存 NoSQL Java
Spring Boot与Redis:整合与实战
【10月更文挑战第15天】本文介绍了如何在Spring Boot项目中整合Redis,通过一个电商商品推荐系统的案例,详细展示了从添加依赖、配置连接信息到创建配置类的具体步骤。实战部分演示了如何利用Redis缓存提高系统响应速度,减少数据库访问压力,从而提升用户体验。
177 2