国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

nginx 部署vue項目,路由模式為history時,頁面刷新404問題

這篇具有很好參考價值的文章主要介紹了nginx 部署vue項目,路由模式為history時,頁面刷新404問題。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

情況說明

nginx部署vue項目,文件放在html下的dist文件夾中
nginx 部署vue項目,路由模式為history時,頁面刷新404問題
nginx.conf 文件中,server 里配置文件的位置、請求跨域等信息
nginx 部署vue項目,路由模式為history時,頁面刷新404問題

本案例解決方法

在啟動項目后因為配置的是root,首先是找不到html下面的sys-test文件夾,再經(jīng)過配置修改為alias配置后,刷新又會報404錯誤,最終配置為如下,成功解決

nginx 部署vue項目,路由模式為history時,頁面刷新404問題

配置解釋

為什么會出現(xiàn)404的情況

因為打包部署后,地址欄的地址只是vue的路由,并不是真的文件目錄地址。所有的路由都是依賴于SPA單頁應(yīng)用的index.html。所以當(dāng)刷新時,按照地址欄的地址,找不到對應(yīng)的文件,就產(chǎn)生404。
解決: 在nginx里進行try_files配置,讓其統(tǒng)一去查找index.html。(就是按照路徑找不到時,就去找index.html)

root 和 alias 的區(qū)別

主要區(qū)別在于nginx如何解釋location后面的uri,這會使兩者分別以不同的方式將請求映射到服務(wù)器文件上。
如以下root配置

location /sys-test {
    root   html;
    index  index.html;
}

這個去找的地方就是 root 配置的值和 location 配置的值相加,也就是去 html/sys-test 下尋找

如果是以下 alias 配置

location /sys-test {
    alias html/dist;
    index  index.html;
    try_files $uri $uri/ /dist/index.html;
}

alias 配置后,資源的路徑就是 alias 后面配置的路徑,也就是去 html/dist 下去尋找

try_files 配置的作用

try_files配置的作用 就是按順序檢查文件是否存在
配上一個簡單的例子進行解釋:

下面的配置意思就是:
當(dāng)我們訪問一個地址為 http://localhost:8888/sys-test/login 
1. 先通過alias 確定路徑 html/dist 
2. 然后通過try_files配置,首先會在html/dist下去找 $uri,也就是login這個文件
3. 這個時候因為沒有l(wèi)ogin文件,就會去找 $uri/ ,也就是 /login/ 這個文件目錄
4. 如果還是沒找到,就會將其重定向到 @router
5. 在定義的 @router 里,我們將其都指向 /dist 文件夾下的 index.html。這樣就成功解決問題!
/*
location /sys-test {
    alias html/dist/;
    index   index.html;
    try_files  $uri $uri/ /dist/index.html;
    // $uri 代表訪問的文件地址
    // $uri/ 代表訪問的文件目錄
}
*/

location /sys-test {
    alias html/dist/;
    index   index.html;
    try_files  $uri $uri/  @router;
    // $uri 代表訪問的文件地址
    // $uri/ 代表訪問的文件目錄
}
location @router {
     rewrite ^.*$ /dist/index.html;
     // 匹配所有  /dist/index.html;
}

友情提示

如若是自行配置nginx時,遇到一些問題,可先找到logs文件夾下的error.log文件,查看錯誤信息,定位錯誤原因,進行調(diào)整或百度文章來源地址http://www.zghlxwxcb.cn/news/detail-401216.html

到了這里,關(guān)于nginx 部署vue項目,路由模式為history時,頁面刷新404問題的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • nginx 部署vue項目,頁面白屏或者頁面刷新出現(xiàn)404問題

    將vue項目打包部署到nginx上面運行 問題一: 運行時頁面白屏。 問題二: 頁面可以正常顯示,當(dāng)刷新頁面的時候頁面報404 錯誤。 頁面白屏分析: 我們可以先查看一下nginx下的 logs/error.log 日志文件,確定我的問題是因為項目打包時候路勁配置問題。 頁面404分析 :我們在將

    2024年02月15日
    瀏覽(26)
  • 使用nginx方向代理部署Vue項目刷新頁面404的問題解決

    部署出現(xiàn)的問題為:由于項目中使用的vue router 項目直接使用node環(huán)境部署項目,在同一個路由如: 192.168.1.30:/home刷新瀏覽器正常 nginx部署刷新不出現(xiàn)404 /nginx not found 如何解決? 以下是我的想法:似乎是nginx代理使其直接訪問文件,而沒有使項目的路由生效從而正確加載資源 這

    2024年02月07日
    瀏覽(29)
  • Vue3中使用History模式引發(fā)刷新頁面出現(xiàn)404的問題

    在vue3中的路由中,路由間的跳轉(zhuǎn)是不刷新瀏覽器的,也就是用ajax來請求后端接口對組件進行增量更新,hash模式中#后面的路徑都不會直接發(fā)送給后端,都是前端自己在玩,但是路徑中有\(zhòng)\\'#\\\'不利于seo優(yōu)化而且也不美觀,一旦在history模式下刷新瀏覽器,就會相當(dāng)于直接請求后端中對應(yīng)uri的

    2024年02月17日
    瀏覽(22)
  • vue項目history模式刷新404問題

    vue項目history模式部署到服務(wù)器后 ,根路徑訪問沒有問題,但是進入其他功能再刷新頁面就會出現(xiàn)404,因為你沒在nginx或者apache配置上面加上重定向跳轉(zhuǎn)。 解決辦法,只需要加上這段配置: nginx配置內(nèi)容: apache配置內(nèi)容: 這句配置的意思是每次匹配url路徑時候找不到對應(yīng)靜態(tài)

    2024年02月11日
    瀏覽(28)
  • Vue學(xué)習(xí)筆記 之 History 路由 和 Hash 路由的區(qū)別 及 History 模式時,Nginx的配置方式

    一、History 模式、Hash 模式 ??Vue Router 是 Vue.js 官方的路由管理器,用于構(gòu)建單頁應(yīng)用的前端路由。它允許你通過定義路由配置來映射不同的 URL 到對應(yīng)的組件,實現(xiàn)頁面間的跳轉(zhuǎn)和導(dǎo)航。Vue Router 支持兩種路由模式:history 模式和 hash 模式。 1、History 模式 ??在 History 模式

    2024年02月07日
    瀏覽(18)
  • docker使用nginx部署vue刷新頁面404

    docker使用nginx部署vue刷新頁面404

    從docker內(nèi)部復(fù)制出來的配置文件是這樣的,但是刷新頁面之后就顯示404,關(guān)鍵是我兩個前端項目都是用的這一個配置文件,但是只有一個項目出現(xiàn)刷新瀏覽器顯示404的問題,這給我搞懵了!??! 在網(wǎng)上查找問題原因和解決辦法,但是大多數(shù)都說是資源找不到,讓修改配置文件

    2024年01月18日
    瀏覽(26)
  • 服務(wù)器部署—若依【vue】如何部署到nginx里面?nginx刷新頁面404怎么辦?【完美解決建議收藏】

    服務(wù)器部署—若依【vue】如何部署到nginx里面?nginx刷新頁面404怎么辦?【完美解決建議收藏】

    服務(wù)器部署項目我們大家都會遇到,但是有些鐵子會遇到很多的問題,比如前端部署nginx如何操作? 前端有單純的靜態(tài)頁面、還有前后端分離的項目;這里博主直接分享最牛最到位的前后端分離項目的前端部署到nginx上面,以若依項目【springboot+vue】為例,實現(xiàn)將前端部署到

    2024年02月03日
    瀏覽(31)
  • Vue/React 項目部署到服務(wù)器后,刷新頁面出現(xiàn)404報錯

    Vue/React 項目部署到服務(wù)器后,刷新頁面出現(xiàn)404報錯

    問題描述:在本地啟動項目一切正常, 部署到服務(wù)器上線后出現(xiàn)BUG,項目刷新頁面出現(xiàn)404 。 起初以為是自己路由守衛(wèi)或是token丟失問題,找了一圈終于解決了 產(chǎn)生原因: 我們打開vue/react打包后生成的dist文件夾,可以看到只有一個 index.html 文件及一些靜態(tài)資源,這個是因為

    2024年02月07日
    瀏覽(33)
  • 解決Vue3+Vite3 打包部署到nginx后配置非根目錄刷新頁面報錯空白

    解決Vue3+Vite3 打包部署到nginx后配置非根目錄刷新頁面報錯空白

    報錯內(nèi)容 解決方法 router文件 vite.config.ts nginx.conf 配置中路徑apps是我自建的存放前端頁面的文件夾 起關(guān)鍵作用的是 try_files $uri $uri/ /demo/index.html ,當(dāng)然上面項目文件夾demo也需保持一致 alias 后面的路徑是Vue項目打包后dist靜態(tài)文件服務(wù)器存放路徑,一般在nginx下面建一個文件夾

    2024年02月11日
    瀏覽(99)
  • vue3項目部署到服務(wù)器,剛打開沒事,一刷新頁面就404

    vue3項目部署到服務(wù)器,剛打開沒事,一刷新頁面就404

    vue3項目部署到服務(wù)器,剛打開沒事,一刷新頁面就404 不知道什么原因。百度了下才發(fā)現(xiàn)問題所在 問題所在: vue-router歷史模式的問題: vue3中歷史模式,默認(rèn)改為了HTML5模式: createWebHistory() 解決辦法: createWebHistory 換成 createWebHashHistory ,將歷史模式,由當(dāng)前的HTML5模式,改

    2024年01月18日
    瀏覽(37)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包