這篇文章帶大家了解Node中的express框架,介紹一下express中的身份認證,希望對大家有幫助!
Web開發模式
目前主流的網路開發模式有兩種:
基於服務端渲染的傳統Web開發模式
服務端渲染的概念:伺服器傳送給客戶端的HTML頁面,是在伺服器透過字串的拼接,動態產生的。因此,客戶端不需要使用Ajax這樣的技術額外請求頁面的資料。 【相關教學建議:nodejs影片教學、程式教學】
程式碼如下:
app.get('/index.html',(req,res)=>{ // 1.要渲染的数据 const user = {name:'zs',age:20} // 2.服务器通过字符串的拼接,动态生成 HTML 内容 const html = `<h1 id="姓名-user-name-年龄-user-age">姓名:${user.name},年龄:${user.age}</h1>` // 3.把生成好的页面内容响应给客户端。因此客户端拿到的是带有真实数据的 HTML 页面 res.send(html) })
服務端渲染的優缺點
優點:
1)#前端耗時少:因為伺服器端負責動態生成HTML內容,瀏覽器只需要直接渲染頁面即可。尤其是行動端,更省電。
2)有利於SEO:因為伺服器端回應的是完整的 HTML頁面內容,所以爬蟲更容易爬取獲得訊息,更有利於SEO。
缺點:
1)佔用伺服器端資源:即伺服器端完成HTML頁面內容的拼接,如果請求較多,會對伺服器造成一定的存取壓力。
2)不利於前後端分離,開發效率低:使用伺服器端渲染,則無法進行分工合作,尤其對於前端複雜度高的項目,不利於專案高效開發。
基於前後端分離的新型Web開發模式
#前後端分離的概念:前後端分離的開發模式,依賴於Ajax技術的廣泛應用。簡而言之,前後端分離的Web開發模式,就是後端只負責提供API接口,前端使用Ajax呼叫接口的開發模式。
前後端分離的優缺點
#:
#1)開發體驗好。前端專注於UI頁面的開發,後端專注於api的開發,且前端有更多的選擇性
2)使用者體驗好。 Ajax技術的廣泛應用,極大的提高了使用者的體驗,可以輕鬆實現頁面的局部刷新
3)減輕了伺服器端的渲染壓力。因為頁面最終是在每個使用者的瀏覽器中產生的。
缺點:
1)不利於SE0。因為完整的HTML頁面需要在客戶端動態拼接完成,所以爬蟲對無法爬取頁面的有效資訊。 (解決方案:利用Vue、React等前端框架的SSR (server side render)技術能夠很好的解決SEO問題!)
如何選擇Web開發模式
例如企業級網站,主要功能是展示而沒有複雜的交互,並且需要良好的SEO,則這時我們就需要使用伺服器端渲染;而類似後台管理項目,互動性比較強,不需要考慮SEO,那麼就可以使用前後端分離的開發模式。
因此,具體使用何種開發模式並不是絕對的,為了同時兼顧了首頁的渲染速度和前後端分離的開發效率,一些網站採用了首屏服務器端渲染+其他頁面前後端分離的開發模式。
身份認證
身份認證(Authentication)又稱「身份驗證”、“鑑權”,是指透過一定的手段,完成對使用者身分的確認。在網頁開發中,也涉及使用者身分的認證,例如:各大網站的手機驗證碼登入、郵件帳號登入
# #、
二維碼登入等。 身份認證的
目的######:為了確認目前所聲稱為某種身分的用戶,確實是所聲稱的用戶。 #########不同開發模式下的######身份認證##########对于服务端渲染和前后端分离这两种开发模式来说,分别有着不同的身份认证方案:
1)服务端渲染推荐使用 Session 认证机制
2)前后端分离推荐使用 JWT 认证机制
Session认证机制
HTTP协议的无状态性:指的是客户端的每次HTTP请求都是独立的,连续多个请求之间没有直接的关系,服务器不会主动保留每次HTTP请求的状态。而要想突破HTTP的无状态的限制,就需要借助Cookie。
Cookie是存储在用户浏览器中的一段不超过4KB的字符串。它由一个名称(Name)、一个值(Value)和其它几个用于控制Cookie有效期、安全性、使用范围的可选属性组成。不同域名下的Cookie 各自独立,每当客户端发起请求时,会自动把当前域名下所有未过期的Cookie一同发送到服务器。
Cookie的特性:自动发送、域名独立、过期时限、4KB限制。
Cookie在身份认证中的作用
客户端第一次请求服务器的时候,服务器通过响应头的形式,向客户端发送一个身份认证的Cookie,客户端会自动将Cookie保存在浏览器中。随后,当客户端浏览器每次请求服务器的时候,浏览器会自动将身份认证相关的Cookie,通过请求头的形式发送给服务器,服务器即可验明客户端的身份。
Cookie的安全性问题
由于Cookie是存储在浏览器中的,而且浏览器提供了读写Cookie的API,因此Cookie很容易被伪造,不具有安全性。因此不建议服务器将重要的隐私数据,通过Cookie的形式发送给浏览器,所以千万不要使用Cookie存储重要且隐私的数据,比如用户的身份信息、密码等。
而Session的认证机制就是为了提高cookie安全性的一种认证机制。
Session的工作原理
在Express中使用Session认证
在Express项目中,只需安装 express-session 中间件,即可在项目中使用Session认证:
npm install express-session
express-session中间件安装完成后,需要通过app.use()来注册session中间件,代码如下:
// 配置 Session 中间件 const session = require('express-session') app.use(session({ secret:'Session_test', // secret 属性值可以是任意字符串 resave:false, // 固定写法 saveUninitialized:true // 固定写法 }))
当express-session中间件配置成功后,即可通过 req.session 来访问和使用 session 对象,从而存储用户的关键信息:
// 登录的API接口 app.post('/api/login',(req,res)=>{ // 判断用户提交的信息是否正确 if(req.body.username !=='admin' || req.body.password !=='123456'){ return res.send({status:1,msg:'登录失败'}) } // 登录成功后,将成功的用户信息保存到session中 // 注意:只有成功配置了 express-session 这个中间件后,才能通过 req 点出来 session 这个属性 req.session.user = req.body // 用户的信息 req.session.islogin = true // 用户的登录状态 res.send({status:0,msg:'登录成功'}) })
当然也可以直接从 req.session 对象上获取之前存储的数据。代码如下:
app.post('/api/logout',(req,res)=>{ // 清空session信息 req.session.destroy() res.send({ status:0, msg:'退出登录成功' }) })
Session认证的局限性:Session认证机制需要配合Cookie 才能实现。由于Cookie默认不支持跨域访问,所以,当涉及到前端跨域请求后端接口的时候,需要做很多额外的配置,才能实现跨域Session认证。
当前端请求后端接口不存在跨域问题的时候,推荐使用Session身份认证机制。
JWT认证机制
JWT(英文全称:JSON Web Token)是目前最流行的跨域认证解决方案。当前端需要跨域请求后端接口的时候,不推荐使用Session身份认证机制,推荐使用JWT认证机制。
JWT工作原理:用户的信息通过Token字符串的形式,保存在客户端浏览器中。服务器通过还原Token字符串的形式来认证用户的身份。
JWT的组成部分:
Header(头部)、Payload(有效荷载)、Signature(签名)。
Payload部分才是真正的用户信息,它是用户信息经过加密之后生成的字符串。
Header和Signature是安全性相关的部分,只是为了保证Token的安全性。
三者之间使用英文的“.”分隔,格式如下:
Header.Payload.Signature
JWT的使用方式: 客户端收到服务器返回的WT之后,通常会将它储存在localStorage或sessionStorage中。此后,客户端每次与服务器通信,都要带上这个WT的字符串,从而进行身份认证。推荐的做法是把JWT放在HTTP请求头的Authorization字段中,格式如下:
Authorization: Bearer <token></token>
在Express中使用JWT
运行如下命令安装两个JWT相关的包:
# jsonwebtoken用于生成JWT字符串 # express-jwt用于将JWT字符串解析还原成JSON对象 npm install jsonwebtoken express-jwt@5.3.3
定义secret密钥:为了保证JWT字符串的安全性,防止JWT字符串在网络传输过程中被别人破解,我们需要专门定义一个用于加密和解密的secret密钥。
当生成JWT字符串的时候,需要使用 secret 密钥对用户的信息进行加密,最终得到加密好的JWT字符串;当把JWT字符串解析还原成JSON对象的时候,需要使用secret密钥进行解密。
// 定义 secret 密钥,建议将密钥命名为 secretKey const secretKey = 'Hello Node.js'
生成JWT字符串:调用jsonwebtoken包提供的sign()方法,将用户的信息加密成JWT字符串,响应给客户端。
// 登录接口 app.post('/api/login',(req,res)=>{ // 将 req.body 请求体中的数据,转存为 userinfo 常量 const userinfo = req.body // 登录失败 if(userinfo.username !=='admin' || userinfo.password !=='123456'){ return res.send({ status:400, message:'登录失败!' }) } // 三个参数分别是:用户信息对象,加密密钥,配置对象 const tokenStr = jwt.sign({username: userinfo.username},secretKey,{expiresIn:'20s'}) // 用户登录成功后,生成 JWT 字符串,通过 token 属性响应给客户端 res.send({ status:200, message:'登录成功', token: tokenStr, // 要发送给客户端的 token 字符串 }) })
JWT字符串还原为JSON对象:客户端每次在访问那些有权限接口的时候,都需要主动通过请求头中的Authorization字段将Token字符串发送到服务器进行身份认证。此时,服务器可以通过express-jwt这个中间件,自动将客户端发送过来的Token解析还原成JSON对象。
// 注册将 JWT 字符串解析还原成 JSON 对象的中间件 // expiresJWT({secret:secretKey}) 用来解析 Token 的中间件 // .unless({path:[/^\/api\//]}) 用来指定哪些接口不需要访问权限 app.use(expressJWT({secret:secretKey}).unless({path:[/^\/api\//]}))
使用req.user获取用户信息:当express-jwt这个中间件配置成功之后,即可在那些有权限的接口中,使用req.user对象,来访问从WT字符串中解析出来的用户信息了,示例代码如下:
app.get('/admin/getinfo',function(req,res){ // 使用 req.user 获取用户信息,并使用data属性将用户信息发送给客户端 console.log(req.user); res.send({ status:200, message:'获取用户信息成功', data:req.user, // 要发送给客户端的用户信息 }) })
捕获解析JWT失败后产生的错误:当使用express-jwt解析Token字符串时,如果客户端发送过来的Token字符串过期或不合法,会产生一个解析失败的错误,影响项目的正常运行。我们可以通过 Express的错误中间件,捕获这个错误并进行相关的处理,示例代码如下:
// 使用全局错误处理中间件,捕获解析 JWT 失败后产生的错误 app.use((err, req, res, next) => { // 这次错误是由 token 解析失败导致的 if (err.name === 'UnauthorizedError') { return res.send({ status: 401, message: '无效的token', }) } res.send({ status: 500, message: '未知的错误', }) })
具体详细代码如下:
// 导入 express 模块 const express = require('express') // 创建服务器 const app = express() // 导入JWT相关的两个包 const jwt = require('jsonwebtoken') const expressJWT = require('express-jwt') // 允许跨域资源共享 const cors = require('cors') app.use(cors()) // 解析 post 表单数据的中间件 const bodyParser = require('body-parser') app.use(bodyParser.urlencoded({ extended: false })) // 定义 secret 密钥,建议将密钥命名为 secretKey const secretKey = 'Hello Node.js' // 注册将 JWT 字符串解析还原成 JSON 对象的中间件 // expiresJWT({secret:secretKey}) 用来解析 Token 的中间件 // .unless({path:[/^\/api\//]}) 用来指定哪些接口不需要访问权限 app.use(expressJWT({secret:secretKey}).unless({path:[/^\/api\//]})) // 登录接口 app.post('/api/login',(req,res)=>{ // 将 req.body 请求体中的数据,转存为 userinfo 常量 const userinfo = req.body // 登录失败 if(userinfo.username !=='admin' || userinfo.password !=='123456'){ return res.send({ status:400, message:'登录失败!' }) } // 三个参数分别是:用户信息对象,加密密钥,配置对象 const tokenStr = jwt.sign({username: userinfo.username},secretKey,{expiresIn:'50s'}) // 用户登录成功后,生成 JWT 字符串,通过 token 属性响应给客户端 res.send({ status:200, message:'登录成功', token: tokenStr, // 要发送给客户端的 token 字符串 }) }) // 这是一个有权限的API接口 app.get('/admin/getinfo',function(req,res){ // 使用 req.user 获取用户信息,并使用data属性将用户信息发送给客户端 console.log(req.user); res.send({ status:200, message:'获取用户信息成功', data:req.user, // 要发送给客户端的用户信息 }) }) // 使用全局错误处理中间件,捕获解析 JWT 失败后产生的错误 app.use((err, req, res, next) => { // 这次错误是由 token 解析失败导致的 if (err.name === 'UnauthorizedError') { return res.send({ status: 401, message: '无效的token', }) } res.send({ status: 500, message: '未知的错误', }) }) // 调用app.listen 方法,指定端口号并启动web服务器 app.listen(80,function(){ console.log('Express server running at http://127.0.0.1:80'); })
更多node相关知识,请访问:nodejs 教程!
以上是一文詳解Node中express的身份認證的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Python和JavaScript在社區、庫和資源方面的對比各有優劣。 1)Python社區友好,適合初學者,但前端開發資源不如JavaScript豐富。 2)Python在數據科學和機器學習庫方面強大,JavaScript則在前端開發庫和框架上更勝一籌。 3)兩者的學習資源都豐富,但Python適合從官方文檔開始,JavaScript則以MDNWebDocs為佳。選擇應基於項目需求和個人興趣。

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

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

JavaScript在現實世界中的應用包括服務器端編程、移動應用開發和物聯網控制:1.通過Node.js實現服務器端編程,適用於高並發請求處理。 2.通過ReactNative進行移動應用開發,支持跨平台部署。 3.通過Johnny-Five庫用於物聯網設備控制,適用於硬件交互。

我使用您的日常技術工具構建了功能性的多租戶SaaS應用程序(一個Edtech應用程序),您可以做同樣的事情。 首先,什麼是多租戶SaaS應用程序? 多租戶SaaS應用程序可讓您從唱歌中為多個客戶提供服務

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

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

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


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Dreamweaver CS6
視覺化網頁開發工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

SublimeText3 Linux新版
SublimeText3 Linux最新版

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

WebStorm Mac版
好用的JavaScript開發工具