CXF报错后,独立解决->unwinding now Response was of unexpected text/html ContentType.

CXF URL-Pattern配置问题
本文记录了一次CXF项目中因修改web.xml的URL-Pattern而导致的调用错误。详细描述了错误现象及解决过程,指出问题在于URL-Pattern配置不当导致的路径不匹配。
部署运行你感兴趣的模型镜像

我的一个cxf项目, 在修改了web.xml的url-pattern后,调用报错,如下:

 

2009-12-8 10:09:00 org.apache.cxf.phase.PhaseInterceptorChain doIntercept
信息: Interceptor has thrown exception, unwinding now Response was of unexpected text/html ContentType.  Incoming portion of HTML stream: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><HTML><HEAD><LINK type="text/css" rel="stylesheet" href="/terminal/TermWebservice/?stylesheet=1"><meta http-equiv=content-type content="text/html; charset=UTF-8"><title>CXF - Service list</title></head><body><span class="heading">Available services:</span><br/><table cellpadding="1" cellspacing="1" border="1" width="100%"><tr><td><span class="porttypename">TermWebservice</span><ul><li>getTermXml</li><li>getTermList</li></ul></td><td><span class="field">Endpoint address:</span> <span class="value">http://localhost:8088/terminal/TermWebservice/TermWebservice</span><br/><span class="field">Wsdl:</span> <a href="http://localhost:8088/terminal/TermWebservice/TermWebservice?wsdl">{http://webservice.terminalmonitor.synjones.com/}TermWebserviceImplService</a><br/><span class="field">Target namespace:</span> <span class="value">http://webservice.terminalmonitor.synjones.com/</span></td></tr></table></body></html>
Exception in thread "main" javax.xml.ws.soap.SOAPFaultException: Response was of unexpected text/html ContentType.  Incoming portion of HTML stream: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><HTML><HEAD><LINK type="text/css" rel="stylesheet" href="/terminal/TermWebservice/?stylesheet=1"><meta http-equiv=content-type content="text/html; charset=UTF-8"><title>CXF - Service list</title></head><body><span class="heading">Available services:</span><br/><table cellpadding="1" cellspacing="1" border="1" width="100%"><tr><td><span class="porttypename">TermWebservice</span><ul><li>getTermXml</li><li>getTermList</li></ul></td><td><span class="field">Endpoint address:</span> <span class="value">http://localhost:8088/terminal/TermWebservice/TermWebservice</span><br/><span class="field">Wsdl:</span> <a href="http://localhost:8088/terminal/TermWebservice/TermWebservice?wsdl">{http://webservice.terminalmonitor.synjones.com/}TermWebserviceImplService</a><br/><span class="field">Target namespace:</span> <span class="value">http://webservice.terminalmonitor.synjones.com/</span></td></tr></table></body></html>
 at org.apache.cxf.jaxws.JaxWsClientProxy.invoke(JaxWsClientProxy.java:145)
 at $Proxy43.getTermList(Unknown Source)
 at com.synjones.terminalmonitor.webservice.client.Client.main(Client.java:26)
Caused by: org.apache.cxf.interceptor.Fault: Response was of unexpected text/html ContentType.  Incoming portion of HTML stream: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><HTML><HEAD><LINK type="text/css" rel="stylesheet" href="/terminal/TermWebservice/?stylesheet=1"><meta http-equiv=content-type content="text/html; charset=UTF-8"><title>CXF - Service list</title></head><body><span class="heading">Available services:</span><br/><table cellpadding="1" cellspacing="1" border="1" width="100%"><tr><td><span class="porttypename">TermWebservice</span><ul><li>getTermXml</li><li>getTermList</li></ul></td><td><span class="field">Endpoint address:</span> <span class="value">http://localhost:8088/terminal/TermWebservice/TermWebservice</span><br/><span class="field">Wsdl:</span> <a href="http://localhost:8088/terminal/TermWebservice/TermWebservice?wsdl">{http://webservice.terminalmonitor.synjones.com/}TermWebserviceImplService</a><br/><span class="field">Target namespace:</span> <span class="value">http://webservice.terminalmonitor.synjones.com/</span></td></tr></table></body></html>
 at org.apache.cxf.interceptor.StaxInInterceptor.handleMessage(StaxInInterceptor.java:73)
 at org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.java:226)
 at org.apache.cxf.endpoint.ClientImpl.onMessage(ClientImpl.java:641)
 at org.apache.cxf.transport.http.HTTPConduit$WrappedOutputStream.handleResponseInternal(HTTPConduit.java:2102)
 at org.apache.cxf.transport.http.HTTPConduit$WrappedOutputStream.handleResponse(HTTPConduit.java:1980)
 at org.apache.cxf.transport.http.HTTPConduit$WrappedOutputStream.close(HTTPConduit.java:1905)
 at org.apache.cxf.transport.AbstractConduit.close(AbstractConduit.java:66)
 at org.apache.cxf.transport.http.HTTPConduit.close(HTTPConduit.java:600)
 at org.apache.cxf.interceptor.MessageSenderInterceptor$MessageSenderEndingInterceptor.handleMessage(MessageSenderInterceptor.java:62)
 at org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.java:226)
 at org.apache.cxf.endpoint.ClientImpl.invoke(ClientImpl.java:469)
 at org.apache.cxf.endpoint.ClientImpl.invoke(ClientImpl.java:299)
 at org.apache.cxf.endpoint.ClientImpl.invoke(ClientImpl.java:251)
 at org.apache.cxf.frontend.ClientProxy.invokeSync(ClientProxy.java:73)
 at org.apache.cxf.jaxws.JaxWsClientProxy.invoke(JaxWsClientProxy.java:124)
 ... 2 more

 

 

主要是本人对错误描述不得要领, google一下关键信息: Interceptor has thrown exception, unwinding now Response was of unexpected text/html ContentType.  但是没有找到满意答案, 后来一看,提示的信息里有http://localhost:8088/terminal/TermWebservice/TermWebservice?wsdl, 这个url比我配置的多了一个TermWebservice

就是我刚刚多配置的web.xml的url-pattern,为<url-pattern>/TermWebservice/*</url-pattern>, 了以前是<url-pattern>/*</url-pattern> 的, 所以问题找到了, 是url要多加一个TermWebservice,

      所以在调用的client端,加上TermWebservice这样在调用就可以了, 因为错误比较误导人,而网上查询有没有, 希望能帮到有同样错误的兄弟。

您可能感兴趣的与本文相关的镜像

Stable-Diffusion-3.5

Stable-Diffusion-3.5

图片生成
Stable-Diffusion

Stable Diffusion 3.5 (SD 3.5) 是由 Stability AI 推出的新一代文本到图像生成模型,相比 3.0 版本,它提升了图像质量、运行速度和硬件效率

### 问题分析 当使用 Apache CXF 客户端调用 WebService 时,出现 `org.apache.cxf.interceptor.Fault: Response was of unexpected text/html ContentType` 错误,通常表示客户端接收到的响应内容类型不是预期的 `application/soap+xml` 或 `text/xml`,而是 `text/html`。这表明服务端返回了 HTML 页面而非 SOAP 响应,常见于服务未正确部署、请求路径错误或服务器发生内部异常导致重定向到错误页面(如 404 页面)等情况。 --- ### 解决方案 #### 1. 检查服务地址是否正确 确保客户端调用的服务地址与实际部署的服务地址一致。如果地址错误,服务器可能会返回 HTML 错误页面而不是 SOAP 响应。可以使用浏览器或 Postman 工具访问该 URL 验证是否能获取 WSDL 或正常响应[^3]。 ```java MyService service = new MyService(); MyPort port = service.getMyPort(); BindingProvider bp = (BindingProvider) port; bp.getRequestContext().put(BindingProvider.ENDPOINT_ADDRESS_PROPERTY, "http://correct/service/url"); ``` #### 2. 查看服务端日志 检查服务端日志是否有异常抛出,例如空指针、类加载失败等,这些异常可能导致服务未正常响应,从而返回 HTML 错误页面。服务端配置文件中也可能存在命名空间不一致或参数缺失等问题,导致无法正确处理请求。 #### 3. 设置 Content-Type 请求头 在客户端设置正确的 Content-Type 请求头,确保请求被识别为 SOAP 消息: ```java Map<String, Object> reqContext = ((BindingProvider) port).getRequestContext(); reqContext.put("Content-Type", "text/xml; charset=utf-8"); ``` #### 4. 使用拦截器查看原始响应 通过添加自定义拦截器打印原始响应内容,确认服务端返回的数据格式是否为 XML 或 SOAP 格式,以判断问题出在客户端解析阶段还是服务端响应阶段: ```java public class LoggingInInterceptor extends AbstractSoapInterceptor { public LoggingInInterceptor() { super(Phase.PRE_PROTOCOL); } @Override public void handleMessage(SoapMessage message) throws Fault { InputStream is = message.getContent(InputStream.class); String response = IOUtils.toString(is); System.out.println("Response: " + response); } } ``` #### 5. 检查服务端命名空间和接口定义 若服务端实现类未指定正确的命名空间或接口定义与客户端不一致,也可能导致解析失败。确保服务端类和方法注解中的命名空间与客户端生成的代码一致: ```java @WebService(targetNamespace = "http://example.com/ns") public class MyServiceImpl implements MyServicePort { // 方法实现 } ``` --- ### 相关问题
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值