溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Nginx報(bào)404錯誤如何解決

發(fā)布時(shí)間:2022-08-17 09:50:08 來源:億速云 閱讀:326 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹“Nginx報(bào)404錯誤如何解決”的相關(guān)知識,小編通過實(shí)際案例向大家展示操作過程,操作方法簡單快捷,實(shí)用性強(qiáng),希望這篇“Nginx報(bào)404錯誤如何解決”文章能幫助大家解決問題。

近日在部署項(xiàng)目時(shí),出現(xiàn)了一些問題,如圖

Nginx報(bào)404錯誤如何解決

正常的登錄界面是可以訪問的,但是在登錄之后訪問之后的地址會報(bào)404錯誤,于是去查看是否配置有錯誤,但是查看之后發(fā)現(xiàn),nginx.confconfig.js兩個配置文件的ip和端口都是沒有錯誤的

這個項(xiàng)目部署過好多次,沒有出現(xiàn)過這樣的錯誤。

這是原版沒動過的解壓縮后的nginx.conf的源文件

Nginx報(bào)404錯誤如何解決

圈起來的地方是應(yīng)該按照項(xiàng)目配置對應(yīng)的ip和監(jiān)聽的端口

listen對應(yīng)的是端口,server_name對應(yīng)的是訪問的ip

但是這樣是不能解決問題,我們需要添加如下的一句話

try_files $uri $uri/ /index.html;

添加的位置應(yīng)當(dāng)在這里

Nginx報(bào)404錯誤如何解決

server下的location段里添加,此時(shí)再重新啟動nginx就可以了

nginx.exe所在的目錄內(nèi),點(diǎn)擊地址欄,輸入cmd,可直接在該目錄下啟動命令行,無需打開cmd后再跳轉(zhuǎn)目錄。

若之前沒有關(guān)閉nginx服務(wù),先停止再打開,如果已關(guān)閉,可以直接輸入啟動服務(wù)的命令

停止nginx服務(wù)命令:

nginx -s stop

 啟動nginx服務(wù)命令:

start nginx

熱部署nignx服務(wù)命令:

(但是不推薦使用這個命令,這個命令有時(shí)候是不起作用的,不如直接停了再啟動)

nginx -s reload

重新啟動nginx后,瀏覽器最好是清除緩存后再進(jìn)行測試

可以直接在瀏覽器窗口按

Ctrl+Shift+Del

可直接打開清除緩存的對話框

重新測試,可以正常訪問了

Nginx報(bào)404錯誤如何解決

補(bǔ)充:Nginx部署之后正常點(diǎn)擊沒問題,刷新頁面會出現(xiàn)404問題的解決

項(xiàng)目部署到服務(wù)器后 ,根路徑訪問沒有問題(http:10.10.10.10),但是進(jìn)入其他功能再刷新頁面就會出現(xiàn)404,比如

http:10.10.10.10/test/test/test 刷新頁面就會出現(xiàn)404,因?yàn)槟銢]在nginx配置上面加上重定向跳轉(zhuǎn)。

解決辦法,只需要加上這段配置:

try_files $uri $uri/ /index.html;

server {
    listen 80;
    server_name 127.0.0.1;
	
	location / {
		root /data/htdocs/FactoryModel/micro-front-end/industrial-internet-platform-main-vue;
		index index.php index.html index.htm;
		# add_header Cache-Control;
		add_header Access-Control-Allow-Origin *;
		if ( $request_uri ~* ^.+.(js|css|jpg|png|gif|tif|dpg|jpeg|eot|svg|ttf|woff|json|mp4|rmvb|rm|wmv|avi|3gp)$ ){
		  add_header Cache-Control max-age=7776000;
		  add_header Access-Control-Allow-Origin *;
		}
		try_files $uri $uri/ /index.html;
	}
}

這句配置的意思是每次匹配url路徑時(shí)候找不到對應(yīng)靜態(tài)資源時(shí)候調(diào)制跳轉(zhuǎn)到index.html文件

如圖加在這里即可

下面內(nèi)容需要稍微知道router路由工作原理、nginx原理

解析為什么會這樣(針對路由在history模式下):

先提出問題:

1、為什么刷新頁面會(沒有配置情況下且不在首頁根目錄刷新)
2、為什么點(diǎn)擊跳轉(zhuǎn)時(shí)候會(有時(shí))

現(xiàn)在來解決問題:

1、假設(shè)現(xiàn)在在瀏覽器上的url為 172.1.2.3:7000/test ,此時(shí)刷新頁面時(shí)候會去根據(jù)瀏覽器上的url去服務(wù)器(nginx)上面請求對應(yīng)的靜態(tài)資源,nginx根據(jù)location / 的匹配規(guī)則在dist文件夾里沒有找到對應(yīng)的靜態(tài)文件"test",所以返回404,合理。

此時(shí)通過配置try_files來重定向返回index.html文件,也就是回去首頁“ / ”,注意,此時(shí)你的頁面已經(jīng)刷新過了,此時(shí)react-router或者vue-router路由發(fā)揮作用,會根據(jù)當(dāng)前的url地址來對應(yīng)匹配上組件,所以此時(shí)url即對應(yīng)組件,頁面重新加載完成,完事。

2、第二個問題,為什么點(diǎn)擊跳轉(zhuǎn)時(shí)候會而有時(shí)候不會,要知道跳轉(zhuǎn)有兩種情況:一種頁面刷新(屬于第一個問題),一種頁面不刷新。這取決于你代碼的書寫情況,請記住:

1、push不會刷新頁面,只會更改瀏覽器上的url路由變更,不管是react-router還是vue-router都是運(yùn)用html的api實(shí)現(xiàn),叫做pushState()
2、通過 會刷新頁面,它相當(dāng)于a標(biāo)簽

可自行在瀏覽器上面試下

Nginx報(bào)404錯誤如何解決

所以當(dāng)你點(diǎn)擊跳轉(zhuǎn)時(shí)候,有時(shí)候你代碼用的是push(不刷新)、有時(shí)候用的是a標(biāo)簽、Link(刷新),才導(dǎo)致這個問題。

關(guān)于“Nginx報(bào)404錯誤如何解決”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識,可以關(guān)注億速云行業(yè)資訊頻道,小編每天都會為大家更新不同的知識點(diǎn)。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI