首頁 web前端 js教程 如何解決nodejs的路徑問題

如何解決nodejs的路徑問題

Jun 30, 2018 pm 03:13 PM
nodejs 路徑

這篇文章主要介紹了nodejs的路徑問題的解決,內容還挺不錯的,現在分享給大家,也給大家做個參考。

最近公司的一個開發項目,後端用的是nodejs。這兩天需要打包給客戶示範,就請公司一個小夥把之前3D機房的打包工具移植過來。打包之後,發現原本在開發環境下的跑的好好的項目,不能訪問了。出現專案的首頁無法存取的問題:

can not get file index.html

express.static

#問題出在哪裡?

nodejs後端的用了express,index.html是一個靜態檔案。我們知道,透過 Express 內建的 express.static 可以方便地託管靜態文件,例如圖片、CSS、JavaScript 文件等。

將靜態資源檔案所在的目錄作為參數傳遞給 express.static 中間件就可以提供靜態資源檔案的存取了。例如,假設在public 目錄放置了圖片、CSS 和JavaScript 文件,可以使用以下程式碼:

 app.use(express.static('public'));
登入後複製
登入後複製

所以,找到專案中的程式碼,查看static呼叫的地方,和上面一行程式碼很一樣:

 app.use(express.static('public'));
登入後複製
登入後複製

到此,我已經發現了問題,我告訴小夥伴,這個地方不用相對路徑可以解決這個問題。由於打包時間限制,我讓小夥伴先簡單處理下,打完包包之後,在來整理下思路:

app.use(express.static('resource/public'));
登入後複製

當然最重要的是,這個問題其實不難,自己多鑽研下,很容易發現問題,也就不會出這個問題,所以小夥伴自己打手心吧。

恩,你沒看錯,這個地方還是相對目錄。後續產品中會改成比較好的一種狀況。

express.static方法解析

#事實上,express.static方法如果傳入的是相對路徑,express會自己把他轉換為絕對路徑,我們可以查看下原始碼,在express.js找到如下程式碼:

exports.static = require('serve-static');
登入後複製

說明static 呼叫了serve-static這個包,直接找到這個包,查看index.js, 可以看到程式碼,下面列出重要的兩行

 ...
var resolve = require('path').resolve
...
opts.root = resolve(root)
...
登入後複製

這兩行就是,express把相對目錄轉換成絕對目錄的程式碼,可以看出,最終使用的path這個內建物件的resolve方法,繼續往下看。

path物件的resolve方法

#直接查看這個方法的api文檔,如下:https://nodejs.org/api/path .html#path_path_resolve_paths

##以下是這個方法的解釋:


##The path.resolve() method resolves a sequence of paths or path segments into an absoluteolves a sequence of paths or path segments into an absolute path.


啥意思呢?就是這個方法把一系列的paths或path segments 組織成一個絕對路徑,比如
 path.resolve('/foo','bar');
// return /foo/bar
登入後複製

詳細的說明請自行參考文檔,這個地方有一句話需要特別注意:


If after processing all given path segments an absolute path has not yet been generated, the current working directory is used.


啥,就是如果處理了所有的path 如何處理了,也沒有產生一個絕對路徑, 就要使用當前工作目錄(current working directory)。例如:
 path.resolve('bar');
// 加上 /Users/terry 是当前工作目录, return /Users/terry/bar
登入後複製

api文檔中一個比較複雜的範例(此處注意resolve的時候,從右到左,參考文件了解詳情):

path.resolve('wwwroot', 'static_files/png/', '../gif/image.gif');
// if the current working directory is /home/myself/node,
// this returns '/home/myself/node/wwwroot/static_files/gif/image.gif'
登入後複製

現在的問題是,啥是目前工作目錄。


nodejs 目前工作目錄 current working directory


nodejs 目前工作目錄是啟動Node的目錄。也就是說,從哪個目錄進去啟動node,就回傳哪個目錄。 

注意,這個目錄不是指js檔案所在的目錄


透過process.cwd()方法可以取得目前工作目錄。


下面透過一個範例來介紹這個目前工作目錄,假如在/Users/terry/Documents/JSWorkspace目錄下寫一個js文件,test.js,程式碼只有一行:

console.log(process.cwd());
登入後複製

此時如果,在目錄/Users/terry/Documents/JSWorkspace下面執行命令:node test.js 輸出如下:

 /Users/terry/Documents/JSWorkspace
登入後複製

但是如果在目錄/Users/terry/Documents/下面執行命令: node ./JSWorkspace/test.js,輸出的結果是:

/Users/terry/Documents
登入後複製

因此可以看出你在那個目錄執行node指令,目前目錄就是那個目錄。


回到之前的打包的問題,由於在開發階段,一般都是直接在js檔案所在目錄執行node指令,所以相對目錄寫的是相對於目前js檔案的目錄沒有問題。


可是打包之後,node的執行放到了js目錄的上一層去了。此時相對目錄「public」不在是相對於js檔案的相對目錄,而是相對於上一層的,自然就找不到這個資料夾了,從而也找不到該資料夾下的index.html文件。


如何解決

#解決的方法:

1.在前面已经说过了,改这个相对目录。但这种方法很蹩脚。因为,启动node命令的目录可能会变;而是如果这应该,开发阶段的node命令执行也需要跟着改。 总之不是兼容性很好的方法。

2.直接使用绝对路径。 但是这个绝对路径在不同的机器上又不一样,该如何解决呢?可以考虑使用全局变量__dirname.

全局变量__dirname

查看api文档 https://nodejs.org/api/modules.html#modules_dirname

看到解释如下:

The directory name of the current module. This is the same as the path.dirname() of the __filename。

啥意思呢,及时返回nodejs 的js文件的所在目录。

有了这个变量之后,我们就可以用如下代码解决这个问题。

app.use(express.static(__dirname + '/public'));
登入後複製

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

Node.js中路径处理模块path的介绍

如何在NodeJS项目中使用ES6

以上是如何解決nodejs的路徑問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

nodejs和vuejs區別 nodejs和vuejs區別 Apr 21, 2024 am 04:17 AM

Node.js 是一種伺服器端 JavaScript 執行時,而 Vue.js 是一個客戶端 JavaScript 框架,用於建立互動式使用者介面。 Node.js 用於伺服器端開發,如後端服務 API 開發和資料處理,而 Vue.js 用於用戶端開發,如單一頁面應用程式和響應式使用者介面。

nodejs是後端框架嗎 nodejs是後端框架嗎 Apr 21, 2024 am 05:09 AM

Node.js 可作為後端框架使用,因為它提供高效能、可擴展性、跨平台支援、豐富的生態系統和易於開發等功能。

nodejs怎麼連接mysql資料庫 nodejs怎麼連接mysql資料庫 Apr 21, 2024 am 06:13 AM

要連接 MySQL 資料庫,需要遵循以下步驟:安裝 mysql2 驅動程式。使用 mysql2.createConnection() 建立連接對象,其中包含主機位址、連接埠、使用者名稱、密碼和資料庫名稱。使用 connection.query() 執行查詢。最後使用 connection.end() 結束連線。

nodejs安裝目錄裡的npm與npm.cmd檔有什麼差別 nodejs安裝目錄裡的npm與npm.cmd檔有什麼差別 Apr 21, 2024 am 05:18 AM

Node.js 安裝目錄中有兩個與 npm 相關的文件:npm 和 npm.cmd,區別如下:擴展名不同:npm 是可執行文件,npm.cmd 是命令視窗快捷方式。 Windows 使用者:npm.cmd 可以在命令提示字元中使用,npm 只能從命令列執行。相容性:npm.cmd 特定於 Windows 系統,npm 跨平台可用。使用建議:Windows 使用者使用 npm.cmd,其他作業系統使用 npm。

nodejs中的全域變數有哪些 nodejs中的全域變數有哪些 Apr 21, 2024 am 04:54 AM

Node.js 中存在以下全域變數:全域物件:global核心模組:process、console、require執行階段環境變數:__dirname、__filename、__line、__column常數:undefined、null、NaN、Infinity、-Infinity

nodejs和java的差別大嗎 nodejs和java的差別大嗎 Apr 21, 2024 am 06:12 AM

Node.js 和 Java 的主要差異在於設計和特性:事件驅動與執行緒驅動:Node.js 基於事件驅動,Java 基於執行緒驅動。單執行緒與多執行緒:Node.js 使用單執行緒事件循環,Java 使用多執行緒架構。執行時間環境:Node.js 在 V8 JavaScript 引擎上運行,而 Java 在 JVM 上運行。語法:Node.js 使用 JavaScript 語法,而 Java 使用 Java 語法。用途:Node.js 適用於 I/O 密集型任務,而 Java 適用於大型企業應用程式。

nodejs是後端開發語言嗎 nodejs是後端開發語言嗎 Apr 21, 2024 am 05:09 AM

是的,Node.js 是一種後端開發語言。它用於後端開發,包括處理伺服器端業務邏輯、管理資料庫連接和提供 API。

nodejs專案怎麼部署到伺服器 nodejs專案怎麼部署到伺服器 Apr 21, 2024 am 04:40 AM

Node.js 專案的伺服器部署步驟:準備部署環境:取得伺服器存取權限、安裝 Node.js、設定 Git 儲存庫。建置應用程式:使用 npm run build 產生可部署程式碼和相依性。上傳程式碼到伺服器:透過 Git 或檔案傳輸協定。安裝依賴項:SSH 登入伺服器並使用 npm install 安裝應用程式相依性。啟動應用程式:使用 node index.js 等命令啟動應用程序,或使用 pm2 等進程管理器。設定反向代理(可選):使用 Nginx 或 Apache 等反向代理路由流量到應用程式

See all articles