ajax 請求后臺跨域

坑爹的問題

最近在項(xiàng)目中遇到一個(gè)跨域問題阻逮,坑了好久容诬,查閱了很多資料終于解決了娩梨,特此記錄。

問題描述

前端庫我這邊用的axios览徒。后臺是java狈定。前臺請求方法是post。token驗(yàn)證放在header里面?zhèn)鞯胶笈_习蓬。
前端代碼如下:


axios.defaults.baseURL = getAppParams().host;
axios.defaults.headers.common['token'] = getAppParams().token;

axios({
        method: "post",
        url: 'order/ordcustomer/save',
        data: formdata,
        transformRequest: [function(data) {
            return JSON.stringify(data)
        }]
    })
    .then(res => {
        console.log(res);
    })
    .catch(err => {
        console.log(err)
    })

瀏覽器會提示這樣:Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:8080' is therefore not allowed纽什。

一些概念

一番查詢后發(fā)現(xiàn)。當(dāng)后臺設(shè)置Content-Type:application/json的時(shí)候躲叼,前端請求為post的時(shí)候芦缰,即為復(fù)雜請求。這時(shí)候枫慷,瀏覽器一次post請求會變成兩次饺藤。

  1. 第一次瀏覽器會優(yōu)先發(fā)送一個(gè)options給后臺,后臺驗(yàn)證通過
  2. 開始發(fā)送真正的post請求
    關(guān)于預(yù)檢的概念網(wǎng)上有很多流礁,我這邊就不記錄了。傳送門

解決方法

這個(gè)問題還是得從后臺解決罗丰。 這是后臺的修改代碼神帅。
后臺框架shiro
servlet filter部分

    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
            throws IOException, ServletException {
        // TODO Auto-generated method stub
        HttpServletResponse resp = (HttpServletResponse) response;
        HttpServletRequest rep = (HttpServletRequest) request;
        
        resp.addHeader("Access-Control-Allow-Origin",rep.getHeader("Origin"));
        //允許跨域請求中攜帶cookie       
        resp.addHeader("Access-Control-Allow-Credentials", "true");
        // 如果存在自定義的header參數(shù),需要在此處添加萌抵,逗號分隔
        resp.addHeader("Access-Control-Allow-Headers", "authorization,Origin, No-Cache, X-Requested-With, "
                + "If-Modified-Since, Pragma, Last-Modified, Cache-Control, Expires, " + "Content-Type, X-E4M-With");
        resp.addHeader("Access-Control-Allow-Methods", "GET, POST, OPTIONS");

        chain.doFilter(request, response);
    }

好多網(wǎng)上推薦的是找御,將resp.addHeader("Access-Control-Allow-Origin",*);因?yàn)檫@邊已經(jīng)設(shè)置了Access-Control-Allow-Credentials:true元镀,所以前端跨域的時(shí)候時(shí)候會帶上cookie。這樣在請求的時(shí)候就會產(chǎn)生沖突霎桅。所以一定要將Access-Control-Allow-Origin設(shè)置成rep.getHeader("Origin")!!! 傳送門

還有一個(gè)細(xì)節(jié)就是栖疑,后臺還要判斷一下獲取的請求,判斷此次是否是預(yù)檢請求(即getHeader()=="OPTIONS")滔驶,如果相同則 return true允許跨域遇革;預(yù)檢后,正式請求揭糕。

  if (((HttpServletRequest) request).getMethod().equals("OPTIONS")){
            return true;
        } else{
            //萝快。。著角。揪漩。。吏口。奄容。。产徊。昂勒。。囚痴。叁怪。
        }
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市深滚,隨后出現(xiàn)的幾起案子奕谭,更是在濱河造成了極大的恐慌,老刑警劉巖痴荐,帶你破解...
    沈念sama閱讀 212,029評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件血柳,死亡現(xiàn)場離奇詭異,居然都是意外死亡生兆,警方通過查閱死者的電腦和手機(jī)难捌,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,395評論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來鸦难,“玉大人根吁,你說我怎么就攤上這事『媳危” “怎么了击敌?”我有些...
    開封第一講書人閱讀 157,570評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長拴事。 經(jīng)常有香客問我沃斤,道長圣蝎,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,535評論 1 284
  • 正文 為了忘掉前任衡瓶,我火速辦了婚禮徘公,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘哮针。我一直安慰自己关面,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,650評論 6 386
  • 文/花漫 我一把揭開白布诚撵。 她就那樣靜靜地躺著缭裆,像睡著了一般。 火紅的嫁衣襯著肌膚如雪寿烟。 梳的紋絲不亂的頭發(fā)上澈驼,一...
    開封第一講書人閱讀 49,850評論 1 290
  • 那天,我揣著相機(jī)與錄音筛武,去河邊找鬼缝其。 笑死,一個(gè)胖子當(dāng)著我的面吹牛徘六,可吹牛的內(nèi)容都是我干的内边。 我是一名探鬼主播,決...
    沈念sama閱讀 39,006評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼待锈,長吁一口氣:“原來是場噩夢啊……” “哼漠其!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起竿音,我...
    開封第一講書人閱讀 37,747評論 0 268
  • 序言:老撾萬榮一對情侶失蹤和屎,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后春瞬,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體柴信,經(jīng)...
    沈念sama閱讀 44,207評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,536評論 2 327
  • 正文 我和宋清朗相戀三年宽气,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了随常。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,683評論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡萄涯,死狀恐怖绪氛,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情涝影,我是刑警寧澤钞楼,帶...
    沈念sama閱讀 34,342評論 4 330
  • 正文 年R本政府宣布,位于F島的核電站袄琳,受9級特大地震影響询件,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜唆樊,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,964評論 3 315
  • 文/蒙蒙 一宛琅、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧逗旁,春花似錦嘿辟、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,772評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至淀衣,卻和暖如春昙读,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背膨桥。 一陣腳步聲響...
    開封第一講書人閱讀 32,004評論 1 266
  • 我被黑心中介騙來泰國打工蛮浑, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人只嚣。 一個(gè)月前我還...
    沈念sama閱讀 46,401評論 2 360
  • 正文 我出身青樓沮稚,卻偏偏與公主長得像,于是被迫代替她去往敵國和親册舞。 傳聞我的和親對象是個(gè)殘疾皇子蕴掏,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,566評論 2 349

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

  • 什么是跨域 跨域,是指瀏覽器不能執(zhí)行其他網(wǎng)站的腳本调鲸。它是由瀏覽器的同源策略造成的盛杰,是瀏覽器對JavaScript實(shí)...
    Yaoxue9閱讀 1,288評論 0 6
  • 什么是跨域 跨域,是指瀏覽器不能執(zhí)行其他網(wǎng)站的腳本线得。它是由瀏覽器的同源策略造成的饶唤,是瀏覽器對JavaScript實(shí)...
    HeroXin閱讀 833評論 0 4
  • 什么是跨域 跨域,是指瀏覽器不能執(zhí)行其他網(wǎng)站的腳本贯钩。它是由瀏覽器的同源策略造成的募狂,是瀏覽器對JavaScript實(shí)...
    他方l閱讀 1,061評論 0 2
  • 引用:http://www.dailichun.com/2017/03/22/ajaxCrossDomainSol...
    Deam無限閱讀 2,245評論 0 9
  • 1.同源策略(Same origin Policy) 瀏覽器出于安全方面的考慮祸穷,只允許與本域下的接口交互。不同源的...
    好奇男孩閱讀 329評論 0 2