react+springboot解決跨域問(wèn)題的3種方法

在學(xué)習(xí)的過(guò)程柱嫌,遇到react 項(xiàng)目axios訪問(wèn)后臺(tái)springboot項(xiàng)目谒养,發(fā)現(xiàn)404 跨域問(wèn)題游岳。
其中涉及到的方法有:
1沥潭、webpack.config.js文件用設(shè)置代理proxy邀泉;
2、直接在springboot項(xiàng)目的Controller文件加入注解@CrossOrigin钝鸽,前端請(qǐng)求中直接寫入后臺(tái)的uri
3汇恤、把react項(xiàng)目部署到 nginx 服務(wù)器上.
以前自己查找方法的時(shí)候,總是抱怨別人的寫的不詳細(xì)拔恰,但是真正 自己寫技術(shù)文章的時(shí)候因谎,才發(fā)現(xiàn)有時(shí)候真的想簡(jiǎn)單點(diǎn),而且有時(shí)也考慮的比較少颜懊,多多包涵财岔。
axios:對(duì)應(yīng)的文檔可以到github 搜索axios .地址:https://github.com/search?q=axios,第一個(gè)就是河爹,進(jìn)去里面就是axios的安裝以及用法

axios.png

好了 下面將分別說(shuō)一下對(duì)應(yīng)的方法:
1匠璧、設(shè)置代理proxy,在webpack.config.js文件修改devServer

var host = '192.168.**.***';
...
devServer: {
        hot: true,
    host: host,
        compress: true,
        port: 3457,
        historyApiFallback: true,
        contentBase: path.resolve(__dirname),
        publicPath: '/build/',
        proxy: {
            "/api/*": {
                //host 即為你后臺(tái)springboot的地址 8083對(duì)應(yīng)的端口號(hào)
                target: `http://{host}:8083/`,  
                secure: false,
                changeOrigin: true,
                // 前端請(qǐng)求uri:api/user  解析出來(lái)的結(jié)果就是http://{host}:8083/user  即去掉api前綴
                pathRewrite: { '^/api': '' }
            }
        },
        stats: {
            modules: false,
            chunks: false
        },
    },

前端的訪問(wèn):

axios.post('/api/t-test/getTtestById', 
        querystring.stringify({
            id: '42',
            lastName: '你好'
          })
          )
          .then(function (response) {
            console.log("打印跨域返回?cái)?shù)據(jù):"+JSON.stringify(response.data));
          })
          .catch(function (error) {
            console.log(error);
          });

2咸这、通過(guò)注解的方式@CrossOrigin
在對(duì)應(yīng)的Controller文件上增加@CrossOrigin 夷恍,也可以單獨(dú)對(duì)需要跨域的方法增加注解

...
@CrossOrigin
@Controller
@RequestMapping("/t-test")
public class TTestController {
...

前端訪問(wèn)的方式

TestKuayu = () =>{
        console.log("測(cè)試跨域問(wèn)題!");
        //直接把springboot項(xiàng)目的uri寫入請(qǐng)求中炊苫,如果不想每次都寫裁厅,可以把uri封裝到一個(gè)變量中
        axios.post('http://localhost:8989/t-test/getTtestById', 
        querystring.stringify({
            id: '42',
            lastName: '你好'
          })
          )
          .then(function (response) {
            console.log("打印跨域數(shù)據(jù):"+JSON.stringify(response.data));
          })
          .catch(function (error) {
            console.log(error);
          });

    }

3.部署到nginx 服務(wù)器冰沙,詳細(xì)講這個(gè)吧

(1)首先安裝nginx 官網(wǎng):http://nginx.org/

微信截圖_20190402163648.png

nginx版本.png

(2) 配置nginx
解壓 先別啟動(dòng)nginx.exe侨艾,打開dos窗口 win+R 輸入cmd. 進(jìn)入到nginx目錄 下面是我的目錄 ,
nginx會(huì)話.png

也可以ctrl+alt+. 打開任務(wù)管理->詳細(xì)信息 能看到nginx啟動(dòng)成功
任務(wù)管理器.png

(3)react項(xiàng)目運(yùn)行npm run build
build.png

之后在文件目錄找到build文件夾 拓挥,下面是我的打包好文件目錄
builds.png

把這里的文件都復(fù)制到nginx的安裝目錄下的html文件夾里面


nginx_html.png

注意:修改nginx 目錄 conf文件夾下nginx.conf 可以用sublime text打開 也可以用文本文件等等唠梨。。

修改 http 下sever:

...
server {
        listen       8800;  #代理的端口
        server_name  localhost;  #代理的地址

        #root:D:\react\reactdemo\reactdemo01\build;
        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html;          # 默認(rèn)的入口文件
            index  index.html index.htm;
        }

        location /api/ {          # /api 代理到下面 地址  就是修改成你后臺(tái)的uri
            proxy_pass http://192.168.*.*:8989/;
        }
....

修改了配置 文件 記得要重啟一起nginx : nginx -s reload

react 測(cè)試 貼出部分代碼

<button onClick={this.TestKuayu}>測(cè)試跨域問(wèn)題</button>

TestKuayu = () =>{
        
        console.log("測(cè)試跨域問(wèn)題侥啤!");
        axios.post('/api/t-test/getTtestById', 
        querystring.stringify({
            id: '42',
            lastName: '你好'
          })
          )
          .then(function (response) {
            console.log("打印nginx跨域:"+JSON.stringify(response.data));
          })
          .catch(function (error) {
            console.log(error);
          });

    }

nginx部署目錄.png
后臺(tái).png
r.png

rs.png

至此全部完成当叭,有什么不正確的茬故,可以指出一起交流。
ly_dv 一個(gè)小菜鳥

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末蚁鳖,一起剝皮案震驚了整個(gè)濱河市磺芭,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌醉箕,老刑警劉巖钾腺,帶你破解...
    沈念sama閱讀 212,080評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異讥裤,居然都是意外死亡放棒,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,422評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門己英,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)间螟,“玉大人,你說(shuō)我怎么就攤上這事损肛∠崞疲” “怎么了?”我有些...
    開封第一講書人閱讀 157,630評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵荧关,是天一觀的道長(zhǎng)溉奕。 經(jīng)常有香客問(wèn)我,道長(zhǎng)忍啤,這世上最難降的妖魔是什么加勤? 我笑而不...
    開封第一講書人閱讀 56,554評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮同波,結(jié)果婚禮上鳄梅,老公的妹妹穿的比我還像新娘。我一直安慰自己未檩,他們只是感情好戴尸,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,662評(píng)論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著冤狡,像睡著了一般孙蒙。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上悲雳,一...
    開封第一講書人閱讀 49,856評(píng)論 1 290
  • 那天挎峦,我揣著相機(jī)與錄音,去河邊找鬼合瓢。 笑死坦胶,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播顿苇,決...
    沈念sama閱讀 39,014評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼峭咒,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了纪岁?” 一聲冷哼從身側(cè)響起凑队,我...
    開封第一講書人閱讀 37,752評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎幔翰,沒想到半個(gè)月后顽决,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,212評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡导匣,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,541評(píng)論 2 327
  • 正文 我和宋清朗相戀三年才菠,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片贡定。...
    茶點(diǎn)故事閱讀 38,687評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡赋访,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出缓待,到底是詐尸還是另有隱情蚓耽,我是刑警寧澤,帶...
    沈念sama閱讀 34,347評(píng)論 4 331
  • 正文 年R本政府宣布旋炒,位于F島的核電站步悠,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏瘫镇。R本人自食惡果不足惜鼎兽,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,973評(píng)論 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望铣除。 院中可真熱鬧谚咬,春花似錦、人聲如沸尚粘。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,777評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)郎嫁。三九已至秉继,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間泽铛,已是汗流浹背尚辑。 一陣腳步聲響...
    開封第一講書人閱讀 32,006評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留厚宰,地道東北人笆怠。 一個(gè)月前我還...
    沈念sama閱讀 46,406評(píng)論 2 360
  • 正文 我出身青樓牧氮,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子培他,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,576評(píng)論 2 349

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