国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

node(koa2) web應用模塊介紹詳解

2024-05-06 15:41:17
字體:
來源:轉載
供稿:網友

在自己的koa2 web項目中,用到了幾個模塊,感覺都是不錯的,特地來分享下這些模塊。

一、前言

我們都知道可以通過koa2 工程名的方式來初始化koa2項目,官方為我們增加了koa-bodyparser、koa-josn、koa-router等非常不錯的模塊,但是,仍不夠,所以我將搜集到的有用的包介紹下,當然,有好的包仍然會添加到其中。整個項目在koa2-web-engine ,為了方便查看,使用了原生的方式,歡迎查看。

二、新的模塊

將代碼克隆到本地并安裝依賴后,啟動服務器,在3000端口可以看到所有demo。

驗證碼

svg-captcha是一個驗證碼的庫,他創建了svg格式的驗證碼,可以在登錄時,驗證是否是正常的用戶登錄。

使用十分的簡單:

const svgCaptcha = require('svg-captcha');captcha = svgCaptcha.create();

captcha對象中包含了svg數據和svg上顯示的內容,至于是否要大小寫強制驗證就可以通過配置的方式來增加了。

處理代碼位于routes/verificationCode.js中。

密碼加密登錄

后端主要是利用node-rsa生成公鑰和私鑰,再將公鑰發送給前端,前端利用jsencrypt進行加密后發送給node,node再用私鑰解密。

為了性能,我只在服務器啟動的時候生成公鑰和私鑰,以后的請求都是用這隊公私鑰,他位于utils/RSA.js文件中,解密在routes/login.js中。

更詳細的可以查看我的這篇博客:基于node簡單實現RSA加解密。

參數類型檢測

為了服務器的安全性,服務器對前端發送來的數據肯定是要做校驗的,我這使用的joi庫。

校驗主要靠Joi.validate()方法,第一個參數是要校驗的對象數據,第二個參數是數據內每個鍵對應的數據類型,第三個則是可選的option,返回值是一個對象,該對象下的error字段用于判斷此次校驗是否成功。

在utils/checkParams.js中,paramsFormat定義了檢測類型,當然每個類型都得用joi內置的類型,checkParams()函數就是做檢測的地方,將最后的檢測結果return出去。

回到routes/joi.js中,利用checkParams()方法檢測數據類型,這兒的檢測是針對單個的請求,如果要針對所有的請求,可以寫成中間件的形式,如utils/middleware.js中,并在app.js中加入以下的就行了:

const middleware = require('./utils/middleware');middleware.use(app);

防xss

這兒用到的是xss模塊,將每次請求到的數據經過xss處理,輸出到后端。為此我自己搞了koa2-xss中間件模塊,順帶學習了如何發布npm包,感興趣的可以看下。

日志記錄

我是用的是log4js模塊,該模塊既可以記錄到數據庫,也可以記錄到log文件中,此處我是寫到文件中的。

utils/logs.js文件中是log4js的配置,并封裝了對外的調用接口,routes/log4js.js中是根據用戶發送的請求記錄到日志文件中。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 襄樊市| 竹北市| 洛宁县| 磐石市| 马公市| 调兵山市| 丰城市| 扎囊县| 邹城市| 河间市| 黄浦区| 大余县| 潜江市| 连平县| 曲水县| 仁寿县| 钟祥市| 托克托县| 东丰县| 龙门县| 定南县| 永泰县| 浪卡子县| 普洱| 海安县| 太康县| 广汉市| 亚东县| 达州市| 从江县| 额济纳旗| 邓州市| 瑞安市| 武夷山市| 仪陇县| 浪卡子县| 即墨市| 芒康县| 二连浩特市| 漳平市| 舟山市|