2012-02-29 24 views
4

OK Javaを使用してRESTサーバーを作成していますが、テストしようとしていますが、エラーコード500が表示されています。私はコードを踏んで、正しくフォーマットされたDataClassオブジェクトのArrayListを使ってこのメソッドの最後に到達したことを知っています(私はそれらを検査し、RESTフロントエンドなしで正常に実行します)。REST + Java +ステータス500内部エラー

ここで私はここで

@GET 
    @Produces(MediaType.APPLICATION_XML) 
    public List<DataClass> receiveXML(
      @DefaultValue("null") @QueryParam("artist") String artist, 
      @DefaultValue("null") @QueryParam("title") String title, 
      @DefaultValue("null") @QueryParam("album") String album, 
      @DefaultValue("null") @QueryParam("genre") String genre, 
      @DefaultValue("null") @QueryParam("type") String type, 
      @DefaultValue("false") @QueryParam("open") Boolean open, 
      @DefaultValue("false") @QueryParam("close") Boolean close, 
      @DefaultValue("noPath") @QueryParam("path") String path, 
      @DefaultValue("noKey") @QueryParam("key") String key, 
      @DefaultValue("null") @QueryParam("show") String show, 
      @DefaultValue("null") @QueryParam("season") String season, 
      @DefaultValue("null") @QueryParam("format") String format) 
    { 

     if(!artist.equals("null")) 
      this.artist = artist; 
     if(!title.equals("null")) 
      this.title = title; 
     if(!album.equals("null")) 
      this.album = album; 
     if(!genre.equals("null")) 
      this.genre = genre; 
     if(!type.equals("null")) 
      this.type = type; 
     if(!open.equals("false")) 
      this.open = open; 
     if(!close.equals("false")) 
      this.close = close; 
     if(!path.equals("noPath")) 
      this.path = path; 
     if(!key.equals("noKey")) 
      this.keyword = key; 
     if(!show.equals("null")) 
      this.show = show; 
     if(!season.equals("null")) 
      this.season = season; 
     if(!format.equals("null")) 
      this.format = format; 

     MultivaluedMap<String,String> queryParams = buildMap(); 
     List<DataClass> resp = receive(queryParams); 
     return resp;  
    } 

を呼んでいるREST方式でのDataClass

@XmlRootElement 
public class DataClass { 
    public String pathname; 
    ArrayList<String> parsedSet; 
    ResultSet resultSet; 
    public String id, path, type, category, size, update, idMeta, title, description; 
    public String genre, album, artist, show, season; 

    public DataClass(ResultSet resultSet){ 
     this.resultSet = resultSet; 
     parsedSet = new ArrayList<String>(); 
     setStringVariables(); 
    } 
    /** 
    * Sets the pathname variable of the local file to be returned 
    * @param pathname 
    */ 
    public DataClass(String pathname){ 
     this.pathname = pathname; 
    } 


     methods to set the fields... 

} 

そして、ここですが、私がサーバーを呼び出す方法です、私は、サーバーがあるため、正しく呼び出されていることを知っています私は文字列を返すテストメソッドを持っています。ここで

public static void testXML() { 
    //a map that adds parameters that will then be added to the the WebService 
    MultivaluedMap<String, String> queryParams = new MultivaluedMapImpl(); 
    queryParams.add("type", "music"); 
    //retrieve info for an artist in XML format 
    System.out.println(service.path("rest").path("media").queryParams(queryParams).accept(
      MediaType.APPLICATION_XML).get(String.class)); 
} 

は申し訳ありませんが、私はいくつかのもの

にreceiveXMLこの

@Path("/media") 
public class Server { 
} 

を持って定義されたクラスを含めるのを忘れて

Exception in thread "main" com.sun.jersey.api.client.UniformInterfaceException: GET http://localhost:8080/TigrisRESTServer/rest/media?type=music returned a response status of 500 Internal Server Error 
    at com.sun.jersey.api.client.WebResource.handle(WebResource.java:676) 
    at com.sun.jersey.api.client.WebResource.access$200(WebResource.java:74) 
    at com.sun.jersey.api.client.WebResource$Builder.get(WebResource.java:503) 
    at tigris.restserver.client.ourClient.testXML(ourClient.java:45) 
    at tigris.restserver.client.ourClient.main(ourClient.java:28) 

私の誤りであり、ここでウェブであります.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>RestServer</display-name> 
    <servlet> 
    <servlet-name>Tigris REST Server App</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>tigris.restserver.connection</param-value> 
    </init-param> 
    <load-on-startup>1</load-on-startup> 
    </servlet> 
    <servlet-mapping> 
    <servlet-name>Tigris REST Server App</servlet-name> 
    <url-pattern>/rest/*</url-pattern> 
    </servlet-mapping> 
</web-app> 

、これは正常に動作します(それがないすべての文字列を返すです)

ここでは、クライアント

public static void testTEST() { 
    System.out.println(service.path("rest").path("media").accept(
      MediaType.TEXT_PLAIN).get(String.class)); 
} 

ここで、サーバ側

@GET 
@Produces(MediaType.TEXT_PLAIN) 
public String sayPlainTextHello() { 
    return "Hello Server"; 
} 

が twain249

+1

500は、サーバ側のエラーを意味し、あなたが問題を把握するために、サーバーからのログ/出力をチェックする必要があります。 – willcodejavaforfood

答えて

1

ありがとうございますですあなたがマップしなければならない経路を含めるのを忘れてしまったようです。

@Path("/rest/") 

GET http://localhost:8080/TigrisRESTServer/rest/media?type=music 

URL/rest /に対してマップしたい場合は、例えば

、このリンクを参照してくださいJersey Documentation

+0

@Path( "/ media")はサーバーファイルの先頭にあります – twain249

+0

投稿したものだけでなく、スタックトレースも利用できますか? –

+0

これは完全なエラートレースです – twain249

関連する問題