網(wǎng)站跨域的五種解決方式

1谐檀、什么是跨越抡谐?

一個(gè)網(wǎng)頁向另一個(gè)不同域名/不同協(xié)議/不同端口的網(wǎng)頁請(qǐng)求資源,這就是跨域桐猬。
跨域原因產(chǎn)生:在當(dāng)前域名請(qǐng)求網(wǎng)站中童叠,默認(rèn)不允許通過ajax請(qǐng)求發(fā)送其他域名。

2课幕、為什么會(huì)產(chǎn)生跨域請(qǐng)求厦坛?

因?yàn)闉g覽器使用了同源策略

3、什么是同源策略乍惊?

同源策略是Netscape提出的一個(gè)著名的安全策略杜秸,現(xiàn)在所有支持JavaScript的瀏覽器都會(huì)使用這個(gè)策略。同源策略是瀏覽器最核心也最基本的安全功能润绎,如果缺少同源策略撬碟,瀏覽器的正常功能可能受到影響±蚱玻可以說web是構(gòu)建在同源策略的基礎(chǔ)之上的呢蛤,瀏覽器只是針對(duì)同源策略的一種實(shí)現(xiàn)。

4棍郎、為什么瀏覽器要使用同源策略其障?

是為了保證用戶的信息安全,防止惡意網(wǎng)站竊取數(shù)據(jù)涂佃,如果網(wǎng)頁之間不滿足同源要求励翼,將不能:

  • 1、共享Cookie辜荠、LocalStorage汽抚、IndexDB
  • 2、獲取DOM
  • 3伯病、AJAX請(qǐng)求不能發(fā)送
同源策略的非絕對(duì)性:
<script></script>
<img/>
<iframe/>
<link/>
<video/>
<audio/>

等帶有src屬性的標(biāo)簽可以從不同的域加載和執(zhí)行資源造烁。其他插件的同源策略:flashjava appletsilverlight惭蟋、googlegears等瀏覽器加載的第三方插件也有各自的同源策略叠纹,只是這些同源策略不屬于瀏覽器原生的同源策略,如果有漏洞則可能被黑客利用敞葛,從而留下XSS攻擊的后患

所謂的同源指:

域名誉察、網(wǎng)絡(luò)協(xié)議、端口號(hào)相同惹谐,三條有一條不同就會(huì)產(chǎn)生跨域持偏。 例如:你用瀏覽器打開http://baidu.com,瀏覽器執(zhí)行JavaScript腳本時(shí)發(fā)現(xiàn)腳本向http://cloud.baidu.com域名發(fā)請(qǐng)求氨肌,這時(shí)瀏覽器就會(huì)報(bào)錯(cuò)鸿秆,這就是跨域報(bào)錯(cuò)。

解決方案有五:

1怎囚、前端使用jsonp (不推薦使用)

當(dāng)我們正常地請(qǐng)求一個(gè)JSON數(shù)據(jù)的時(shí)候卿叽,服務(wù)端返回的是一串JSON類型的數(shù)據(jù),而我們使用 JSONP模式來請(qǐng)求數(shù)據(jù)的時(shí)候服務(wù)端返回的是一段可執(zhí)行的 JavaScript代碼恳守。因?yàn)?code>jsonp 跨域的原理就是用的動(dòng)態(tài)加載 scriptsrc 考婴,所以我們只能把參數(shù)通過 url的方式傳遞,所以jsonptype類型只能是get示例:

$.ajax({
    url: 'http://192.168.1.114/yii/demos/test.php', //不同的域
    type: 'GET', // jsonp模式只有GET 是合法的
    data: {
        'action': 'aaron'
    },
    dataType: 'jsonp', // 數(shù)據(jù)類型
    jsonp: 'backfunc', // 指定回調(diào)函數(shù)名,與服務(wù)器端接收的一致催烘,并回傳回來
})

使用JSONP 模式來請(qǐng)求數(shù)據(jù)的整個(gè)流程:
客戶端發(fā)送一個(gè)請(qǐng)求沥阱,規(guī)定一個(gè)可執(zhí)行的函數(shù)名(這里就是jQuery做了封裝的處理,自動(dòng)幫你生成回調(diào)函數(shù)并把數(shù)據(jù)取出來供success屬性方法來調(diào)用,而不是傳遞的一個(gè)回調(diào)句柄)伊群,服務(wù)器端接受了這個(gè) backfunc函數(shù)名考杉,然后把數(shù)據(jù)通過實(shí)參的形式發(fā)送出去

(在jquery源碼中,jsonp的實(shí)現(xiàn)方式是動(dòng)態(tài)添加<script>標(biāo)簽來調(diào)用服務(wù)器提供的js腳本舰始。jquery會(huì)在window對(duì)象中加載一個(gè)全局的函數(shù)崇棠,當(dāng) <script>代碼插入時(shí)函數(shù)執(zhí)行,執(zhí)行完畢后就 <script>會(huì)被移除丸卷。同時(shí)jquery還對(duì)非跨域的請(qǐng)求進(jìn)行了優(yōu)化枕稀,如果這個(gè)請(qǐng)求是在同一個(gè)域名下那么他就會(huì)像正常的 Ajax請(qǐng)求一樣工作。)

2及老、后臺(tái) Http 請(qǐng)求轉(zhuǎn)發(fā)

使用HttpClinet轉(zhuǎn)發(fā)進(jìn)行轉(zhuǎn)發(fā)(簡(jiǎn)單的例子 不推薦使用這種方式)

try {
    HttpClient client = HttpClients.createDefault();            //client對(duì)象
    HttpGet get = new HttpGet("http://localhost:8080/test");    //創(chuàng)建get請(qǐng)求
    CloseableHttpResponse response = httpClient.execute(get);   //執(zhí)行g(shù)et請(qǐng)求
    String mes = EntityUtils.toString(response.getEntity());    //將返回體的信息轉(zhuǎn)換為字符串
    System.out.println(mes);
} catch (ClientProtocolException e) {
    e.printStackTrace();
} catch (IOException e) {
    e.printStackTrace();
}

3抽莱、后臺(tái)配置同源Cors (推薦)

SpringBoot2.0上的跨域 用以下代碼配置 即可完美解決你的前后端跨域請(qǐng)求問題
SpringBoot2.0 上的跨域 用以下代碼配置 即可完美解決你的前后端跨域請(qǐng)求問題

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.cors.CorsConfiguration;
import org.springframework.web.cors.UrlBasedCorsConfigurationSource;
import org.springframework.web.filter.CorsFilter;

/**
 * 實(shí)現(xiàn)基本的跨域請(qǐng)求
 * @author linhongcun
 *
 */
@Configuration
public class CorsConfig {

    @Bean
    public CorsFilter corsFilter() {
        final UrlBasedCorsConfigurationSource urlBasedCorsConfigurationSource = new UrlBasedCorsConfigurationSource();
        final CorsConfiguration corsConfiguration = new CorsConfiguration();
        /*是否允許請(qǐng)求帶有驗(yàn)證信息*/
        corsConfiguration.setAllowCredentials(true);
        /*允許訪問的客戶端域名*/
        corsConfiguration.addAllowedOrigin("*");
        /*允許服務(wù)端訪問的客戶端請(qǐng)求頭*/
        corsConfiguration.addAllowedHeader("*");
        /*允許訪問的方法名,GET POST等*/
        corsConfiguration.addAllowedMethod("*");
        urlBasedCorsConfigurationSource.registerCorsConfiguration("/**", corsConfiguration);
        return new CorsFilter(urlBasedCorsConfigurationSource);
    }



}

4、使用 SpringCloud 網(wǎng)關(guān)

服務(wù)網(wǎng)關(guān)(zuul)又稱路由中心骄恶,用來統(tǒng)一訪問所有api接口,維護(hù)服務(wù)匕垫。
Spring Cloud Zuul通過與Spring Cloud Eureka的整合僧鲁,實(shí)現(xiàn)了對(duì)服務(wù)實(shí)例的自動(dòng)化維護(hù),所以在使用服務(wù)路由配置的時(shí)候,我們不需要向傳統(tǒng)路由配置方式那樣去指定具體的服務(wù)實(shí)例地址寞秃,只需要通過Ant模式配置文件參數(shù)即可

5斟叼、使用 nginx 做轉(zhuǎn)發(fā)

現(xiàn)在有兩個(gè)網(wǎng)站想互相訪問接口 在http://a.a.com:81/A中想訪問 http://b.b.com:81/B 那么進(jìn)行如下配置即可
然后通過訪問 www.my.com/A 里面即可訪問 www.my.com/B

server {
        listen       80;
        server_name  www.my.com;
        location /A {
            proxy_pass  http://a.a.com:81/A;
            index  index.html index.htm;
        }
        location /B {
            proxy_pass  http://b.b.com:81/B;
            index  index.html index.htm;
        }
    }

如果是兩個(gè)端口想互相訪問接口 在http://b.b.com:80/Api中想訪問 http://b.b.com:81/Api 那么進(jìn)行如下配置即可
使用nginx轉(zhuǎn)發(fā)機(jī)制就可以完成跨域問題

server {
        listen       80;
        server_name  b.b.com;
        location /Api {
            proxy_pass  http://b.b.com:81/Api;
            index  index.html index.htm;
        }
    }
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市春寿,隨后出現(xiàn)的幾起案子朗涩,更是在濱河造成了極大的恐慌,老刑警劉巖绑改,帶你破解...
    沈念sama閱讀 211,376評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件谢床,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡厘线,警方通過查閱死者的電腦和手機(jī)识腿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,126評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來造壮,“玉大人渡讼,你說我怎么就攤上這事《担” “怎么了成箫?”我有些...
    開封第一講書人閱讀 156,966評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)旨枯。 經(jīng)常有香客問我伟众,道長(zhǎng),這世上最難降的妖魔是什么召廷? 我笑而不...
    開封第一講書人閱讀 56,432評(píng)論 1 283
  • 正文 為了忘掉前任凳厢,我火速辦了婚禮,結(jié)果婚禮上竞慢,老公的妹妹穿的比我還像新娘先紫。我一直安慰自己,他們只是感情好筹煮,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,519評(píng)論 6 385
  • 文/花漫 我一把揭開白布遮精。 她就那樣靜靜地躺著,像睡著了一般败潦。 火紅的嫁衣襯著肌膚如雪本冲。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,792評(píng)論 1 290
  • 那天劫扒,我揣著相機(jī)與錄音檬洞,去河邊找鬼。 笑死沟饥,一個(gè)胖子當(dāng)著我的面吹牛添怔,可吹牛的內(nèi)容都是我干的湾戳。 我是一名探鬼主播,決...
    沈念sama閱讀 38,933評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼广料,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼砾脑!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起艾杏,我...
    開封第一講書人閱讀 37,701評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤韧衣,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后购桑,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體畅铭,經(jīng)...
    沈念sama閱讀 44,143評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,488評(píng)論 2 327
  • 正文 我和宋清朗相戀三年其兴,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了顶瞒。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,626評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡元旬,死狀恐怖榴徐,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情匀归,我是刑警寧澤坑资,帶...
    沈念sama閱讀 34,292評(píng)論 4 329
  • 正文 年R本政府宣布,位于F島的核電站穆端,受9級(jí)特大地震影響袱贮,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜体啰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,896評(píng)論 3 313
  • 文/蒙蒙 一攒巍、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧荒勇,春花似錦柒莉、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,742評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至仅偎,卻和暖如春跨蟹,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背橘沥。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來泰國(guó)打工窗轩, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人威恼。 一個(gè)月前我還...
    沈念sama閱讀 46,324評(píng)論 2 360
  • 正文 我出身青樓品姓,卻偏偏與公主長(zhǎng)得像寝并,于是被迫代替她去往敵國(guó)和親箫措。 傳聞我的和親對(duì)象是個(gè)殘疾皇子腹备,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,494評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • 有一句翻譯出自老子名言的德文:Reichist, wer wei?, dass er genug hat.簡(jiǎn)而易懂...
    文莉蔓策兒閱讀 484評(píng)論 0 0
  • 在群里經(jīng)常遇到各種提問,今天和大家談?wù)劷锫釂栔翱梢宰龅囊恍┕ぷ鳌?本文的目標(biāo):提供基本的搜索渠道植酥,可以解決大部分...
    阿寶尋金閱讀 255評(píng)論 0 0