apache如何解決跨域資源訪問


很多時候,大中型網站為了靜態資源分布式部署,加快訪問速度,減輕主站壓力,會把靜態資源(例如字體文件、圖片等)放在獨立服務器或者CDN上,並且使用獨立的資源域名(例如res.test.com)

但是在實際部署中,會發現瀏覽器無法載入這些不同域名的資源,firefox控制台會報錯:

 

[html]  view plain  copy
 
  1. <span role="presentation" class="objectBox objectBox-errorMessage "><span class="errorMessage ">已阻止跨源請求:同源策略禁止讀取位於 http://xxxxx 的遠程資源。(原因:CORS 頭缺少 'Access-Control-Allow-Origin')。</span></span>  
  2. 已阻止跨源請求:同源策略禁止讀取位於 http://xxxxx 的遠程資源。(原因:CORS 請求失敗)。  

 

這是因為現代瀏覽器將其定義為跨域資源而不允許加載

 

理解跨域首先必須要了解同源策略。同源策略是瀏覽器上為安全性考慮實施的非常重要的安全策略。
    何謂同源:
        URL由協議、域名、端口和路徑組成,如果兩個URL的協議、域名和端口相同,則表示他們同源。
    同源策略:
        瀏覽器的同源策略,限制了來自不同源的"document"或腳本,對當前"document"讀取或設置某些屬性。 (白帽子講web安全[1])
        從一個域上加載的腳本不允許訪問另外一個域的文檔屬性。

 

那么關鍵是如何解決呢,其實很簡單,只要在靜態資源服務器上,增加一個頭信息:

Access-Control-Allow-Origin *

本文就apache進行操作,nginx大同小異

 

首先編輯httpd.conf

找到這行

#LoadModule headers_module modules/mod_headers.so

把#注釋符去掉

LoadModule headers_module modules/mod_headers.so

目的是開啟apache頭信息自定義模塊

 

然后在獨立資源域名的虛擬主機添加一行

Header set Access-Control-Allow-Origin *

意思是對這個域名的資源進行訪問時,添加一個頭信息

 

重啟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>


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM