在調用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裏面的方法了