Ajax跨域访问,访问成功但一直走error不走success的的问题解决

Ajax跨域访问,访问成功但一直走error不走success的的问题解决

通过搜索各种资料,终于解决啦,废话不多说了,还是老规矩直接上代码:

我这里用了jsonp,有想了解的点击 : jsonp

前端代码:

javascript 复制代码
  $.ajax({
                    type:'post',
                    url:'http://171125dv96.iask.in/weiqing_manage/Package.json',
                    dataType:'jsonp',
                    jsonp:'callback',
                    data:{phone:18865920808, type:'0'},
                    jsonpCallback:"successCallback",
                    success:function(data){
                        alert("成功!success");
                        alert(data.name);
                    },
                    error:function(XMLHttpRequest, textStatus, errorThrown){
                        alert("失败!error");
                        alert(XMLHttpRequest.status);
                        alert(XMLHttpRequest.readyState);
                        alert(textStatus);
                    }
                });

                /*
                *回调名successCallback可以自定义,必须和后台响应的名
                *对应
                *
                *如果XMLHttpRequest.status打印值为200
                *XMLHttpRequest.readyState为4
                *textStatus为parsererror
                *
                *parsererror:解析错误
                *由parsererror可以看出应该就是后台返回的数据格式有问题
                *了
                */

后台代码:

java 复制代码
@Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        response.setContentType("text/json;charset=UTF-8");
        request.setCharacterEncoding("UTF-8");
        PrintWriter out = response.getWriter();
        String TELPHONE = request.getParameter("phone");
        String TYPE = request.getParameter("type");
        System.out.println("------------------------------------------");
        System.out.println("telphone: " + TELPHONE);
        System.out.println("type: " + TYPE);
        try {
            Package p = new Package();
            Gson gson = new Gson();
            String st = " 手机号:"+TELPHONE+",type:"+TYPE;
            System.out.println("111111111111111111111");
            p.setName(st);
            System.out.println(" 测试: " + gson.toJson(p));
            out.print("successCallback(" + gson.toJson(p) + ")");//尤其注意这里返回的数据格式: {"name":" 手机号:18865920808,type:0"}
            /*
            *因为Jsonp的返回类型:回调函数名+(+json+) 
            *
            */
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            out.flush();
            out.close();
        }

    }

后台打印:

相关推荐
2501_9209317037 分钟前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜
javascript·react native·react.js·游戏·ecmascript·harmonyos
layman05281 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔1 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李1 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN1 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒1 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局
PHP武器库1 小时前
ULUI:不止于按钮和菜单,一个专注于“业务组件”的纯 CSS 框架
前端·css
方也_arkling1 小时前
Element Plus主题色定制
javascript·sass
电商API_180079052471 小时前
第三方淘宝商品详情 API 全维度调用指南:从技术对接到生产落地
java·大数据·前端·数据库·人工智能·网络爬虫
晓晓莺歌1 小时前
vue3某一个路由切换,导致所有路由页面均变成空白页
前端·vue.js