1

Jetty6を埋め込みモードで使用しています。ContextHandlerCollectionにいくつかのサーブレットがあります。この問題を超えて、サーブレットは異なるURLで正常に動作します。

ContextHandlerCollection contexts = new ContextHandlerCollection();
server.setHandler(contexts);
HandlerContainer mainhandler = contexts;

    Context qxrpc = new Context(contexts,"/api",Context.SESSIONS);

    ServletHolder rpcServHolder = new ServletHolder(new FrzRpcServlet()); 
    rpcServHolder.setInitParameter("referrerCheck", "public"); 
            // allows cross-domain calls
    qxrpc.addServlet( rpcServHolder, "*.qxrpc");

    Context statscontext =new Context(contexts,"/stats",Context.SESSIONS);
    ServletHolder statsHolder = new ServletHolder(new FrzStatsServlet());
    statsHolder.setInitParameter("restrictToLocalhost", "false"); 
                // allows cross-domain calls        
    statscontext.addServlet(statsHolder, "/*");

    Context hellocontext = new Context(contexts,"/hello", Context.SESSIONS);        
    hellocontext.addServlet(new ServletHolder(new HelloServlet("HELLO TEST: ")),
                                          "/*");

    Context zdbcontext = new Context(contexts,"/zdb", Context.ALL);     
    ServletHolder zdbHolder = new ServletHolder(new FrzZdbServlet());
    statsHolder.setInitParameter("restrictToLocalhost", "false");
            // allows cross-domain calls        

    zdbcontext.addServlet(zdbHolder, "/*");

    Context root = new Context(mainhandler,"/",Context.SESSIONS);
    root.setResourceBase(docroot);
    root.addServlet(DefaultServlet.class, "/");  

POSTリクエストがサーバーに届いていることはわかっています。ngrepの出力は次のとおりです。

T 127.0.0.1:51634 -> 127.0.0.1:8080 [AP]
GET /zdb/test.123:1.1.local1.stringtest HTTP/1.1..Host: 127.0.0.1:8080..Connection: keep-alive..Referer: http://127.0.0.1:8888/GWT_ZDB_editor.html?gwt.codesvr=127.0.0.1:9997..Origin: http://127.0.0.1:8888..User-Agent: Mozilla/5.0 (X11; Linux i686) AppleWebKit/534.24 (KHTML, like Gecko) Chrome/11.0.696.71 Safari/534.24..Content-Type: text/plain; charset=utf-8..Accept: */*..Accept-Encoding: gzip,deflate,sdch..Accept-Language: en-US,en;q=0.8..Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.3....      
##
T 127.0.0.1:8080 -> 127.0.0.1:51634 [AP]
  HTTP/1.1 200 OK..Access-Control-Allow-Origin: *..Content-Type: application/json; charset=ISO-8859-1..Content-Length: 124..Server: Jetty(6.1.15)....                                                     
##
T 127.0.0.1:8080 -> 127.0.0.1:51634 [AP]
  { "r":0,"D":"test.123:1.1.local1.stringtest","m":"OK","t":0,"p": {"ztype": "STRING", "dat" : { "cp":0, "v": "test12131" }}}                                                                            
##

POSTが失敗しました-200OKを報告します-しかしサーブレットに到達しません

T 127.0.0.1:51634 -> 127.0.0.1:8080 [AP]
OPTIONS /zdb/test.123:1.1.local1.stringtest/put HTTP/1.1..Host: 127.0.0.1:8080..Connection: keep-alive..Referer: http://127.0.0.1:8888/GWT_ZDB_editor.html?gwt.codesvr=127.0.0.1:9997..Access-Control-Request-Method: POST..Origin: http://127.0.0.1:8888..User-Agent: Mozilla/5.0 (X11; Linux i686) AppleWebKit/534.24 (KHTML, like Gecko) Chrome/11.0.696.71 Safari/534.24..Access-Control-Request-Headers: content-type..Accept: */*..Accept-Encoding: gzip,deflate,sdch..Accept-Language: en-US,en;q=0.8..Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.3....                                                        
#
T 127.0.0.1:8080 -> 127.0.0.1:51634 [AP]
  HTTP/1.1 200 OK..Allow: GET, HEAD, POST, TRACE, OPTIONS..Content-Length: 0..Server: Jetty(6.1.15)...
  .                

私が理解できないのは、doGet()が呼び出されているのに、doPost()が呼び出されていない理由です。問題のサーブレットはFrzZdbServletです。

Googleで多数のスレッドが見つかりましたが、Jettyの人々は例を指摘しているだけであり、コンテキストの例に対してはdo doGet()のみを実装しています。ここのように

また、GWTコードから投稿しており、content-type application/jsonを使用しています。これが問題になる可能性がありますか?任意のポインタをいただければ幸いです。

4

1 に答える 1

0

私のコンテキストは明らかに content-type: application/json の POST を受け入れませんでした。クライアントコードでこれを削除すると修正されました。他の誰かが入力した場合は、感謝します。

于 2011-06-29T07:13:10.347 に答える