同源策略

同源策略(Same origin policy)是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,则浏览器的正常功能可能都会受到影响。可以说Web是构建在同源策略基础之上的,浏览器只是针对同源策略的一种实现。

同源策略,它是由Netscape提出的一个著名的安全策略。现在所有支持JavaScript 的浏览器都会使用这个策略。所谓同源是指,域名,协议,端口相同。当一个浏览器的两个tab页中分别打开来 百度和谷歌的页面当浏览器的百度tab页执行一个脚本的时候会检查这个脚本是属于哪个页面的,即检查是否同源,只有和百度同源的脚本才会被执行。如果非同源,那么在请求数据时,浏览器会在控制台中报一个异常,提示拒绝访问。  
==================================http://127.0.0.1:8001项目的index
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="http://code.jquery.com/jquery-latest.js"></script>
</head>
<body>
<button>ajax</button>

<script>
    $("button").click(function(){
        $.ajax({
            url:"http://127.0.0.1:7766/SendAjax/",
            type:"POST",
            data:{"username":"test","csrfmiddlewaretoken":'{{ csrf_token }}',
            success:function(data){
                alert(123);
                alert(data)
            }
        })
    })
</script>
</body>
</html>

==================================http://127.0.0.1:8001项目的views

def index(request):
    return render(request,"index.html")

def ajax(request):
    import json
    print(request.POST,"+++++++++++")
    return HttpResponse(json.dumps("hello"))
第一个主机
==================================http://127.0.0.1:8002项目的index
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="http://code.jquery.com/jquery-latest.js"></script>
</head>
<body>


<button>sendAjax</button>

{% csrf_token %}

<script>
    $("button").click(function(){


        $.ajax({
            url:"/SendAjax/",
            type:"POST",
            data:{"username":"yuan","csrfmiddlewaretoken":$("[name='csrfmiddlewaretoken']").val()},
            success:function(data){
                alert(data)
            }
        })
    })
</script>

</body>
</html>

==================================http://127.0.0.1:8002项目的view视图函数

def index(request):
    return render(request,"index.html")

from django.views.decorators.csrf import csrf_exempt

@csrf_exempt
def SendAjax(request):
    import json
    print("++++++++")

    return HttpResponse(json.dumps("hello2"))
第二个主机

相关文章:

  • 2021-05-29
  • 2021-10-23
猜你喜欢
  • 2021-12-19
  • 2021-12-19
  • 2021-03-31
  • 2021-05-30
  • 2021-07-31
  • 2022-01-23
相关资源
相似解决方案