ajax请求跨域问题总结

跨域原理的总结:

浏览器将cors请求分为简单请求(simple request)和非简单请求(not-so-simple request)
一、简单请求
必须同时满足以下两个条件:
1、请求方法是get/post/head
2、请求头信息不超出以下字段:
(1)Accept (2)Accept-Language (3)Content-Language(4)Last-Event-ID(5)Content-type(只 限于三个值application/x-www-form-urlencoded、 multipart/form-data、text/plain)
二、非简单请求
凡是非简单请求均属于非简单请求

跨域的几种现象:

第一种现象

No ‘Access-Control-Allow-Origin’ header is present on the requested resource

the response had HTTP status code 404
出现这种现象的原因:
本次ajax请求是非简单请求,所以请求前会发送一次预检请求(OPTIONS)
服务器端后台接口没有允许OPTIONS请求,导致无法找到对应接口地址
解决方案:后端允许options请求

第二种现象

No ‘Access-Control-Allow-Origin’ header is present on the requested resource

the response had HTTP status code 405
出现这种现象的原因:
后台方法允许预检请求,但是一些配置文件(如安全配置等)阻止了预检请求
解决方案:后端关闭对应的安全设置

第三种现象

No ‘Access-Control-Allow-Origin’ header is present on the requested resource

status 200
出现这种现象的原因
服务端允许预检请求并且接口也允许预检,但是头部出现不匹配现象
解决方案:后端增加对头部的支持

第四种现象

Head contains multiple values ‘,
表现现象是后台响应的http头部有两个’Access-Control-Allow-Origin:*’

解决ajax跨域就是通过JSONP或者CORS解决,现在几乎不使用JSONP

一、415错误

错误代码:

$.ajax({
       //请求方式
        type: "POST",
        //请求地址
        url: "http://39.98.245.70:8090/activityUser/upLoadImg",
        //数据,json字符串
        data: JSON.stringify(list),
        //请求成功
        success: function (res) {
            console.log(res);
            if (res.code == 200) {
                $('#showImg').attr('src', res.context);
                $('.delImg').addClass("showImg");
                imgUrl = res.context;
            } else {
                alert(res.message)
            }
        },
        //请求失败,包含具体的错误信息
        error: function (e) {
            alert('网络连接失败,请稍后再试!')
        }
    })

在这里插入图片描述
请求参数:
在这里插入图片描述
解决:
此问题原因八成是contentType格式与接口接收参数格式不同造成的,将参数格式定义相同就行了
在ajax中 添加 contentType: ‘application/json’,

$.ajax({
   //请求方式
       type: "POST",
       //请求地址
       url: "http://39.98.245.70:8090/activityUser/upLoadImg",
       contentType: 'application/json',
       //数据,json字符串
       data: JSON.stringify(list),
       //请求成功
       success: function (res) {
           console.log(res);
           if (res.code == 200) {
               $('#showImg').attr('src', res.context);
               $('.delImg').addClass("showImg");
               imgUrl = res.context;
           } else {
               alert(res.message)
           }
       },
       //请求失败,包含具体的错误信息
       error: function (e) {
           alert('网络连接失败,请稍后再试!')
       }
   })

二、跨域报错

在这里插入图片描述

chrome浏览器解决方法: --disable-web-security --user-data-dir

具体操作:chrome浏览器===>右键===>属性 将 ‘ --disable-web-security --user-data-dir’ 放入目标中 =>应用=>确定===>重启浏览器 OK~完美!
在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
跨域问题是由浏览器的同源策略(Same-Origin Policy)所引起的。同源策略是浏览器的一种安全策略,它限制了一个网页文档或脚本如何能够与其他来源的资源进行交互。同源是指协议、域名、端口号都相同,只要有一个不同就算跨域。 在jQuery中,如果要进行跨域请求,可以使用以下两种方式: 1. JSONP JSONP(JSON with Padding)是一种跨域请求数据的方式,它利用了script标签不受同源策略限制的特性。具体实现步骤如下: (1)定义一个回调函数 ```javascript function callback(data) { console.log(data); } ``` (2)在请求URL中添加回调函数参数 ```javascript $.ajax({ url: 'http://example.com/data?callback=callback', dataType: 'jsonp', }); ``` (3)服务端返回数据时,将数据作为参数传递给回调函数 ```javascript callback({name: '张三', age: 18}); ``` 2. CORS CORS(Cross-Origin Resource Sharing)是一种跨域访问资源的方式,它需要服务器端支持。具体实现步骤如下: (1)在服务端设置响应头 ```javascript Access-Control-Allow-Origin: http://example.com Access-Control-Allow-Methods: GET, POST Access-Control-Allow-Headers: X-Requested-With, Content-Type ``` (2)在客户端发送请求时,设置withCredentials属性为true ```javascript $.ajax({ url: 'http://example.com/data', type: 'GET', xhrFields: { withCredentials: true }, success: function(data) { console.log(data); } }); ``` 需要注意的是,使用CORS方式发送请求时,需要浏览器支持XMLHttpRequest Level 2和CORS。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值