44

我创建了一个需要在 jersey 中发布的 json,由 grizzly 运行的具有 REST Web 服务的服务器获取需要输出的传入 json 对象。我正在尝试,但不确定如何正确实施。

import java.io.IOException;
import java.io.InputStream;

import net.sf.json.JSONObject;
import net.sf.json.JSONSerializer;

import org.apache.commons.io.IOUtils;

import javax.ws.rs.*;

    @Path("/helloworld")
    public class GetData {
        @GET
        @Consumes("application/json")
        public String getResource() {

            JSONObject obj = new JSONObject();
            String result = obj.getString("name");

            return result;      
        }                   

    } 

我有一个在加载时运行此方法的 html 文件

    function sendData() {
        $.ajax({
                url: '/helloworld',
                type: 'POST',
                contentType: 'application/json',
                data: {
                    name:"Bob",


                },
                dataType: 'json'
            });
            alert("json posted!");
        };
4

2 回答 2

90

要将 json 发送到服务器,首先必须创建 json

function sendData() {
    $.ajax({
        url: '/helloworld',
        type: 'POST',
        contentType: 'application/json',
        data: JSON.stringify({
            name:"Bob",
            ...
        }),
        dataType: 'json'
    });
}

这就是构建 ajax 请求以将 json 作为 post var 发送的方式。

function sendData() {
    $.ajax({
        url: '/helloworld',
        type: 'POST',
        data: { json: JSON.stringify({
            name:"Bob",
            ...
        })},
        dataType: 'json'
    });
}

json 现在将位于jsonpost var 中。

于 2012-04-11T17:27:18.860 回答
3

也可以使用FormData(). 但是您需要设置contentTypefalse

var data = new FormData();
data.append('name', 'Bob'); 

function sendData() {
    $.ajax({
        url: '/helloworld',
        type: 'POST',
        contentType: false,
        data: data,
        dataType: 'json'
    });
}
于 2015-05-28T00:23:20.813 回答