在调用https的webService的时候几种常用的方法会出现安全错误,很多人说的是在jre里面装证书。。。那也太郁闷了吧
这里提供一种不用证书的方式
对方webService提供的接口,这个你应该要知道的吧,不知道的话就wsdl自己还原
- /**
- * 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();
- }
- /** 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里面的方法了