搜尋
首頁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
Vercel是什么?怎么部署Node服务?Vercel是什么?怎么部署Node服务?May 07, 2022 pm 09:34 PM

Vercel是什么?本篇文章带大家了解一下Vercel,并介绍一下在Vercel中部署 Node 服务的方法,希望对大家有所帮助!

node.js gm是什么node.js gm是什么Jul 12, 2022 pm 06:28 PM

gm是基于node.js的图片处理插件,它封装了图片处理工具GraphicsMagick(GM)和ImageMagick(IM),可使用spawn的方式调用。gm插件不是node默认安装的,需执行“npm install gm -S”进行安装才可使用。

火了!新的JavaScript运行时:Bun,性能完爆Node火了!新的JavaScript运行时:Bun,性能完爆NodeJul 15, 2022 pm 02:03 PM

今天跟大家介绍一个最新开源的 javaScript 运行时:Bun.js。比 Node.js 快三倍,新 JavaScript 运行时 Bun 火了!

聊聊Node.js中的多进程和多线程聊聊Node.js中的多进程和多线程Jul 25, 2022 pm 07:45 PM

大家都知道 Node.js 是单线程的,却不知它也提供了多进(线)程模块来加速处理一些特殊任务,本文便带领大家了解下 Node.js 的多进(线)程,希望对大家有所帮助!

nodejs中lts是什么意思nodejs中lts是什么意思Jun 29, 2022 pm 03:30 PM

在nodejs中,lts是长期支持的意思,是“Long Time Support”的缩写;Node有奇数版本和偶数版本两条发布流程线,当一个奇数版本发布后,最近的一个偶数版本会立即进入LTS维护计划,一直持续18个月,在之后会有12个月的延长维护期,lts期间可以支持“bug fix”变更。

node爬取数据实例:聊聊怎么抓取小说章节node爬取数据实例:聊聊怎么抓取小说章节May 02, 2022 am 10:00 AM

node怎么爬取数据?下面本篇文章给大家分享一个node爬虫实例,聊聊利用node抓取小说章节的方法,希望对大家有所帮助!

深入浅析Nodejs中的net模块深入浅析Nodejs中的net模块Apr 11, 2022 pm 08:40 PM

本篇文章带大家带大家了解一下Nodejs中的net模块,希望对大家有所帮助!

怎么获取Node性能监控指标?获取方法分享怎么获取Node性能监控指标?获取方法分享Apr 19, 2022 pm 09:25 PM

怎么获取Node性能监控指标?本篇文章来和大家聊聊Node性能监控指标获取方法,希望对大家有所帮助!

See all articles

熱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.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SublimeText3 Mac版

SublimeText3 Mac版

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

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具