0

所以我开始阅读这篇关于如何使用 Jersey 开发 Restful 服务的教程。我想开发将数据从 MySQL 数据库发送到 Android 客户端的 Rest 服务。我阅读并按照教程中的步骤制作了自己的资源类,但是当我尝试在 Apache 上运行该服务时,出现以下错误

我刚刚开始尝试使用 Web 服务和 Rest,我已经从那个 IBM 站点阅读了与该主题相关的信息,并且我认为我掌握了它,但我真的迷失了为什么不工作。

我的 web.xml 如下

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
  <display-name>TesterRest</display-name>
  <welcome-file-list>
    <welcome-file>index.html</welcome-file>
  </welcome-file-list>
 <servlet>
    <servlet-name>Jersey REST Service</servlet-name>
    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
    <init-param>
      <param-name>com.sun.jersey.config.property.packages</param-name>
      <param-value>com.mx.ipn.escom.testerRest.resources</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
  </servlet>

  <servlet-mapping>
    <servlet-name>Jersey REST Service</servlet-name>
    <url-pattern>/rest/*</url-pattern>
  </servlet-mapping>


</web-app>

这是我的资源类:

包 com.mx.ipn.escom.testerRest.resources;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.Context;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Request;
import javax.ws.rs.core.UriInfo;
import javax.xml.bind.annotation.XmlRootElement;

import com.mx.ipn.escom.testerRest.dao.TemaDao;
import com.mx.ipn.escom.testerRest.db.Connector;
import com.mx.ipn.escom.testerRest.modelo.Tema;

@XmlRootElement
@Path("/temas")
public class TemaResource {
    @Context
    UriInfo uriInfo;
    @Context
    Request request;

    @GET
    @Produces({MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML})
    public List<Tema> getTemas() throws SQLException{

        TemaDao temaDao = new TemaDao();        
        List<Tema> temas=temaDao.getTemas();
        temaDao.terminarSesion();

        return temas;
    }
}

我的数据库连接类工作正常,所以这不是问题。

我正在使用 Eclipse 3.6 开发和 Apache Tomcat 6。

我对 JAXB 完全陌生,所以如果有人能给我指导我错过了什么样的注释,我将不胜感激。

4

1 回答 1

1

根据您的屏幕截图,我认为您应该更新您的 web.xml 以具有正确的包名称:

<servlet>
  <servlet-name>Jersey REST Service</servlet-name>
  <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
  <init-param>
    <param-name>com.sun.jersey.config.property.packages</param-name>
    <param-value>com.mx.ipn.escom.testerRest.resources</param-value>
  </init-param>
  <load-on-startup>1</load-on-startup>
</servlet> 

您的mx配置中缺少 。

于 2012-08-12T16:56:11.330 回答