晨祎
2017-11-23 09:25
采纳率: 100%
浏览 2.6k
已采纳

jQuery POST请求参数解析出错

index.jsp中构造param:
function hello() {
alert("hello");
var mydata = [{"word" : "12345"}];
alert(JSON.stringify(mydata));
$.post('hello', JSON.stringify(mydata), function(text, status) {
alert(text);
});
}

请求接收端的代码如下:
@Controller
public class HelloWorldController
{
@RequestMapping(value = "/hello",method = RequestMethod.POST)
public @ResponseBody HttpSayHelloTestRsp sayHello(
@RequestBody String req) throws UnsupportedEncodingException
{
String decodeStr = URLDecoder.decode(req,"utf-8");
System.out.println("-----------------收到Hello请求\r\n"+decodeStr );
return null;
}
}

但是在HelloWorldController端接收到的decodeStr是[{"word" : "12345"}]=
而且,在firfox浏览器的控制台界面,看到传输的参数是:[{"word" : "12345"}]:
请问各位大神,这是什么情况?

  • 写回答
  • 好问题 提建议
  • 追加酬金
  • 关注问题
  • 邀请回答

4条回答 默认 最新

  • qq_41047780 2017-11-23 11:03
    最佳回答

    首先没搞清楚你要干嘛,但是如果你纠结等号的问题话:
    @RequestBody String req --》请求是json数据,但是post应该不能发送json,换成ajax就没问题了
    function hello() {
    var mydata = [ {
    "word" : "12345"
    } ];
    $.ajax({
    url : '${pageContext.request.contextPath}/test.action',
    contentType : 'application/json',//请求json
    type : "post",
    dataType : 'json',
    data : JSON.stringify(mydata),
    success : function(data) {
    alert(data);
    }
    });
    }

    评论
    解决 无用
    打赏 举报
查看更多回答(3条)

相关推荐 更多相似问题