最近实际项目中使用到了WebService,简单总结下使用方式:
1、拿到接口:http://*******:8080/osms/services/OrderWebService?wsdl
我们可以将该接口地址在浏览器打开,查看其接口描述:

2、导出接口类,用以后续客户端调用,方法有两种:
方法一:
1)新建后缀名为“.wsdl”文件,直接拷贝上一步在浏览器打开的内容到该文件中:

在eclipse中新建一个WebService的Client项目:

选中刚新建的.wsdl文件:

eclipse会自动解析wsdl文件,并生成相应的类文件:

方法二:使用jdk自带的wsimport命令:
命令:e > wsimport -s . ********:2080/osms/services/OrderWebService?wsdl

打开e盘,我们可看到已经生成对应的java类文件(其中class文件可以忽略):

3、客户端调用:
以下环境为java环境,我们使用JaxWsProxyFactoryBean来调用:
package test;
import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.rmi.RemoteException;
import org.apache.commons.codec.binary.Base64;
import org.apache.commons.codec.digest.DigestUtils;
import org.apache.cxf.jaxws.JaxWsProxyFactoryBean;
import com.sf.osms.wbs.services.order.server.impl.OrderWebService;
//import com.sf.novatar.util.codec.Base64Codec;
public class Test_apiOrderService{
public static void main(String[] args) throws RemoteException {
JaxWsProxyFactoryBean svr = new JaxWsProxyFactoryBean();
//设置代理接口类
svr.setServiceClass(OrderWebService.class);
//设置接口调用地址
svr.setAddress("******:8080/osms/services/OrderWebService?wsdl");
//创建代理接口
OrderWebService orderWebService = (OrderWebService)svr.create();
//读取报文:参数为请求报文xml文件路径
String xml = readTxtFile("/config/"+"apiOrderService.xml");
//通过客户的validateCode加密报文数据 --全包加密
String data = decodingValidCode(xml);
System.out.println("加密报文:" + data);
//验证数据完整性加密 -- 签值 fc34c561a34f
String validateStr = jm("fc34c561a34f", xml);
//调用接口 --调用对方的接口
//当使用WEBSERVICE接口时,报文通过方法参数传入(三个参数分别为:xml报文、校验码、客户编码)
String s = orderWebService.sfexpressService(data, validateStr, "OSMS_1");
System.out.println("响应结果:" + s);
}
/**
* 报文加密
* @param orderData 报文
* @return
*/
private static String decodingValidCode(String orderData) {
// 1、使用org.apache.commons.codec.binary.Base64加密
return new Base64().encodeToString(orderData.getBytes());
// 2、使用sun.misc.BASE64Encoder加密
// return new sun.misc.BASE64Encoder().encode(orderData.getBytes());
}
/**
* 报文加签:验证报文完整性
* @param validCode 秘钥
* @param xml 报文
* verifyCode校验码的生成规则:接入IBS平台前,IBS平台系统管理员会为每个接入客户分配一个“密钥”,以下把密钥简称为checkword,verifyCode的生成规则为:
将xml报文进行Base64编码
将编码后的报文与checkword前后连接。
把连接后的字符串做MD5编码。
把MD5编码后的数据进行Base64编码,此时编码后的字符串即为verifyCode。
*/
public static String jm(String validCode ,String xml){
//校验加密测试
// xml = "123456";
// System.out.println("xml=" + xml);
// System.out.println("checkword=" + validCode);
//(1)xml+validCode
String bind = xml + validCode;
// System.out.println("xml+validCode:
" + bind);
//(2)对连接后的字符串做md5编码
String md5 = DigestUtils.md5Hex(bind);
System.out.println("md5连接后的字符串:" + md5);
//(3)把MD5编码后的数据进行Base64编码
// --1、使用sun.misc.BASE64Encoder加密
// BASE64Encoder base64Sun = new sun.misc.BASE64Encoder();
// String result = base64Sun.encode(md5.getBytes());
// --2、使用org.apache.commons.codec.binary.Base64加密
Base64 base64Apache = new Base64();
String result = base64Apache.encodeToString(md5.getBytes());
System.out.println("base64加签结果:" + result);
return result;
}
/**
* 读取接口xml文档
* @param filePath 接口文档路径
* @return
*/
public static String readTxtFile(String filePath) {
StringBuilder builder = new StringBuilder();
try {
String encoding = "UTF-8";
//请求报文输出
InputStream is = Test_apiOrderService.class.getResourceAsStream(filePath);
byte[] buf = new byte[3072];
int len = is.read(buf);
System.out.println("请求报文:
"+new String(buf,0,len,"utf-8"));
InputStreamReader read = new InputStreamReader(Test_apiOrderService.class
.getResourceAsStream(filePath), encoding);// 考虑到编码格式
BufferedReader bufferedReader = new BufferedReader(read);
String lineTxt = null;
while ((lineTxt = bufferedReader.readLine()) != null) {
builder.append(lineTxt);
}
read.close();
} catch (Exception e) {
e.printStackTrace();
}
return builder.toString();
}
}
由于在实际生产中,我们是需要对请求报文做动态赋值的,所以对接口做了从新封装:传入对象,解析取值,xml报文通过xslt模板转换,请求服务端,获取响应,解析对端报文。
改造后的工程目录如下,因为比较简单,就不详细写:

其中lib支持使用了apache-cxf-2.1.4.tar.gz
最后,附上测试结果:
