1

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 なしで) 作成し、メソッドを実行しようとします。

どんな助けでも大歓迎です

4

1 に答える 1