3

RESTfulWebサービスを作成しました。

@POST
@Path("/test")
@Consumes({ MediaType.APPLICATION_JSON})
public String test(TestObject to)
{
    System.out.println(to.getTestString());
    return "SUCCESS";
}

@XmlRootElementで作成されたオブジェクトがあります

@XmlRootElement
public class TestObject implements Serializable {
    private static final long serialVersionUID = 1L;

    private String testString;

    public TestObject() {}

    public TestObject(String testString) {
        this.testString = testString;
    }

    public String getTestString() {
        return testString;
    }
    public void setTestString(String testString) {
        this.testString = testString;
    }
}

次に、次のajax呼び出しで呼び出してみます

$.ajax({
    url: 'http://localhost:8080/testPage/test/',
    type: 'POST',
    data: '{"testString":"test"}',
    dataType: 'text',
    contentType: "application/json; charset=utf-8",
    success: function(jqXHR, textStatus, errorThrown){
        alert('Success');
    },
    error: function(jqXHR, textStatus, errorThrown){
        alert("jqXHR - " + jqXHR.statusText + "\n" + 
              "textStatus - " + textStatus + "\n" + 
              "errorThrown - " + errorThrown);
    }
});

textStatusに対して単に「エラー」が返されることになります。私のテストサービスにも到達していないようです。テキスト/プレーンのみを渡すと、GETが機能し、POSTも機能するようになります。jsonを渡そうとすると、動作させることができません。

POSTERを使う!Firefoxのアドオン同じデータを渡すサービスを正常に呼び出すことができます。サービス側でリクエストヘッダーをキャッチするためにいくつかの追加のロギングを追加したので、少なくともリクエストを認識しているように見えますが、それでは何もしません。

以下は私がログから得たリクエストです。一番上はajaxで失敗したものです。一番下はPOSTERで成功したものです。(実際にはコードではありませんが、それを入れるのにこれ以上良いものはありません)

INFO: 1 * Server in-bound request
1 > OPTIONS http://localhost:8080/testPage/test 
1 > Host: localhost:8080
1 > User-Agent: Mozilla/5.0 (Windows NT 5.1; rv:13.0) Gecko/20100101 Firefox/13.0.1
1 > Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
1 > Accept-Language: en-us,en;q=0.5
1 > Accept-Encoding: gzip, deflate
1 > DNT: 1
1 > Connection: keep-alive
1 > Origin: http://localhost:8081
1 > Access-Control-Request-Method: POST
1 > Access-Control-Request-Headers: content-type
1 > Pragma: no-cache
1 > Cache-Control: no-cache
1 > 

INFO: 2 * Server in-bound request
2 > POST http://localhost:8080/testPage/test
2 > Host: localhost:8080
2 > User-Agent: Mozilla/5.0 (Windows NT 5.1; rv:13.0) Gecko/20100101 Firefox/13.0.1
2 > Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
2 > Accept-Language: en-us,en;q=0.5
2 > Accept-Encoding: gzip, deflate
2 > DNT: 1
2 > Connection: keep-alive
2 > Content-Type: application/json; charset=utf-8
2 > Content-Length: 22
2 > Cookie: JSESSIONID=bvizai6k0277
2 > Pragma: no-cache
2 > Cache-Control: no-cache
2 >
{"testString": "test"}

これから、jsonがサービスに渡されていないようです。上記のようにjsonを書き出してみましたが、JSON.stringifyを使用して作成しようとしましたが、どちらも成功しませんでした。

jqueryajax呼び出しでPOSTを使用してRESTfulWebサービスにjsonを送信しようとしたときに、私が間違っていることを誰かが知っていますか?

4

1 に答える 1

0

dataType: 'json'ajax呼び出しの代わりに試しましたdataType: 'text'か?

于 2012-09-08T01:32:11.683 に答える