以https Web服务进行通信时,接收HTTP 302错误代码(Receiving HTTP 30

2019-10-20 04:04发布

我在Apache Tomcat上托管的Java Web服务。 Tomcat的Server.xml文件有一个这样的条目:

Connector port="8025" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443"

但是,端口8443(假设是SSL端口)被注释掉了。

使用HttpWatch的,我注意到,服务器重定向客户端请求http://sa-dev-sf.erp.net/testWSthree/service?wsdl 。 来代替https:// ..,做出如下中的HttpWatch头信息:(状态行)HTTP / 1.1 302实测值; 连接关闭位置sa-dev-sf.erp.net/testWSthree/service?wsdl

这里是我的客户测试类。 如果我在部署Tomcat服务器的客户端,并调用我得到错误的服务(见下面登录)。 请注意,从我的本地机器使用Eclipse IDE,这是工作的罚款

import a.Service;  //from wsimport
import a.ServiceImplService; //from wsimport

public class Call {
public String callTest(){  
    ServiceImplService serviceImpl = new ServiceImplService();
    Service s = serviceImpl.getServiceImplPort();
    final BindingProvider getResultBP = (BindingProvider) s ;
    getResultBP.getRequestContext().put(BindingProvider.ENDPOINT_ADDRESS_PROPERTY,"https://sa-dev.erp.xxxx.net/testWSthree/service");
    System.out.println(s.salaryUpgrade("sanjoy"));
}}

这里有wsimport生成的两个类:

@WebService(name = "Service", targetNamespace = "http://a/")
@SOAPBinding(style = SOAPBinding.Style.RPC)
public interface Service {
/**
 * @param name
 * @return returns java.lang.String
 */
@WebMethod(operationName = "SalaryUpgrade")
@WebResult(partName = "return")
@Action(input = "http://a/Service/SalaryUpgradeRequest", output = "http://a/Service/SalaryUpgradeResponse")
public String salaryUpgrade(
    @WebParam(name = "name", partName = "name")
    String name);
}

@WebServiceClient(name = "ServiceImplService", targetNamespace = "http://a/", wsdlLocation = 
"https://sa-dev.erp.xxxxx.net/testWSthree/service?wsdl")
public class ServiceImplService extends javax.xml.ws.Service
{

private final static URL SERVICEIMPLSERVICE_WSDL_LOCATION;
private final static WebServiceException SERVICEIMPLSERVICE_EXCEPTION;
private final static QName SERVICEIMPLSERVICE_QNAME = new QName("http://a/", "ServiceImplService");

static {
    URL url = null;
    WebServiceException e = null;
    try {
        url = new URL("https://sa-dev.erp.xxxxx.net/testWSthree/service?wsdl");
    } catch (MalformedURLException ex) {
        e = new WebServiceException(ex);
    }
    SERVICEIMPLSERVICE_WSDL_LOCATION = url;
    SERVICEIMPLSERVICE_EXCEPTION = e;
}

public ServiceImplService() {
    super(__getWsdlLocation(), SERVICEIMPLSERVICE_QNAME);
}

public ServiceImplService(WebServiceFeature... features) {
    super(__getWsdlLocation(), SERVICEIMPLSERVICE_QNAME, features);
}

public ServiceImplService(URL wsdlLocation) {
    super(wsdlLocation, SERVICEIMPLSERVICE_QNAME);
}

public ServiceImplService(URL wsdlLocation, WebServiceFeature... features) {
    super(wsdlLocation, SERVICEIMPLSERVICE_QNAME, features);
}

public ServiceImplService(URL wsdlLocation, QName serviceName) {
    super(wsdlLocation, serviceName);
}

public ServiceImplService(URL wsdlLocation, QName serviceName, WebServiceFeature... features) {
    super(wsdlLocation, serviceName, features);
}

/**
 * 
 * @return
 *     returns Service
 */
@WebEndpoint(name = "ServiceImplPort")
public a.Service getServiceImplPort() {
    return super.getPort(new QName("http://a/", "ServiceImplPort"), Service.class);
}

/**
 * 
 * @param features
 *     A list of {@link javax.xml.ws.WebServiceFeature} to configure on the proxy.  Supported features not in the <code>features</code> parameter will have their default values.
 * @return
 *     returns Service
 */
@WebEndpoint(name = "ServiceImplPort")
public a.Service getServiceImplPort(WebServiceFeature... features) {
    return super.getPort(new QName("http://a/", "ServiceImplPort"), Service.class, features);
}

private static URL __getWsdlLocation() {
    if (SERVICEIMPLSERVICE_EXCEPTION!= null) {
        throw SERVICEIMPLSERVICE_EXCEPTION;
    }
    return SERVICEIMPLSERVICE_WSDL_LOCATION;
}
}

这是当我打电话从Eclipse IDE中的Web服务工作正常。 但是,如果我在我们的Tomcat服务器部署此客户端应用程序并调用服务,我收到以下错误:

 Stacktrace:
org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:568)
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:470)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:390)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:334)
javax.servlet.http.HttpServlet.service(HttpServlet.java:728)

 root cause 
 javax.xml.ws.WebServiceException: Failed to access the WSDL at: https://sa-dev.erp.xxxxx.net/testWSthree/service?wsdl. It failed with: 
Got sa-dev-sf.erp.umasscs.net while opening stream from https://sa-dev.erp.xxxxx.net  /testWSthree/service?wsdl.
com.sun.xml.internal.ws.wsdl.parser.RuntimeWSDLParser.tryWithMex(RuntimeWSDLParser.java:173)
com.sun.xml.internal.ws.wsdl.parser.RuntimeWSDLParser.parse(RuntimeWSDLParser.java:155)
com.sun.xml.internal.ws.wsdl.parser.RuntimeWSDLParser.parse(RuntimeWSDLParser.java:120)
com.sun.xml.internal.ws.client.WSServiceDelegate.parseWSDL(WSServiceDelegate.java:257)
com.sun.xml.internal.ws.client.WSServiceDelegate.<init>(WSServiceDelegate.java:220)
com.sun.xml.internal.ws.client.WSServiceDelegate.<init>(WSServiceDelegate.java:168)
com.sun.xml.internal.ws.spi.ProviderImpl.createServiceDelegate(ProviderImpl.java:96)
javax.xml.ws.Service.<init>(Service.java:77)
a.ServiceImplService.<init>(ServiceImplService.java:41)
ws.callWS.Call.callTest(Call.java:26)
org.apache.jsp.index_jsp._jspService(index_jsp.java:68)
org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:432)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:390)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:334)
javax.servlet.http.HttpServlet.service(HttpServlet.java:728)

 root cause 
 java.io.IOException: Got sa-dev-sf.erp.umasscs.net while opening stream from https://sa-    dev.erp.xxxxx.net/testWSthree/service?wsdl

 com.sun.xml.internal.ws.wsdl.parser.RuntimeWSDLParser.createReader(RuntimeWSDLParser.java:842)
com.sun.xml.internal.ws.wsdl.parser.RuntimeWSDLParser.resolveWSDL(RuntimeWSDLParser.java:283)

我真的很感激在这个问题上的任何帮助。 谢谢。

Answer 1:

你导入的信任存储SSL证书? 这可能是日食JVM有证书和部署没有。

的OpenSSL的s_client.First -connect -showcerts <的/ dev /空| OpenSSL的X​​509 -outform PEM> cert.pem这个命令将下载证书。 你可以做到这一点与指向您的服务器的Web地址的任何浏览器。

并列出与命令:keytool -list -keystore -storepass

密钥工具-import -alias -file derp.pem -keystore -storepass:如果您的证书是不是有你添加它



文章来源: Receiving HTTP 302 error code when communicating with https web service