摘要:瀏覽器一般默認(rèn)會(huì)禁止跨域訪問。因?yàn)椴话踩?,容易出現(xiàn)跨站請(qǐng)求偽造攻擊。二控制瀏覽器允許跨域訪問通過添加等頭信息的方式控制瀏覽器緩存。
一、什么是跨域
跨域是指從一個(gè)域名的網(wǎng)頁(yè)去請(qǐng)求另一個(gè)域名的資源。比如從 www.a.com 頁(yè)面去請(qǐng)求 www.b.com 的資源。
瀏覽器一般默認(rèn)會(huì)禁止跨域訪問。因?yàn)椴话踩?,容易出現(xiàn) CSRF(跨站請(qǐng)求偽造)攻擊。
二、Nginx控制瀏覽器允許跨域訪問Nginx通過添加 Access-Control-Allow-Origin、Access-Control-Allow-Methods、Access-Control-Allow-Headers 等HTTP頭信息的方式控制瀏覽器緩存。
"Access-Control-Allow-Origin" 設(shè)置允許發(fā)起跨域請(qǐng)求的網(wǎng)站ngx_http_headers_module 語(yǔ)法
"Access-Control-Allow-Methods" 設(shè)置允許發(fā)起跨域請(qǐng)求請(qǐng)求的HTTP方法
"Access-Control-Allow-Headers" 設(shè)置允許跨域請(qǐng)求包含 Content-Type頭
Syntax: add_header name value [always]; Default: — Context: http, server, location, if in location應(yīng)用實(shí)例 1. vim conf.d/cross_site.conf
# 配置網(wǎng)站www.a.com server { server_name www.a.com; root /vagrant/a; # 允許 http://www.b.com 使用 GET,POST,DELETE HTTP方法發(fā)起跨域請(qǐng)求 add_header Access-Control-Allow-Origin http://www.b.com; add_header Access-Control-Allow-Method GET,POST,DELETE; } # 配置網(wǎng)站www.b.com server { server_name www.b.com; root /vagrant/b; } # 配置網(wǎng)站www.c.com server { server_name www.c.com; root /vagrant/c; }2. nginx -s reload 重新載入nginx配置文件 3. 創(chuàng)建 /vagrant/a/a.txt、/vagrant/b/index.html、/vagrant/c/index.html 文件
vim /vagrant/a/a.txt
Hello,I"m a!
/vagrant/b/index.html
Ajax跨站訪問b Ajax跨站訪問b -
/vagrant/c/index.html
4. 配置客戶端的hosts文件(使用真是域名的可以忽略)Ajax跨站訪問c Ajax跨站訪問c -
windows: C:WindowsSystem32driversetchosts
linux: /etc/hosts
添加如下內(nèi)容,并保存(192.168.33.88為筆者虛擬機(jī)的IP,需自行替換為自己的IP):
192.168.33.88 www.a.com 192.168.33.88 www.b.com 192.168.33.88 www.c.com5. 瀏覽器分別訪問 http://www.b.com/index.html 和 http://www.c.com/index.html
http://www.b.com/index.html
Ajax跨站訪問b - Hello,I"m a!
http://www.c.com/index.html
Ajax跨站訪問c - 請(qǐng)求失敗!
打開瀏覽器的開發(fā)者模式Console,還可以發(fā)現(xiàn) http://www.c.com/index.html 的頁(yè)面出現(xiàn)報(bào)錯(cuò):
Failed to load http://www.a.com/a.txt: The "Access-Control-Allow-Origin" header has a value "http://www.b.com" that is not equal to the supplied origin. Origin "http://www.c.com" is therefore not allowed access.
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/40037.html
摘要:瀏覽器一般默認(rèn)會(huì)禁止跨域訪問。因?yàn)椴话踩?,容易出現(xiàn)跨站請(qǐng)求偽造攻擊。二控制瀏覽器允許跨域訪問通過添加等頭信息的方式控制瀏覽器緩存。 一、什么是跨域 跨域是指從一個(gè)域名的網(wǎng)頁(yè)去請(qǐng)求另一個(gè)域名的資源。比如從 www.a.com 頁(yè)面去請(qǐng)求 www.b.com 的資源。 showImg(https://segmentfault.com/img/remote/1460000015873212?...
摘要:瀏覽器一般默認(rèn)會(huì)禁止跨域訪問。因?yàn)椴话踩?,容易出現(xiàn)跨站請(qǐng)求偽造攻擊。二控制瀏覽器允許跨域訪問通過添加等頭信息的方式控制瀏覽器緩存。 一、什么是跨域 跨域是指從一個(gè)域名的網(wǎng)頁(yè)去請(qǐng)求另一個(gè)域名的資源。比如從 www.a.com 頁(yè)面去請(qǐng)求 www.b.com 的資源。 showImg(https://segmentfault.com/img/remote/1460000015873212?...
摘要:技術(shù)的學(xué)習(xí)也是如此唯有實(shí)踐才能更清楚的明白原理和加深印象,因此本文會(huì)利用對(duì)前端的各種跨域方式進(jìn)行實(shí)踐,強(qiáng)烈建議一步一步跟著做,相信你肯定會(huì)對(duì)跨域有更深層次的理解。 前言 常言道,讀萬(wàn)卷書,不如行萬(wàn)里路。技術(shù)的學(xué)習(xí)也是如此,唯有實(shí)踐才能更清楚的明白原理和加深印象,因此本文會(huì)利用node.js對(duì)前端的各種跨域方式進(jìn)行實(shí)踐,強(qiáng)烈建議一步一步跟著做,相信你肯定會(huì)對(duì)跨域有更深層次的理解。而由于篇...
閱讀 4189·2021-09-22 15:34
閱讀 2802·2021-09-22 15:29
閱讀 521·2019-08-29 13:52
閱讀 3375·2019-08-29 11:30
閱讀 2301·2019-08-26 10:40
閱讀 869·2019-08-26 10:19
閱讀 2283·2019-08-23 18:16
閱讀 2352·2019-08-23 17:50