【ajax跨域问题解决之jsonp】

本文介绍了如何通过定义JavaScript回调函数m来处理Ajax请求的结果。使用jQuery的$.ajax方法,设置类型为GET,dataType为jsonp,并指定jsonpCallback为m。服务器端根据接收到的callback参数,返回格式化的JSON字符串。处理返回乱码问题,通过在@RequestMapping中设置charset为UTF-8。整个流程展示了前端与后端如何协同完成跨域数据的获取和处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. 定义处理结果的js函数:
    function m(p1){
        console.log(p1)
    }
  1. ajax请求,同时指定拿到结果后的回调函数
    $.ajax({
        url:"xxx",
        type:"GET",
        dataType: 'jsonp',
        jsonpCallback:"m", // jsonp指定回调函数参数名,jsonpCallback指定回调函数
        contentType: "application/jsonp; charset=utf-8",
        success:function (param0,param1,param2){
                console.log(param0,param1,param2)
            },
        error:function (param0,param1,param2){
                console.log(param0,param1,param2)
            },
        complete:function (param0,param1,param2){
                console.log(param0,param1,param2)
            }
    });
  1. 服务端进行处理,当有callback参数时,返回对应的格式String。(方法名+“(”+‘服务端结果String’ +“)”)
    @ResponseBody
    @RequestMapping(method = RequestMethod.GET, value = "/xxx",produces = "text/plain;charset=UTF-8")
    public String getSrMsg(HttpServletRequest request, HttpServletResponse servletResponse){
        String callBack = request.getParameter("callback");
        if(callBack != null){
            return callBack + "(" + JSON.toJSONString(response) + ")";
        }
        return JSON.toJSONString(response);
    }
  1. 解决返回乱码
@RequestMapping(method = RequestMethod.GET, value = "/xxx",produces = "text/plain;charset=UTF-8")
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Jonny Jiang-zh

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值