Tomcat にデプロイする必要がある Wink リソースにアクセスしようとしています。リソースコードは
@Path("/lookup")
public class LookupResource {
private static final Logger logger = LoggerFactory.getLogger(LookupResource.class);
private MetaService metaService;
/**
*
*/
public LookupResource() {
logger.debug("CTOR +-");
}
/**
* @return the metaService
*/
public MetaService getMetaService() {
return metaService;
}
/**
* @param metaService the metaService to set
*/
public void setMetaService(MetaService metaService) {
logger.debug(String.format("Setting Meta Svc: %s ", metaService));
this.metaService = metaService;
}
@GET
@Path("/states")
@Produces("application/json")
public JSONObject getStates() {
final String METHOD = "getMessage";
JSONObject answer = new JSONObject();
try {
logger.debug(String.format("%s +", METHOD));
List<Lookup> states = getMetaService().findStates();
for (Lookup state : states) {
answer.put("Lookup", state);
}
} catch (JSONException e) {
logger.debug("Problem", e);
} finally {
logger.debug(String.format("%s -", METHOD));
}
return answer;
}
}
Spring を web.xml に追加しました
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:META-INF/server/wink-core-context.xml
classpath:my-server.xml
classpath:my-webapp.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
そして、my-webapp.xml の春の構成で、リソースを登録しました
<bean id="lookupResource" class="com.codeheadllc.webapp.LookupResource" >
<property name="metaService" ref="metaService" />
</bean>
<bean class="org.apache.wink.spring.Registrar">
<property name = "instances">
<set>
<ref bean="lookupResource"/>
</set>
</property>
</bean>
tomcat をデプロイして起動すると、ロガーで LookupResource Bean がロードされ、metaService への参照を取得することがわかります。ただし、http:///my-webapp/lookup/states にアクセスすると、LookupResouce にアクセスする代わりに 404 メッセージが表示されます。骨の折れる見落としだと確信していますが、何が間違っているのかわかりません。RestServlet の web.xml にサーブレットを追加し、rest/* などのマッピングを追加すると、RestServlet は LookupResource の新しいインスタンスを (Spring IOC なしで) 作成し、メソッドを実行しようとします。
どんな助けでも大歓迎です