java调用https的webservice,https的wsdl 收藏
java调webService太正常了。。。
在调用https的webService的时候几种常用的方法会出现安全错误,很多人说的是在jre里面装证书。。。那也太郁闷了吧
这里提供一种不用证书的方式
对方webService提供的接口,这个你应该要知道的吧,不知道的话就wsdl自己还原
Java代码 复制代码
/**
* webService接口声明
* 包括两个方法:
* 1.获取微博authtoken
* 2.获取微博信息
* @author bo
* @version $Id: WeiboInterface.java,v 0.1 2009-9-1 上午09:59:05 bo Exp $
*/
public interface WeiboInterface{
// 获取微博authtoken
public String getWeiboAuthToken();
// 获取微博信息
public String getWeiboInfo();
}
Java代码 复制代码
/** webService地址 */
private static final String SERVICE_URL = "https://localhost/wsdl/services1/";
/** webService的名称空间 */
private static final String SERVICE_NAMESPACE = https://localhost/wsdls;
/** 服务名称 */
private static final String SERVICE_NAME = "weiboGetInfo";
/** http协议类型 */
private static final String HTTP_TYPE = "https";
/** 端口号 */
private static final int PORT = 443;
/**
* 初始化webService调用,设置访问webService的相关属性
*/
private void initService() {
ProtocolSocketFactory easy = new EasySSLProtocolSocketFactory();
Protocol protocol = new Protocol(HTTP_TYPE, easy, PORT);
Protocol.registerProtocol(HTTP_TYPE, protocol);
Service serviceModel = new ObjectServiceFactory().create(WeiboInterface.class,
"weiboService", SERVICE_NAMESPACE, null);
try {
service = (WeiboInterface) new XFireProxyFactory().create(serviceModel, SERVICE_URL
+ SERVICE_NAME);
} catch (MalformedURLException e) {
logger.error("初始化webService失败," + e);
}
//设置client的相关属性,设置传输数据的方式
Client client = ((XFireProxy) Proxy.getInvocationHandler(service)).getClient();
client.addOutHandler(new DOMOutHandler());
client.setProperty(CommonsHttpMessageSender.GZIP_ENABLED, Boolean.TRUE);
client.setProperty(CommonsHttpMessageSender.DISABLE_EXPECT_CONTINUE, "1");
client.setProperty(CommonsHttpMessageSender.HTTP_TIMEOUT, "0");
}
service就相当于将webService给初始化了,然后就可以直接service调用XXXInterface里面的方法了