使用CXF开发WebService程序的总结(五):基于Map数据类型处理的的客户端和服务端代码的编写
1. 首先我们按照List或数组等处理方式来处理Map,看看效果
/**
* 查询所有班级信息加上对应的学生列表
*
* @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的方法
/**
* 查询所有班级信息加上对应的学生列表
*
* @return
*/
@XmlJavaTypeAdapter(value = MapAdapter.class)
public Map<String, List<User>> findAllUsers();
这里的 类MapAdapter 是 用来进行编排和编排的
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
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. 客户端调用测试
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数据类型处理的的客户端和服务端代码的编写的更多相关文章
- 使用CXF开发WebService程序的总结(四):基于bean的客户端和服务端代码的编写
1. 在原服务端项目 ws_server中添加两个bean 1.1 添加两个类 User 和 Clazz package com.lonely.pojo; public class User { ...
- 根据wsdl,apache cxf的wsdl2java工具生成客户端、服务端代码
根据wsdl,apache cxf的wsdl2java工具生成客户端.服务端代码 apache cxf的wsdl2java工具的简单使用: 使用步骤如下: 一.下载apache cxf的包,如apac ...
- 使用CXF开发WebService程序的总结(六):结合拦截器使用
1. 使用CXF提供的拦截器 拦截器在我看来分为两端两向,两端分为:客户端和服务端,两向(方向)分为:进(in)和出(out),即大致四类拦截器. 在这里利用cxf提供的 日志拦截器举例 1.1 在服 ...
- 使用CXF开发WebService程序的总结(三):创建webservice客户端
1.创建一个maven子工程 ws_client,继承父工程 1.1 修改父工程pom配置 <modules> <module>ws_server</module> ...
- 使用CXF开发WebService程序的总结(七):Spring+CXF+Mybatis+Mysql共同打造的服务端示例
通过该demo,可以 熟悉下 spring+cxf+maven+mybatis+mysql等常见后端技术整合 1. 在前面的 父工程 ws_parent 中 添加依赖 由于原来的项目是使用的cxf依赖 ...
- 使用GSoap开发WebService客户端与服务端
Gsoap 编译工具提供了一个SOAP/XML 关于C/C++ 语言的实现, 从而让C/C++语言开发web服务或客户端程序的工作变得轻松了很多. 用gsoap开发web service的大致思路 我 ...
- 【WebService】使用CXF开发WebService(四)
CXF简介 Apache CXF = Celtix + XFire,开始叫 Apache CeltiXfire,后来更名为 Apache CXF 了,以下简称为 CXF.CXF 继承了 Celtix ...
- 3.使用CXF开发webService
CXF 简介 关于 Apache CXF Apache CXF = Celtix + XFire,Apache CXF 的前身叫 Apache CeltiXfire,现在已经正式更名为 Apache ...
- struts1+spring+myeclipse +cxf 开发webservice以及普通java应用调用webservice的实例
Cxf + Spring+ myeclipse+ cxf 进行 Webservice服务端开发 使用Cxf开发webservice的服务端项目结构 Spring配置文件applicationCont ...
随机推荐
- Miniui 表单验证
自定义表单验证: input输入框的表单验证可通过vtype和onvalidation事件两种方式实现 可编辑列表(例如div)的表单验证只能通过vtye来实现表单验证 (1)vtype方式: jsp ...
- C++如何限制对象在堆上或栈上生成
1,限制类的对象只能生成在栈上 将 operator new 各种原型设为私有 #include <iostream> class OnlyOnStack { public: OnlyOn ...
- JavaScript getClass() 函数
定义和用法 getClass() 函数可返回一个 JavaObject 的 JavaClass. 语法 getClass(javaobj) 参数 描述 javaobj 一个 JavaObject 对象 ...
- scp 传输命令
scp -r 文件名 用户名@地址:路径 -r 代表上传文件夹
- 【转】数组指针&指针数组
转自:https://www.cnblogs.com/mq0036/p/3382732.html 数组指针和指针数组的区别 数组指针(也称行指针)定义 int (*p)[n];()优先级高,首先说明p ...
- 查看进程CPU、内存使用情况
本文介绍通过ps和top查看进程的cpu.内存等使用情况. 1.ps命令 1.1 概览 ps命令相关参数定义: -e 或者-A,选择所有的进程: -L 显示线程: -o 自定义输出格式: 输出格式: ...
- kotlin之字符串
在kotlin 中 使用String 表示字符串类型,如下二类字符串 一 普通字符串 var s1 = "hello world" 二 保留原始格式的字符串 var s2 = &q ...
- react介绍、环境搭建、demo运行实例
React官网:https://reactjs.org/docs/create-a-new-react-app.html cnpm网址:http://npm.taobao.org/ 1.react介绍 ...
- Interface default method介绍
一.introduce interface default method Introduce default methodWrite the default method at interfaceTh ...
- Python基本语法_函数_返回值
目录 目录 前言 函数的返回值 在函数中Return和Print的区别 函数中的文档 前言 函数的返回值是函数重要的组成部分.函数的根本在于实现程序的部分功能,所以很多时候我们需要将函数执行后的结果返 ...