django基础-跨域操作jsonp/cors

什么是跨域

所谓的跨域就是进行不用域名内的请求,比如我在A域名想访问B域名的内容就是一种跨域的行为。

但是在我们浏览器端会有一个同源策略的设置,这个同源策略只对Ajax请求有限制,如果你通过Ajax请求发送数据,在被访问的一端能够接受访问请求并且进行处理后返回给浏览器,但是浏览器不进行接收,所以不能进行跨域请求。

我们知道浏览器会对Ajax请求进行同源策略但是对带有src功能的标签没有进行限制。
一个方法可以解决这个同源策略的问题,方法是:设置通过带有src的标签去访问其他域名的内容。

跨域方法:jsonp

一、设置本地配置和Django配置文件

1、设置本地配置和Django配置文件

mac:cd /etc;vim hosts

1 127.0.0.1   www.s4.com
2 127.0.0.1   www.s5.com
hosts

2、设置Django配置文件settings的内容

ALLOWED_HOSTS = ['www.s4.com',]

二、JOSNP(自动动态生成标签)

1、JOSNP自动动态生成带有src的标签(html)(通过带有src的标签进行访问)

 1 ==============================================通过src进行访问 html=========================================
 2 <!DOCTYPE html>
 3 <html lang="en">
 4 <head>
 5     <meta charset="UTF-8">
 6     <title>Title</title>
 7 </head>
 8 <body>
 9 {#这个是josnp采用的方式   要求客户端和服务端进行约束 自己动态创建标签#}
10 function getUsers() {
11 {#定义一个点击函数#}
12     var tag =document.createElement('script');
13 {#创建一个script标签,name=tag#}
14     tag.src='http://www.s4.com:8010/users/?callback=bbb';
15 {#通过tag.src设置访问路劲,这个是get请求把数据放在url上#}
16 {#    tag.src='http://www.s4.com:8010/users/?funcname=bbb';#}
17     document.head.appendChild(tag);
18 {#在把名字等于tag的标签添加到请求头中#}
19 }
20 </script>
21 </body>
22 </html>
html

2、JOSNP自动动态生成带有src的标签(views)

 1 from django.shortcuts import render,redirect,HttpResponse
 2 import json
 3 # Create your views here.
 4  
 5 def users(request):
 6     v =request.GET.get('callback')
 7     # v =request.GET.get('funcname')
 8     print('请求来了')
 9     user_list=[
10         'alex','eric','egon'
11     ]
12     user_list_str=json.dumps(user_list)
13     temp ='%s(%s)' %(v,user_list_str)
14     print(temp)
15     return HttpResponse(temp)
Views

三、JOSNP(JQuery)

1、JOSNP 通过JQuery本身的方式访问(html)

 1 ====================================通过JQuery访问 html===================================================
 2 <!DOCTYPE html
 3 <html lang="en">
 4 <head>
 5     <meta charset="UTF-8">
 6     <title>Title</title>
 7 </head>
 8 <body>
 9 {#通过JQuery进行跨域请求,只要遵循JQuery标准就能成功访问#}
10 function getUsers() {
11 {#定义一个点击函数#}
12     $.ajax({
13 {#通过Ajax 向http://www.s4.com:8010/users/发送请求#}
14         url: 'http://www.s4.com:8010/users/',
15         type: 'POST',
16 {#发送方式#}
17         dataType: 'JSONP',
18 {#设置JSONP模式#}
19         jsonp: 'funcname',
20 {#Jsonp的值是funcname#}
21         jsonpCallback: 'bbb'
22 {#设置后台的函数名#}
23     })
24  
25 function bbb(arg) {
26     console.log(arg)
27 }
28  
29 </script>
30 </body>
31 </html>
html

2、JOSNP 通过JQuery本身的方式访问(views)

 1 from django.shortcuts import render,redirect,HttpResponse
 2 import json
 3 # Create your views here.
 4  
 5 def users(request):
 6     v =request.GET.get('callback')
 7     # v =request.GET.get('funcname')
 8     print('请求来了')
 9     user_list=[
10         'alex','eric','egon'
11     ]
12     user_list_str=json.dumps(user_list)
13     temp ='%s(%s)' %(v,user_list_str)
14     print(temp)
15     return HttpResponse(temp)
Views

跨域方法:CORS(跨域资源共享)

一、CORS(一种不需要通过别的方式去访问其他域名的方式)

cors 的原理是访问其他域名的内容,在执行完成后返回给浏览器时,告知浏览器不对Ajax请求进行同源限制

1、cors简单访问(html)

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6 </head>
 7 <body>
 8     <input type="button" value="获取用户列表" onclick="getUsers()">
 9 <ul id="user_list"></ul>
10 <script src="/static/jquery-3.2.1.js"></script>
11 <script>
12     function getUsers() {
13         $.ajax({
14             url:'http://www.s4.com:8010/lsd_users/',
15             type:'GET',
16             success:function (arg) {
17                 console.log(arg)
18             }
19         })
20     }
21 </script>
22 </body>
23 </html>
Views

2、cors简单的访问(views)

在访问其他域名的内容并执行完成后,返回一个响应头,响应头内有告知浏览器不进行Ajax的同源策略的方法。

 1 from django.shortcuts import render,redirect,HttpResponse
 2 import json
 3 # Create your views here.def lsd_users(request):
 4     user_list = [
 5         'alex', 'eric', 'egon'
 6     ]
 7     print('请求来了!')
 8     user_list_str=json.dumps(user_list)
 9     obj=HttpResponse(user_list_str)
10     obj['Access-Control-Allow-Origin']="http://www.s5.com:8100"
11     #  反会给浏览器已给响应头,告诉浏览器这个API不执行同源策略
12     return obj
Views

3、cors复杂的访问(html)

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6 </head>
 7 <body>
 8     <input type="button" value="获取用户列表" onclick="getUsers()">
 9 <ul id="user_list"></ul>
10 <script src="/static/jquery-3.2.1.js"></script>
11 <script>
12     function getUsers() {
13         $.ajax({
14             url:'http://www.s4.com:8010/new_users/',
15             type:'DELETE',
16  
17             success:function (arg) {
18                 console.log(arg)
19             }
20         })
21     }
22 </script>
23 </body>
24 </html>
View Code

4、cors复杂的访问(views)

复杂的访问请求要先进行一个预检,看下什么样的请求方式和请求域名可以进行访问,返回给浏览器浏览器在判断是不是和预检的需求一致,如果一致就可以访问,再次返回给浏览器时设置响应头,响应头内有告知浏览器不进行Ajax的同源策略的方法。

 1 from django.shortcuts import render,redirect,HttpResponse
 2 import json
 3 # Create your views here
 4 def new_users(request):
 5     print(request.method)
 6     # 打印请求方式
 7     user_list = [
 8         'alex', 'eric', 'egon'
 9     ]
10     if request.method=='OPTIONS':
11         # 判断请方式是不是一种options请求
12         print('预检....')
13         obj=HttpResponse()
14         obj['Access-Control-Allow-Origin']='*'
15         # 所有域名的都可以进行访问
16         obj['Access-Control-Allow-Methods']='DELETE'
17         # 返回请求的方式,并告知浏览器不进行同源策略
18         return obj
19     obj = HttpResponse('asdfasdf')
20     # 再次请求来的时候返回内容
21     obj['Access-Control-Allow-Origin'] = "*"
22     # 允许所有的域名进行访问
23     return obj
Views

 

end 

posted @ 2017-07-10 09:21  Adamanter  阅读(132)  评论(0编辑  收藏  举报