Apache跨域資源訪問報(bào)錯(cuò)問題解決方案
很多時(shí)候,大中型網(wǎng)站為了靜態(tài)資源分布式部署,加快訪問速度,減輕主站壓力,會(huì)把靜態(tài)資源(例如字體文件、圖片等)放在獨(dú)立服務(wù)器或者CDN上,并且使用獨(dú)立的資源域名(例如res.test.com)
但是在實(shí)際部署中,會(huì)發(fā)現(xiàn)瀏覽器無法載入這些不同域名的資源,firefox控制臺(tái)會(huì)報(bào)錯(cuò):
<span role="presentation" class="objectBox objectBox-errorMessage "><span class="errorMessage ">已阻止跨源請(qǐng)求:同源策略禁止讀取位于 http://xxxxx 的遠(yuǎn)程資源。(原因:CORS 頭缺少 'Access-Control-Allow-Origin')。</span></span>
已阻止跨源請(qǐng)求:同源策略禁止讀取位于 http://xxxxx 的遠(yuǎn)程資源。(原因:CORS 請(qǐng)求失?。?/p>
這是因?yàn)楝F(xiàn)代瀏覽器將其定義為跨域資源而不允許加載
理解跨域首先必須要了解同源策略。同源策略是瀏覽器上為安全性考慮實(shí)施的非常重要的安全策略。
何謂同源:
URL由協(xié)議、域名、端口和路徑組成,如果兩個(gè)URL的協(xié)議、域名和端口相同,則表示他們同源。
同源策略:
瀏覽器的同源策略,限制了來自不同源的"document"或腳本,對(duì)當(dāng)前"document"讀取或設(shè)置某些屬性。 (白帽子講web安全[1])
從一個(gè)域上加載的腳本不允許訪問另外一個(gè)域的文檔屬性。
那么關(guān)鍵是如何解決呢,其實(shí)很簡單,只要在靜態(tài)資源服務(wù)器上,增加一個(gè)頭信息:
Access-Control-Allow-Origin *
本文就apache進(jìn)行操作,nginx大同小異
首先編輯httpd.conf
找到這行
#LoadModule headers_module modules/mod_headers.so
把#注釋符去掉
LoadModule headers_module modules/mod_headers.so
目的是開啟apache頭信息自定義模塊
然后在獨(dú)立資源域名的虛擬主機(jī)添加一行
Header set Access-Control-Allow-Origin *
意思是對(duì)這個(gè)域名的資源進(jìn)行訪問時(shí),添加一個(gè)頭信息
重啟apache
再訪問,OK!
NameVirtualHost 10.0.0.2:80 <VirtualHost 10.0.0.2:80> DocumentRoot /var/www/host.example.com ServerName host.example.com JkMount /webapp/* jkworker Header set Access-Control-Allow-Origin "*" RewriteEngine on RewriteRule ^/otherhost http://otherhost.example.com/webapp [R,L] </VirtualHost>
And here's an example of the Apache config for the second:
NameVirtualHost 10.0.1.2:80 <VirtualHost 10.0.1.2:80> DocumentRoot /var/www/otherhost.example.com ServerName otherhost.example.com JkMount /webapp/* jkworker Header set Access-Control-Allow-Origin "*" </VirtualHost>
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
linux下快速列出局域網(wǎng)中所有主機(jī)名(計(jì)算機(jī)名)的腳本
這篇文章主要介紹了linux下快速列出局域網(wǎng)中所有主機(jī)名(計(jì)算機(jī)名)的腳本,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07
IO復(fù)用之select poll epoll的總結(jié)(推薦)
下面小編就為大家?guī)硪黄狪O復(fù)用之select poll epoll的總結(jié)(推薦)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-01-01
解決啟動(dòng)php-fpm后訪問不到php文件的辦法
今天碰了一個(gè)很奇怪的問題,當(dāng)啟動(dòng)php-fpm后,發(fā)現(xiàn)居然訪問不到php文件了,后來通過查看日志、分析+搜索終于解決了,現(xiàn)在將整個(gè)過程分享給大家,也方便同樣遇到這個(gè)問題的同學(xué)們參考借鑒,下面來一起看看吧。2016-12-12
Ubuntu Server 14.04升級(jí)Ubuntu Server 16.04
這篇文章主要介紹了 Ubuntu Server 14.04升級(jí)Ubuntu Server 16.04,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2016-12-12
Linux下nginx配置https協(xié)議訪問的方法
這篇文章主要介紹了Linux下nginx配置https協(xié)議訪問的方法,需要的朋友可以參考下2016-07-07

