每個開發人員都應該了解的基本 Express 請求屬性
在專案後端工作時,處理請求和回應至關重要。有效管理這些請求對於客戶端和伺服器之間的順利通訊至關重要。以下是每個開發人員都應該熟悉的一些常見且重要的請求屬性。
1. 請求ip
Express.js 中的req.ip 是請求物件的屬性,它提供發出請求的客戶端的 IP 位址。它傳回一個代表客戶端 IP 位址的字串。
處理代理:
預設情況下,如果應用程式位於代理程式後面,則 req.ip 可能會傳回代理程式的 IP,而不是真實客戶端的 IP。若要取得正確的用戶端 IP,您可以透過設定信任代理程式來設定 Express 信任代理程式。
app.set("trust proxy", true);
現在,即使在代理後面,req.ip 也會傳回客戶端的正確 IP。
範例:
app.get('/', (req, res) => { console.log(req.ip); // Logs the client's IP address res.send(`Your IP address is ${req.ip}`); });
2. 請求cookies
要使用 req.cookies,我們需要安裝名為 cookie-parser 中介軟體的套件。此屬性用於取得 Cookies header 中用戶端所發送的 cookie。 req.cookies 中的 Cookie 未簽名,表示它們未經修改或驗證。您可以將其用於不太敏感的數據
import cookieParser from "cookie-parser"; app.use(cookieParser()); app.get('/example', (req, res) => { console.log(req.cookies); // { cookieName: 'cookieValue' } });
3.req.signedCookies
要使用 req.signedCookies,我們需要安裝名為 cookie-parser 中間件的套件。其中包含已簽署和驗證的 cookie,以確保它們未被更改。簽署的 cookie 使用金鑰進行加密。 req.signedCookies 只儲存通過驗證的cookie。
如何設定簽章 Cookie:
若要設定簽章cookie,您可以使用signed: true選項:
res.cookie('signedCookieName', 'signedValue', { signed: true });
範例:
import cookieParser from "cookie-parser"; app.use(cookieParser('your-secret-key')); app.get('/example', (req, res) => { console.log(req.signedCookies); // { signedCookieName: 'signedValue' } });
4. 請求參數
Express.js 中的req.params 是一個包含請求 URL 中的路由參數的物件。路由參數在路由路徑中被命名為佔位符,req.params 將客戶端提供的值儲存在這些佔位符的 URL 中。
您可以透過在參數名稱前使用冒號 (:) 來定義帶參數的路由。
範例:
app.get('/users/:userId', (req, res) => { console.log(req.params); // { userId: 'valueFromURL' } res.send(`User ID is ${req.params.userId}`); });
5. 請求查詢
Express.js 中的req.query 是一個對象,其中包含請求 URL 中的查詢字串參數。查詢字串是位於 ? 之後的鍵值對。位於 URL 中,用於將附加資料傳遞到伺服器。可以使用 & 傳遞多個查詢。
範例網址:
http://example.com/search?term=flowers&sort=asc
範例:
app.get('/search', (req, res) => { console.log(req.query); // { term: 'flowers', sort: 'asc' } res.send(`Search term: ${req.query.term}, Sort order: ${req.query.sort}`); });
6. 請求體
它包含客戶端發送的資料的鍵值對。預設情況下,其值未定義。可以使用內建中間件(例如express.json和urlencoded({extended:true}))或外部中間件(例如body-parser)填充正文資料。
以下程式碼幫助您理解
import express from "express"; const app = express(); app.use(express.json()); app.use(express.urlencoded({ extended: true })); app.get("/user", (req, res) => { const user = req.body; consolo.log(user); res.send(user); })
希望您覺得這有幫助!不要忘記喜歡並保存以供將來參考。快樂編碼!
以上是每個開發人員都應該了解的基本 Express 請求屬性的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

不同JavaScript引擎在解析和執行JavaScript代碼時,效果會有所不同,因為每個引擎的實現原理和優化策略各有差異。 1.詞法分析:將源碼轉換為詞法單元。 2.語法分析:生成抽象語法樹。 3.優化和編譯:通過JIT編譯器生成機器碼。 4.執行:運行機器碼。 V8引擎通過即時編譯和隱藏類優化,SpiderMonkey使用類型推斷系統,導致在相同代碼上的性能表現不同。

JavaScript是現代Web開發的核心語言,因其多樣性和靈活性而廣泛應用。 1)前端開發:通過DOM操作和現代框架(如React、Vue.js、Angular)構建動態網頁和單頁面應用。 2)服務器端開發:Node.js利用非阻塞I/O模型處理高並發和實時應用。 3)移動和桌面應用開發:通過ReactNative和Electron實現跨平台開發,提高開發效率。

Python更適合初學者,學習曲線平緩,語法簡潔;JavaScript適合前端開發,學習曲線較陡,語法靈活。 1.Python語法直觀,適用於數據科學和後端開發。 2.JavaScript靈活,廣泛用於前端和服務器端編程。

本文展示了與許可證確保的後端的前端集成,並使用Next.js構建功能性Edtech SaaS應用程序。 前端獲取用戶權限以控制UI的可見性並確保API要求遵守角色庫

從C/C 轉向JavaScript需要適應動態類型、垃圾回收和異步編程等特點。 1)C/C 是靜態類型語言,需手動管理內存,而JavaScript是動態類型,垃圾回收自動處理。 2)C/C 需編譯成機器碼,JavaScript則為解釋型語言。 3)JavaScript引入閉包、原型鍊和Promise等概念,增強了靈活性和異步編程能力。

JavaScript不需要安裝,因為它已內置於現代瀏覽器中。你只需文本編輯器和瀏覽器即可開始使用。 1)在瀏覽器環境中,通過標籤嵌入HTML文件中運行。 2)在Node.js環境中,下載並安裝Node.js後,通過命令行運行JavaScript文件。
