很多時候,大中型網站為了靜態資源分布式部署,加快訪問速度,減輕主站壓力,會把靜態資源(例如字體文件、圖片等)放在獨立服務器或者CDN上,并且使用獨立的資源域名(例如res.test.com)
創新互聯專注為客戶提供全方位的互聯網綜合服務,包含不限于成都網站建設、成都網站設計、永平網絡推廣、微信小程序、永平網絡營銷、永平企業策劃、永平品牌公關、搜索引擎seo、人物專訪、企業宣傳片、企業代運營等,從售前售中售后,我們都將竭誠為您服務,您的肯定,是我們大的嘉獎;創新互聯為所有大學生創業者提供永平建站搭建服務,24小時服務熱線:13518219792,官方網址:vcdvsql.cn但是在實際部署中,會發現瀏覽器無法載入這些不同域名的資源,firefox控制臺會報錯:成都服務器托管
<span role="presentation" class="objectBox objectBox-errorMessage "><span class="errorMessage ">已阻止跨源請求:同源策略禁止讀取位于 http://xxxxx 的遠程資源。(原因:CORS 頭缺少 'Access-Control-Allow-Origin')。</span></span>
已阻止跨源請求:同源策略禁止讀取位于 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!成都小程序開發公司
1 2 3 4 5 6 7 8 9 | 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:
1 2 3 4 5 6 7 | 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 > |
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:https://www.cnblogs.com/wangluochong/p/6001651.html
當前標題:Apache跨域資源訪問報錯問題解決方案
鏈接分享:http://vcdvsql.cn/article16/dipdg.html
成都網站建設公司_創新互聯,為您提供品牌網站建設、面包屑導航、關鍵詞優化、網站維護、網站策劃、App設計
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯