欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Flask框架踩坑之a(chǎn)jax跨域請(qǐng)求實(shí)現(xiàn)

 更新時(shí)間:2019年02月22日 11:52:14   作者:一杯閃光喵  
這篇文章主要介紹了Flask框架踩坑之a(chǎn)jax跨域請(qǐng)求實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

業(yè)務(wù)場(chǎng)景:

前后端分離需要對(duì)接數(shù)據(jù)接口。

接口測(cè)試是在postman做的,今天才開(kāi)始和前端對(duì)接,由于這是我第一次做后端接口開(kāi)發(fā)(第一次嘛,問(wèn)題比較多)所以在此記錄分享我的踩坑之旅,以便能更好的理解,應(yīng)用。

問(wèn)題:

前端ajax請(qǐng)求后端接口出現(xiàn)跨域問(wèn)題,如下圖。

翻譯:因?yàn)轫憫?yīng)頭沒(méi)有"Access-Control-Allow-Origin",所以接口拒絕把數(shù)據(jù)返回給前端。

什么是Access-Control-Allow-Origin?

Access-Control-Allow-Origin是HTML5中定義的一種解決資源跨域的策略。

瀏覽器只允許請(qǐng)求當(dāng)前域的資源,而對(duì)其他域的資源表示不信任。那怎么才算跨域呢?

  • 請(qǐng)求協(xié)議http,https的不同
  • domain的不同
  • 端口port的不同

其實(shí)說(shuō)簡(jiǎn)單點(diǎn),跨域,指的就是瀏覽器不能執(zhí)行其他網(wǎng)站的腳本。它是由瀏覽器的同源策略造成的,是瀏覽器施加的安全限制。

同源是指:協(xié)議相同,域名相同,端口相同。三者同時(shí)成立才能叫同源。

瀏覽器的同源策略從它誕生的那一刻就出現(xiàn)了,具體是指從域名A下的一個(gè)頁(yè)面(一般是通過(guò)ajax請(qǐng)求)獲取域名B下的一個(gè)資源,是不被瀏覽器允許的。

跨域資源共享(CORS)是瀏覽器提供的一種跨域協(xié)商機(jī)制,讓前后端協(xié)商是否可以發(fā)出跨域請(qǐng)求。CORS添加了若干Access-controll-request-xxx 的頭,給客戶(hù)端聲明自己的源、要使用的頭部、用使用的請(qǐng)求方法;添加了若干Access-Controll-Allow-xxx的頭,給服務(wù)端聲明自己支持跨域的源、頭部和方法。

URL 說(shuō)明 是否允許通信
http://www.a.com/a.js
http://www.a.com/b.js
同一域名下 允許
http://www.a.com/lab/a.js
http://www.a.com/script/b.js
同一域名下不同文件夾 允許
http://www.a.com:8000/a.js
http://www.a.com/b.js
同一域名,不同端口 不允許
http://www.a.com/a.js
https://www.a.com/b.js
同一域名,不同協(xié)議 不允許
http://www.a.com/a.js
http://70.32.92.74/b.js
域名和域名對(duì)應(yīng)ip 不允許
http://www.a.com/a.js
http://script.a.com/b.js
主域相同,子域不同 不允許
http://www.a.com/a.js
http://a.com/b.js
同一域名,不同二級(jí)域名(同上) 不允許(cookie這種情況下也不允許訪(fǎng)問(wèn))
http://www.cnblogs.com/a.js
http://www.a.com/b.js
不同域名 不允許

解決方案(從后端解決)

1.后臺(tái)接口允許跨域請(qǐng)求

以Python Flask框架為例,有兩種方法。

第一種第三方插件實(shí)現(xiàn),只需要安裝第三方插件就可以輕松地為所有接口添加響應(yīng)頭。

復(fù)制代碼 代碼如下:
pip3 install flask-cors

pip3 install flask-cors
from flask_cors import *

app = Flask(__name__)
# r'/*' 是通配符,讓本服務(wù)器所有的URL 都允許跨域請(qǐng)求 
CORS(app, resources=r'/*')

實(shí)際上就是為接口響應(yīng)頭添加了一個(gè)Access-Control-Allow-Origin并設(shè)置值*表示所有網(wǎng)站都可以請(qǐng)求。

第二種接口函數(shù)自定義添加屬性。

res.headers['Access-Control-Allow-Origin'] = '*'
return res

為返回結(jié)果res屬性headers設(shè)置Access-Control-Allow-Origin值為*。只對(duì)當(dāng)前接口有效。

2.利用nginx反向代理

說(shuō)到nginx,不得不說(shuō)真的很強(qiáng)大,也帶來(lái)很多便利用于解決一些頭疼的難題。

一般來(lái)說(shuō)可以用來(lái)做:靜態(tài)頁(yè)面的服務(wù)器、靜態(tài)文件緩存服務(wù)器、網(wǎng)站反向代理、負(fù)載均衡服務(wù)器等等,而且實(shí)現(xiàn)這一切,基本只需要改改那萬(wàn)能的配置文件即可。

server {
    listen    80;
    server_name localhost;
      location / {
      proxy_pass http://localhost:81;
      proxy_redirect default;
    }

		location /apis { #添加訪(fǎng)問(wèn)目錄為/apis的代理配置

			rewrite ^/apis/(.*)$ /$1 break;
			proxy_pass  http://localhost:82;
    }
}

1.由配置信息可知,我們讓nginx監(jiān)聽(tīng)localhost的80端口,本地的81端口有都是經(jīng)過(guò)localhost的80端口進(jìn)行訪(fǎng)問(wèn)。

2.我們特殊配置了一個(gè)“/apis”目錄的訪(fǎng)問(wèn),并且對(duì)url執(zhí)行了重寫(xiě),最后使以“/apis”開(kāi)頭的地址都轉(zhuǎn)到“http://localhost:82”進(jìn)行處理。

3.rewrite ^/apis/(.*)$ /$1 break,代表重寫(xiě)攔截進(jìn)來(lái)的請(qǐng)求,并且只能對(duì)域名后邊以“/apis”開(kāi)頭的起作用,例如www.a.com/apis/msg?x=1重寫(xiě)。只對(duì)/apis重寫(xiě)。rewrite后面的參數(shù)是一個(gè)簡(jiǎn)單的正則 ^/apis/(.*)$ ,$1代表正則中的第一個(gè)(),$2代表第二個(gè)()的值,以此類(lèi)推。break代表匹配一個(gè)之后停止匹配。

總結(jié)一下,搭建一個(gè)nginx并把相應(yīng)代碼部署在服務(wù)器本機(jī),由頁(yè)面請(qǐng)求本域名的一個(gè)地址,轉(zhuǎn)由nginx代理到目標(biāo)服務(wù)器處理后返回結(jié)果給頁(yè)面。這樣就完美解決了跨域問(wèn)題。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • python 在mysql中插入null空值的操作

    python 在mysql中插入null空值的操作

    這篇文章主要介紹了python 在mysql中插入null空值的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-03-03
  • tensorflow 變長(zhǎng)序列存儲(chǔ)實(shí)例

    tensorflow 變長(zhǎng)序列存儲(chǔ)實(shí)例

    今天小編就為大家分享一篇tensorflow 變長(zhǎng)序列存儲(chǔ)實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-01-01
  • python BeautifulSoup庫(kù)的安裝與使用

    python BeautifulSoup庫(kù)的安裝與使用

    這篇文章主要介紹了python BeautifulSoup庫(kù)的安裝與使用,幫助大家更好的理解和使用python,感興趣的朋友可以了解下
    2020-12-12
  • Python實(shí)現(xiàn)從訂閱源下載圖片的方法

    Python實(shí)現(xiàn)從訂閱源下載圖片的方法

    這篇文章主要介紹了Python實(shí)現(xiàn)從訂閱源下載圖片的方法,涉及Python采集的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-03-03
  • python實(shí)現(xiàn)文件名批量替換和內(nèi)容替換

    python實(shí)現(xiàn)文件名批量替換和內(nèi)容替換

    這篇文章主要介紹了python實(shí)現(xiàn)文件名批量替換和內(nèi)容替換,第一個(gè)例子可以指定文件類(lèi)型,需要的朋友可以參考下
    2014-03-03
  • Django的基本運(yùn)用之Django垃圾分類(lèi)詳解

    Django的基本運(yùn)用之Django垃圾分類(lèi)詳解

    大家都知道Django 是一個(gè)由 Python 編寫(xiě)的一個(gè)開(kāi)放源代碼的 Web 應(yīng)用框架。接下來(lái)通過(guò)本文給大家介紹Django的基本運(yùn)用之Django垃圾分類(lèi)詳解,感興趣的朋友一起看看吧
    2021-09-09
  • Python基礎(chǔ)之條件語(yǔ)句詳解

    Python基礎(chǔ)之條件語(yǔ)句詳解

    今天給大家?guī)?lái)的是關(guān)于Python基礎(chǔ)的一些知識(shí),文章圍繞著Python條件語(yǔ)句展開(kāi),文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下
    2021-06-06
  • 使用Python腳本來(lái)控制Windows Azure的簡(jiǎn)單教程

    使用Python腳本來(lái)控制Windows Azure的簡(jiǎn)單教程

    這篇文章主要介紹了使用Python腳本來(lái)控制Windows Azure的簡(jiǎn)單教程,由于微軟官方提供了Python SDK,使得用戶(hù)自己用Python控制Azure成為了可能,需要的朋友可以參考下
    2015-04-04
  • 實(shí)例說(shuō)明Python中比較運(yùn)算符的使用

    實(shí)例說(shuō)明Python中比較運(yùn)算符的使用

    這篇文章主要介紹了=Python中比較運(yùn)算符的使用,是Python學(xué)習(xí)當(dāng)中的基本知識(shí),需要的朋友可以參考下
    2015-05-05
  • 使用Python找出水仙花數(shù)的方法介紹

    使用Python找出水仙花數(shù)的方法介紹

    水仙花數(shù)也被稱(chēng)為超完全數(shù)字不變數(shù)、自戀數(shù)、自?xún)鐢?shù)、阿姆斯壯數(shù)或阿姆斯特朗數(shù),水仙花數(shù)是指一個(gè)3位數(shù),本文就給大家簡(jiǎn)單聊聊如何使用Python找出水仙花數(shù),感興趣的同學(xué)可以參考閱讀
    2023-07-07

最新評(píng)論