0

我想将一个json字符串作为纯字符串发布到一个动作中,然后使用gson将该字符串转换为List,但该字符串仍被jquery/webwork视为json对象,我使用的是jquery 1.43+webwork+gson,没有jquery json插件什么的。

这是行动:

public class ImageAction extends BaseAction {

    private String pks;

    public void setPks(String pks) {
        this.pks = pks;
        Gson gson=new Gson();
        List<Map> list=gson.fromJson(pks,new TypeToken<List<Map<String,String>>>(){}.getType());
        System.out.println(list.size());
    }

    ......
}

jQuery代码:

j$.ajax({
            url:approveUrl,
            data: {pks:'[{"userName":"theoffspring"}]'},
//            dataType:'json',
            type:'post',
//            traditional: true,
            success:function (response) {
                hideProgressBar(parent.document)
                if (response.result==false){
                    alert(response.msg);
                    return;
                }

//                document.location.reload();
            }

        })

我希望将 pks 作为通用字符串而不是 json 对象发布。但是当我调用 jquery 代码时,结果并没有调用 setPks 方法。这么奇怪。

4

2 回答 2

0

看看这个:http: //jsfiddle.net/flocsy/vuGL9/

您会看到您的 pks 实际上是根据需要作为字符串发送的,当它不是作为字符串 (pks2) 发送时,它看起来会有所不同。

PS:根据您的浏览器,查看 firebug 或检查元素中的网络选项卡:

pks: '[{"userName":"theoffspring"}]'

pks2[0][userName2]:'hehe'

所以可能你的服务器端做了一些魔法......

于 2012-05-31T07:03:26.833 回答
0

您还没有序列化您通过 ajax.serialize 在客户端使用 JSON.stringify() 发送的数据,发送它将被转换为单个字符串。

将您的代码修改为:

$.ajax({
            url:approveUrl,
            data:JSON.stringify(yourdata),
//            dataType:'json',
            type:'post',
//            traditional: true,
            success:function (response) {
                hideProgressBar(parent.document)
                if (response.result==false){
                    alert(response.msg);
                    return;
                }

//                document.location.reload();
            }

        })

这可能有效。

于 2012-05-31T07:24:13.493 回答