react打包后放到tomcat嵌套路由消失以及刷新頁(yè)面404解決方案

之前公司一直是用node服務(wù)器來(lái)對(duì)react打包后的項(xiàng)目進(jìn)行服務(wù)器部署的,最近有后臺(tái)小伙伴問(wèn)可以將打包后的文件丟到tomcat里面部署嗎摹菠,我回答當(dāng)然可以。但是在測(cè)試部署過(guò)程中遇到兩個(gè)問(wèn)題尿贫。

先說(shuō)下部署方式往毡,打包后生產(chǎn)的dist文件夾,丟到tomcat下的webapp下面洪乍。目錄如下圖,通過(guò)http://localhost:8080/dist/訪(fǎng)問(wèn)眯杏,發(fā)現(xiàn)

33.jpg

問(wèn)題1. 由于用的是全局路由(即在所以路由外面包了一層公共入口),發(fā)現(xiàn)部署后只能訪(fǎng)問(wèn)全局路由的內(nèi)容壳澳,所以子路由一片空白岂贩,頁(yè)面上只有一個(gè)全局路由的架子。(如果不用全局路由巷波,頁(yè)面直接就會(huì)空白萎津,訪(fǎng)問(wèn)不到)

1.jpg

原因:原來(lái)默認(rèn)我們?cè)诒镜亻_(kāi)發(fā)是直接通過(guò)http://localhost:8080/來(lái)訪(fǎng)問(wèn)的,現(xiàn)在部署的時(shí)候多了dist抹镊,路由就找不到了锉屈。

解決方案:所以需要在開(kāi)發(fā)過(guò)程中添加基礎(chǔ)路徑。

比如umi框架垮耳,只需要在.umirc.js添加base:'/dist'即可颈渊,其他框架,如dva等氨菇,需要將createHistory()改成createHistory({basename:'/dist'})即可儡炼。這樣頁(yè)面就可以訪(fǎng)問(wèn)到了。

22.jpg

問(wèn)題2:但是又發(fā)現(xiàn)當(dāng)我跳轉(zhuǎn)到其他頁(yè)面時(shí)查蓉,開(kāi)始是好的乌询,只要一刷新,頁(yè)面就報(bào)404找不到了豌研。

404.gif

原因:原來(lái)之所以你在開(kāi)發(fā)時(shí)候可以由首頁(yè)跳轉(zhuǎn)到其他路由地址妹田,是因?yàn)檫@是由前端自行渲染的,即在React Router定義了對(duì)應(yīng)的路由鹃共,有router更改了location,實(shí)際并沒(méi)有刷新網(wǎng)頁(yè)訪(fǎng)問(wèn)后臺(tái)鬼佣。所以頁(yè)面沒(méi)有問(wèn)題。但是部署到tomcat中霜浴,當(dāng)你刷新時(shí)晶衷,此時(shí)并不是之前的客戶(hù)端通過(guò)router來(lái)更改location,而是直接訪(fǎng)問(wèn)的后臺(tái)該頁(yè)面地址,然后后臺(tái)返回頁(yè)面到瀏覽器上。并沒(méi)有經(jīng)過(guò)前臺(tái)的路由(react所有的路由都是在index.html中來(lái)轉(zhuǎn)發(fā)晌纫,所以必須要任何請(qǐng)求必須要經(jīng)過(guò)index.html)税迷,所以就報(bào)404了。

解決方案:所以锹漱,我們需要對(duì)報(bào)404的頁(yè)面進(jìn)行重定向到index.html箭养,剩下的就會(huì)由react-router來(lái)進(jìn)行路徑跳轉(zhuǎn)。

我們?cè)诓渴鸬膁ist文件夾中新建一個(gè)WEB-INF文件夾哥牍,然后新建web.xml文件(web.xml用來(lái)初始化工程配置信息毕泌,比如說(shuō)welcome頁(yè)面,filter嗅辣,listener撼泛,servlet,servlet-mapping辩诞,啟動(dòng)加載級(jí)別等等坎弯。),在其中添加下面代碼就行了:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
                    http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
version="3.1"
metadata-complete="true">

    <error-page>
        <error-code>404</error-code>
        <location>/index.html</location>
    </error-page>

</web-app>
88.jpg

重啟tomcat服務(wù)器译暂,刷新頁(yè)面抠忘,成功訪(fǎng)問(wèn)。
至此外永,成功部署崎脉。注:上面出現(xiàn)的問(wèn)題,react-router模式為BrowerRouter才會(huì)有這種問(wèn)題伯顶,HashRouter不會(huì)出現(xiàn)問(wèn)題囚灼,因?yàn)閔ash路徑并沒(méi)有改變路徑,只是在同一個(gè)路徑增加參數(shù)而已

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末祭衩,一起剝皮案震驚了整個(gè)濱河市灶体,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌掐暮,老刑警劉巖蝎抽,帶你破解...
    沈念sama閱讀 211,265評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異路克,居然都是意外死亡樟结,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門(mén)精算,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)瓢宦,“玉大人,你說(shuō)我怎么就攤上這事灰羽⊥月模” “怎么了鱼辙?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,852評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)疲吸。 經(jīng)常有香客問(wèn)我座每,道長(zhǎng)前鹅,這世上最難降的妖魔是什么摘悴? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,408評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮舰绘,結(jié)果婚禮上蹂喻,老公的妹妹穿的比我還像新娘。我一直安慰自己捂寿,他們只是感情好口四,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,445評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著秦陋,像睡著了一般蔓彩。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上驳概,一...
    開(kāi)封第一講書(shū)人閱讀 49,772評(píng)論 1 290
  • 那天赤嚼,我揣著相機(jī)與錄音,去河邊找鬼顺又。 笑死更卒,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的稚照。 我是一名探鬼主播蹂空,決...
    沈念sama閱讀 38,921評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼果录!你這毒婦竟也來(lái)了上枕?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,688評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤弱恒,失蹤者是張志新(化名)和其女友劉穎辨萍,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體斤彼,經(jīng)...
    沈念sama閱讀 44,130評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡分瘦,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,467評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了琉苇。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片嘲玫。...
    茶點(diǎn)故事閱讀 38,617評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖并扇,靈堂內(nèi)的尸體忽然破棺而出去团,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 34,276評(píng)論 4 329
  • 正文 年R本政府宣布土陪,位于F島的核電站昼汗,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏鬼雀。R本人自食惡果不足惜顷窒,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,882評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望源哩。 院中可真熱鬧鞋吉,春花似錦、人聲如沸励烦。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,740評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)坛掠。三九已至赊锚,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間屉栓,已是汗流浹背舷蒲。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,967評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留系瓢,地道東北人阿纤。 一個(gè)月前我還...
    沈念sama閱讀 46,315評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像夷陋,于是被迫代替她去往敵國(guó)和親欠拾。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,486評(píng)論 2 348