时间:2021-05-19
因项目需要,将之前使用过的webservice重新捡了起来,并且这次选择了使用不需要jar包的Java原生Jaxws。首先是wsimport的用法,先分享我的用法:cmd下先转到工程所在路径,然后运行以下命令
复制代码 代码如下:
wsimport -keep -extension -s ./src -p com.jaxws.test http://192.168.1.1:8080/service?wsdl
在com.jaxws.test的包下就能找到自动生成的各种客户端相关辅助类。这些类怎么用就不细说了,网上很多资料。然后就是自己编写调用类(我这里只是一个方法,会被调用到就行)
复制代码 代码如下:
public String jaxws(Object[] opArgs)
{
ServicesService service=new ServicesService();
//向SOAP添加表头
service.setHandlerResolver(new HandlerResolver(){
public List<Handler> getHandlerChain(PortInfo portInfo) {
List<Handler> handlerList = new ArrayList<Handler>();
//添加认证信息
handlerList.add(new ClientHandler());
return handlerList;
}
});
String result =service.getServicesPort().getResults(opArgs.toString());
//得到结果
System.out.println(result);
return result;
}
注意到这里的【//添加认证信息 handlerList.add(new ClientHandler());】,所以我们还需要新建一个ClientHandler类来实现认证消息的组装,如下:
复制代码 代码如下:
package com.jaxws.test;
import java.util.Set;
import javax.xml.namespace.QName;
import javax.xml.soap.*;
import javax.xml.ws.handler.MessageContext;
import javax.xml.ws.handler.soap.SOAPHandler;
import javax.xml.ws.handler.soap.SOAPMessageContext;
public class ClientHandler implements SOAPHandler<SOAPMessageContext> {
public boolean handleMessage(SOAPMessageContext ctx) {
//出站,即客户端发出请求前,添加表头信息
Boolean request_p=(Boolean)ctx.get(MessageContext.MESSAGE_OUTBOUND_PROPERTY);
if(request_p){
try {
SOAPMessage msg=ctx.getMessage();
SOAPEnvelope env=msg.getSOAPPart().getEnvelope();
SOAPHeader hdr=env.getHeader();
if(hdr==null) hdr=env.addHeader();
//添加认证信息头
//QName(String namespaceURI, String localPart, String prefix)
//QName(String namespaceURI, String localPart)
//QName(String localPart)
//@param namespaceURI:QName的名称空间
//@param localPart:QName的本地部分
//@param prefix:QName的前缀
QName name=new QName("http://csdc.info/", "Authentication", "wsse");
SOAPHeaderElement header = hdr.addHeaderElement(name);
//addChildElement(String localName, String prefix,String uri)
//addChildElement(String localName, String prefix)
//addChildElement(String localName)
//@param uri:新元素所属空间名称URI
//@param localName:新元素的本地名称
//@param prefix:新元素名称的空间前缀
//见JDK 1.6的API
SOAPElement userElement = header.addChildElement("Username", "wsse");
userElement.addTextNode("admin");
SOAPElement passElement = header.addChildElement("Password", "wsse");
passElement.addTextNode("admin");
msg.saveChanges();
//把SOAP消息输出到System.out,即控制台
msg.writeTo(System.out);
return true;
} catch (Exception e) {
e.printStackTrace();
}
}
return false;
}
@Override
public boolean handleFault(SOAPMessageContext context) {
// TODO Auto-generated method stub
return false;
}
@Override
public void close(MessageContext context) {
// TODO Auto-generated method stub
}
@Override
public Set<QName> getHeaders() {
// TODO Auto-generated method stub
return null;
}
}
这个类就把所有的soap消息都加上了一个头消息,我这里的头消息如下:
复制代码 代码如下:
<wsse:Authentication xmlns:wsse="http://csdc.info/">
<wsse:Username>admin</wsse:Username>
<wsse:Password>admin</wsse:Password>
</wsse:Authentication>
这样就实现了带soap头认证的基于jaxws的webservice客户端。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
一:PHP本身的SOAP所有的webservice都包括服务端(server)和客户端(client)。要使用php本身的soap首先要把该拓展安装好并且启用。
前面学习了,服务端验证,这篇文章中,我们接着学习客户端验证,客户端的验证,使用Jquery和Jquery插件来实现【jquery.validate.min.js
Android客户端和PHP、MySQL搭建的服务器之间的简单交互,实现登录功能。实现原理图:Handler消息机制原理:Handler机制主要包括4个关键对象
使用JQuery的validate插件做客户端验证非常方便,下面做一个使用validate插件验证用户注册信息的例子。本实例使用的是1.5版本。示例是在SSH下
有公网ipstep1:下载并安装客户端软件从本地linux机器登录到linux云服务器时,需要使用客户端软件建立连接。建议使用openssh发布的ssh工具进行