Ajax的問題(跨域)-創(chuàng)新互聯(lián)

ajax往自己的域名訪問是可以,如果向別的域名訪問就會報(bào)錯(cuò)。
這一版是請求發(fā)過去了,服務(wù)器也給返回?cái)?shù)據(jù)了,但是瀏覽器會給報(bào)錯(cuò)(瀏覽器遵:同源策略)。他的這個(gè)策略把a(bǔ)jax跨域發(fā)送請求時(shí),再回來時(shí)候?yàn)g覽器阻止了。

站在用戶的角度思考問題,與客戶深入溝通,找到工布江達(dá)網(wǎng)站設(shè)計(jì)與工布江達(dá)網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:成都做網(wǎng)站、網(wǎng)站建設(shè)、外貿(mào)營銷網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、申請域名、虛擬主機(jī)、企業(yè)郵箱。業(yè)務(wù)覆蓋工布江達(dá)地區(qū)。

JSONP

jsonp 就是鉆空子,瀏覽器雖然禁止ajax跨域,但是允許script(src)的代碼不禁止,可以把這個(gè)用jquery CDN的方法
使用方法:

  • 發(fā)送:--->>在自己的頁面創(chuàng)建一個(gè)script標(biāo)簽,讓它的src=‘http://baidu.com/?p=1’這樣鉆過去

https://www.cnblogs.com/xiaohuochai/p/6568039.html
這個(gè)博客寫的非常好

跨站練習(xí)

環(huán)境設(shè)置

啟動兩個(gè)項(xiàng)目一個(gè)端口為8001,一個(gè)為8000,端口8001提供數(shù)據(jù)。通過8000端口的程序來獲取8001提供的數(shù)據(jù)

8001的代碼
from django.shortcuts import render,HttpResponse
import json
def user_jsonp(request):
    print('請求來了。。。')
    user_list=[
        'zhang','wang','li','zhao'
    ]
    temp = json.dumps(user_list)
    return HttpResponse(temp)
8000的代碼
def user(request):
    return render(request,'user.html')
<body>
<input type="button" value="獲取信息" onclick="showdata();">
<div>
    <ul id="user_list">

    </ul>
</div>
<script>
    function showdata() {
        xhr = new XMLHttpRequest();
        xhr.onreadystatechange=function () {
            if(xhr.readyState==4){
                var content = xhr.responseText;
                console.log(content)
            }
        }
        xhr.open('GET','http://127.0.0.1:8001/user_jsonp/');
        xhr.send()
    }
</script>

</body>

這個(gè)時(shí)候兩個(gè)項(xiàng)目啟動起來后,8000頁面點(diǎn)擊獲取來獲取8001的數(shù)據(jù)時(shí)候是出錯(cuò)的(瀏覽器的同源策略)報(bào)錯(cuò)如下:
(index):1 Failed to load http://127.0.0.1:8001/user_jsonp/: No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://127.0.0.1:8000' is therefore not allowed access.
這個(gè)就是同源策略阻止了ajax的訪問。為了解決這個(gè)問題,我們可以送script的js的方式來解決
如下面的代碼:

function showdata() {
        var tag = document.createElement('script');
        tag.src='http://127.0.0.1/8001/user_jsonp/';
        document.head.appendChild(tag)
    }

這里通過scirpt的方式已經(jīng)跨過站了,數(shù)據(jù)已經(jīng)存儲到了內(nèi)存中,下面我們?nèi)绾螐膬?nèi)存里面拿到8001的值那?如果這里有一個(gè)變量的換,我們是可以通過變量來獲取的 ,通過這個(gè)思路,出現(xiàn)了下面的這個(gè)代碼
數(shù)據(jù)端8001這邊在返回的時(shí)候返回一個(gè)fun(xxx)這么類型的一個(gè)字段,前端來獲取這個(gè)
8001代碼:

from django.shortcuts import render,HttpResponse
import json
def user_jsonp(request):
    v = request.GET.get('funname')
    print('請求來了。。。')
    user_list=[
        'zhang','wang','li','zhao'
    ]
    # temp = json.dumps(user_list)
    user_list_str = json.dumps(user_list)
    temp = "%s(%s)"%(v,user_list_str)
    return HttpResponse(temp)

8000前端獲取的8001的返回后,做如下處理

function showdata() {
        var tag = document.createElement('script');
        tag.src='http://127.0.0.1/8001/user_jsonp/?funname=bbb';
        document.head.appendChild(tag)#這里返回的是一個(gè)bbb(xx),然后bbb就會執(zhí)行下面的bbb函數(shù)
    }
    function bbb(arg) {
        console.log(arg)
    }

現(xiàn)在大家默認(rèn)函數(shù)會是callback

通過ajax 實(shí)現(xiàn)jsonp的方式

Ajax的問題(跨域)

jsonp只能通過get方式,你寫了post,內(nèi)部還是get請求。而且是雙方約定的

cros跨站

http://www.cnblogs.com/wupeiqi/articles/5703697.html

cros 就是服務(wù)端返回的字符串帶著一個(gè)字段,告訴瀏覽器不要阻止。

 簡單請求:

            def new_users(request):
                obj = HttpResponse('返回內(nèi)容')
                obj['Access-Control-Allow-Origin'] = "*"
                return obj
        復(fù)雜請求:
            def new_users(request):

                if request.method == "OPTIONS":
                    obj = HttpResponse()
                    obj['Access-Control-Allow-Origin'] = "*"
                    obj['Access-Control-Allow-Methods'] = "DELETE"
                    return obj

                obj = HttpResponse('asdfasdf')
                obj['Access-Control-Allow-Origin'] = "*"
                return obj
        其他:
            - 任何請求

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

文章題目:Ajax的問題(跨域)-創(chuàng)新互聯(lián)
當(dāng)前地址:http://www.muchs.cn/article0/dpggio.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化、網(wǎng)頁設(shè)計(jì)公司、企業(yè)網(wǎng)站制作、服務(wù)器托管、小程序開發(fā)網(wǎng)站改版

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)