問題:すべての注釈とのインターフェースとして定義されたルート リソース クラス。CXFServlet は、インターフェイスで定義されているにもかかわらず、impl クラスでの POST 操作を認識できません。すべての注釈が impl クラスにコピーされると、正常に動作します。
注:インターフェイスでのみ定義されている場合、GET は正常に機能します。POST のみが問題を引き起こしています。
@Path("foo/")
public interface TestService {
@Path("foo/{id}")
@GET
@Produces("text/plain")
public String getIt(String id);
@Path("foo")
@POST
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
@ElementClass(response = Bar.class)
public Response createStuff(@Context MessageContext context,
Bar bar);
}
@Features(features = "org.apache.cxf.feature.LoggingFeature")
public class TestServiceImpl implements TestService {
@Override
public String getIt(String id) {
return "Hi there!";
}
@Override
public Response createStuff(@Context MessageContext context,
Bar bar) {
bar.set...
bar.set...
return Response.ok(bar).build();
}
Beans.xml {
<jaxrs:server id="testService" address="/test">
<jaxrs:serviceBeans>
<ref bean="testservice1"/>
</jaxrs:serviceBeans>
</jaxrs:server>
<bean id="testservice1" class="foo.bar.TestServiceImpl"/>
}
Web.xml
<listener>
<listener-class>
org.springframework.web.context.ContextLoaderListener
</listener-class>
……..
</listener>
<servlet-name>CXFServlet</servlet-name>
<url-pattern>/*</url-pattern>
</servlet-mapping>
Tomcat7.0 サーバーから印刷された再発行: Chrome Postman の使用
情報: 受信メッセージ
ID: 1
Address: http://localhost:8080/<war-name>/test/foo/foo
Encoding: ISO-8859-1
Http-Method: POST
Content-Type: application/json
Headers: {Accept=[*/*], accept-encoding=[gzip,deflate,sdch], accept-language=[en-US,en;q=0.8], cache-control=[no-cache], connection=[keep-alive], Content-Length=[144], content-type=[application/json], host=[localhost:8080], origin=[chrome-extension://fdmmgilgnpjigdojojpjoooidkmcomcm], user-agent=[Mozilla/5.0 (Macintosh; Intel Mac OS X 10_8_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/29.0.1547.76 Safari/537.36]}
Payload: {
"bar": {
"create_time": "Fri Sep 20 17:51:40 PDT 2013",
"update_time": "e0739141-1e8c-48ad-b8ad-410331b3dba3",
}
}
エラー: 2013 年 9 月 21 日 12:13:05 PM org.apache.cxf.jaxrs.utils.JAXRSUtils findTargetMethod 警告:要求パス "//test/foo/foo" に一致する操作が見つかりません。相対パス: /foo、HTTPメソッド: POST、ContentType: アプリケーション/json、Accept: / ,. 詳細については、FINE/TRACE ログ レベルを有効にしてください。2013 年 9 月 21 日 12:13:05 午後 org.apache.cxf.interceptor.LoggingOutInterceptor
INFO: Outbound Message
---------------------------
ID: 1
Response-Code: 404
Content-Type: text/xml
Headers: {Allow=[GET, OPTIONS, HEAD], Date=[Sat, 21 Sep 2013 19:13:05 GMT], Content-Length=[0]}