在测试的过程中遇到了一个奇怪的异常:
com.sun.xml.internal.messaging.saaj.soap.SOAPVersionMismatchException:
Cannot create message: incorrect content-type for SOAP version.
Got: application/soap+xml;
action="http://smarttrust.com/opm/ws/opm/ActivateRequest";
charset=UTF-8
Expected: text/xml
通过异常信息,可以很明显的发现是携带SOAP消息的HTTP报文请求头的Content-Type字段出了问题
通过抓包可以看到HTTP报文请求头的格式是下面这个样子的(还要注意的一点是,没有SOAPAction字段,而是action字段)
POST /opm HTTP/1.1
Content-Type: application/soap+xml; charset=UTF-8;
action="http://smarttrust.com/opm/ws/opm/ActivateRequest"
User-Agent: Axis2
Host: 10.160.68.107:9010
Transfer-Encoding: chunked
之后我新建了一个测试工程,仔细的查看了下Axis2自动生成的代码,发现有这么一段:
public MathStub(
org.apache.axis2.con