1. 首先我们按照List或数组等处理方式来处理Map,看看效果

1.1 在服务端的接口中添加以下方法
	/**
* 查询所有班级信息加上对应的学生列表
*
* @return
*/
public Map<String, List<User>> findAllUsers();

1.2 在实现类中模拟数据库访问实现

	@Override
public Map<String, List<User>> findAllUsers() {
Map<String, List<User>> map = new HashMap<>();
List<User> users1 = new ArrayList<>();
users1.add(new User(1, "aa", 1));
users1.add(new User(2, "bb", 1));
map.put("1班", users1); List<User> users2 = new ArrayList<>();
users2.add(new User(3, "cc", 2));
map.put("2班", users2); return map;
}

1.3 发布 看结果


1.4 结论:CXF只支持String,基本数据类型,JavaBean类型,List集合,数组的转化,不支持Map及非JavaBean的类型的转换。


2. 解决CXF不能处理Map的方法

解决思路就是  将 Map通过适配器 转成 cxf可以处理的数据类型
2.1 在服务端的接口中指定方法上添加注解  @XmlJavaTypeAdapter(value = MapAdapter.class),例如如下:
/**
* 查询所有班级信息加上对应的学生列表
*
* @return
*/
@XmlJavaTypeAdapter(value = MapAdapter.class)
public Map<String, List<User>> findAllUsers();

这里的 类MapAdapter 是 用来进行编排和编排的

2.2 创建和实现转换类
package com.lonely.adapter;

import java.util.HashMap;
import java.util.List;
import java.util.Map; import javax.xml.bind.annotation.adapters.XmlAdapter; import com.lonely.pojo.MyClass;
import com.lonely.pojo.User; public class MapAdapter extends XmlAdapter<MyClass[], Map<String, List<User>>> { @Override
public Map<String, List<User>> unmarshal(MyClass[] v) throws Exception {
Map<String, List<User>> map = new HashMap<>();
for (MyClass myClass : v) {
map.put(myClass.getKey(), myClass.getValue());
}
return map;
} @Override
public MyClass[] marshal(Map<String, List<User>> v) throws Exception {
MyClass[] myClasses = new MyClass[v.size()];
int i = 0;
for (String key : v.keySet()) {
myClasses[i] = new MyClass();
myClasses[i].setKey(key);
myClasses[i].setValue(v.get(key));
i++;
}
return myClasses;
} }

在这里用到了 MyClass[] ,MyClass是对我们的Map数据做得一个封装,里面实际上跟map一样。有key和value


2.3 自定义bean MyClass
package com.lonely.pojo;

import java.util.List;

/**
* map转换的 自定义bean
*
* @author 15072
*
*/
public class MyClass { private String key;
private List<User> value; public String getKey() {
return key;
} public void setKey(String key) {
this.key = key;
} public List<User> getValue() {
return value;
} public void setValue(List<User> value) {
this.value = value;
} public MyClass() {
super();
// TODO Auto-generated constructor stub
} public MyClass(String key, List<User> value) {
super();
this.key = key;
this.value = value;
} }

2.4 至此,在来发布,发现发布成功,下面就是客户端调用测试




3. 客户端调用测试

3.1 编写测试
package com.lonely.client;

import java.util.List;

import com.lonely.server.HelloWs;
import com.lonely.server.HelloWsService;
import com.lonely.server.MyClass;
import com.lonely.server.MyClassArray;
import com.lonely.server.User; public class HelloInvoking { public static void main(String[] args) {
HelloWsService helloWsService = new HelloWsService();
HelloWs helloWs = helloWsService.getHelloWsPort();
// System.out.println(helloWs.sayHelloWs("dugu")); /*
* Clazz clazz = new Clazz(); clazz.setClassId(1); List<User> list =
* helloWs.findUsersByClassId(clazz); for (User user : list) {
* System.out.println(user.getUsername() + ":" + user.getClassId()); }
*/ MyClassArray myClassArray = helloWs.findAllUsers();
List<MyClass> list = myClassArray.getItem();
for (MyClass myClass : list) {
System.out.println("班级:" + myClass.getKey());
List<User> users = myClass.getValue();
for (User user : users) {
System.out.println("\t学生:" + user.getUsername());
}
}
}
}

3.2 查看结果 发现成功调用




使用CXF开发WebService程序的总结(五):基于Map数据类型处理的的客户端和服务端代码的编写的更多相关文章

  1. 使用CXF开发WebService程序的总结(四):基于bean的客户端和服务端代码的编写

    1. 在原服务端项目 ws_server中添加两个bean 1.1 添加两个类  User 和 Clazz   package com.lonely.pojo; public class User { ...

  2. 根据wsdl,apache cxf的wsdl2java工具生成客户端、服务端代码

    根据wsdl,apache cxf的wsdl2java工具生成客户端.服务端代码 apache cxf的wsdl2java工具的简单使用: 使用步骤如下: 一.下载apache cxf的包,如apac ...

  3. 使用CXF开发WebService程序的总结(六):结合拦截器使用

    1. 使用CXF提供的拦截器 拦截器在我看来分为两端两向,两端分为:客户端和服务端,两向(方向)分为:进(in)和出(out),即大致四类拦截器. 在这里利用cxf提供的 日志拦截器举例 1.1 在服 ...

  4. 使用CXF开发WebService程序的总结(三):创建webservice客户端

    1.创建一个maven子工程 ws_client,继承父工程 1.1 修改父工程pom配置 <modules> <module>ws_server</module> ...

  5. 使用CXF开发WebService程序的总结(七):Spring+CXF+Mybatis+Mysql共同打造的服务端示例

    通过该demo,可以 熟悉下 spring+cxf+maven+mybatis+mysql等常见后端技术整合 1. 在前面的 父工程 ws_parent 中 添加依赖 由于原来的项目是使用的cxf依赖 ...

  6. 使用GSoap开发WebService客户端与服务端

    Gsoap 编译工具提供了一个SOAP/XML 关于C/C++ 语言的实现, 从而让C/C++语言开发web服务或客户端程序的工作变得轻松了很多. 用gsoap开发web service的大致思路 我 ...

  7. 【WebService】使用CXF开发WebService(四)

    CXF简介 Apache CXF = Celtix + XFire,开始叫 Apache CeltiXfire,后来更名为 Apache CXF 了,以下简称为 CXF.CXF 继承了 Celtix ...

  8. 3.使用CXF开发webService

    CXF 简介 关于 Apache CXF Apache CXF = Celtix + XFire,Apache CXF 的前身叫 Apache CeltiXfire,现在已经正式更名为 Apache ...

  9. struts1+spring+myeclipse +cxf 开发webservice以及普通java应用调用webservice的实例

    Cxf + Spring+ myeclipse+ cxf 进行  Webservice服务端开发 使用Cxf开发webservice的服务端项目结构 Spring配置文件applicationCont ...

随机推荐

  1. C++入门经典-例3.23-使用嵌套循环输出乘法口诀表

    1:代码如下: // 3.23.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iomanip> #incl ...

  2. C++入门经典-例2.11-流输出小数控制

    1:代码如下: // 2.11.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> usin ...

  3. 第六周总结 & 实验报告(四)

    第六周小结 一.instanceof关键字         在Java中使用instanceof关键字判断一个对象到底是哪个类的实例,返回boolean类型 1.instanceof关键字的作用 例c ...

  4. HearthBuddy 第一次调试

    HearthBuddy https://www.jiligame.com/70639.html 解压缩包,打开hearthbuddy.exe直接运行就可以:不用替换mono.dll直接可用:不需要校验 ...

  5. leetcode 72. 编辑距离

    /***** 定义状态: DP[i][j]其中i表示word1前i个字符,j表示Word2前i个字符 DP[i][j]表示单词1前i个字符匹配单词2前j个字符,最少变换次数: 状态转移: for i: ...

  6. centos7 禁止root远程ssh直接登录

    修改/etc/ssh/sshd_config文件,将 #PermitRootLogin yes 修改为 PermitRootLogin no   查看 more /etc/ssh/sshd_confi ...

  7. apache配置静态缓存

    配置静态缓存:节省带宽,加快访问速度,提高用户体验.<IfModule mod_expires.c> ExpiresActive on ExpiresByType image/gif &q ...

  8. Screen Painter 程序设计

    一.Screen 的创建及维护, TCode:SE51 输入程序名称,单击[建立], 程序1000为SAP预留屏幕号,屏幕号必须定义1000外的其他数字,且最多不超过四位, 本例定义屏幕为SAP预留屏 ...

  9. Stream流实现斐波那契数列

    1.前言 我们都知道斐波那契数列有很多种实现方法,在jdk1.8以前没有流操作,只能通过递归或者迭代等其他方式来实现斐波那契数列, 但是jdk1.8以后,有了流操作,我们就可以使用流来实现斐波那契数列 ...

  10. 不错的点击li标签删除的例子

    <script type="text/javascript">function delElement(obj){ obj.parentNode.removeChild( ...