node(koa2) web应用模块介绍详解


Posted in Javascript onMarch 29, 2019

在自己的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中是根据用户发送的请求记录到日志文件中。

定时任务

利用了node-schedule模块,一个系统总会用到定时任务的,node-schedule提供了较为简单的api,使用比较方便。

路由合并

koa2初始化的项目中是将每个路由文件require到app.js中的,当路由文件变多时,管理这些路由就是件麻烦的事,于是引入了koa-compose来管理这些路由文件,只对外暴露一个接口。详细的可以查看routes/index.js文件。

webSocket

websocket在实时性要求比较高的场景下也是会用到的,我们可以利用ws模块实现。更为详细的可以查看我的这篇文章:基于node实现websocket通信。

三、总结

后期用到一些有意思,有用的模块也将加入到koa2-web-engine 中。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery异步加载数据并添加事件示例
Aug 24 Javascript
javascript发送短信验证码实现代码
Nov 12 Javascript
Bootstrap下拉菜单效果实例代码分享
Jun 30 Javascript
浅谈JS使用[ ]来访问对象属性
Sep 21 Javascript
浅谈bootstrap使用中的一些问题以及解决过程
Oct 18 Javascript
headjs实现网站并行加载但顺序执行JS
Nov 29 Javascript
jQuery解析返回的xml和json方法详解
Jan 05 Javascript
jQuery对table表格进行增删改查
Dec 22 Javascript
教你5分钟学会用requirejs(必看篇)
Jul 25 Javascript
vue移动端微信授权登录插件封装的实例
Aug 28 Javascript
javascript中floor使用方法总结
Feb 02 Javascript
JavaScript undefined及null区别实例解析
Jul 21 Javascript
Vue js 的生命周期(看了就懂)(推荐)
Mar 29 #Javascript
浅谈js闭包理解
Mar 28 #Javascript
微信小程序中转义字符的处理方法
Mar 28 #Javascript
微信小程序中使用Async-await方法异步请求变为同步请求方法
Mar 28 #Javascript
详解Js里的for…in和for…of的用法
Mar 28 #Javascript
ES7之Async/await的使用详解
Mar 28 #Javascript
详解vue-cli3多环境打包配置
Mar 28 #Javascript
You might like
PHP获取表单textarea数据中的换行问题
2010/09/10 PHP
HTML中嵌入PHP的简单方法
2016/02/16 PHP
PHP中调用C/C++制作的动态链接库的教程
2016/03/10 PHP
Ajax提交表单时验证码自动验证 php后端验证码检测
2016/07/20 PHP
hover的用法及live的用法介绍(鼠标悬停效果)
2013/03/29 Javascript
使用简洁的jQuery方法实现隔行换色功能
2014/01/02 Javascript
js处理php输出时间戳对不上号的解决方法
2014/06/20 Javascript
javascript实现全局匹配并替换的方法
2015/04/27 Javascript
JS工作中的小贴士之”闭包“与事件委托的”阻止冒泡“
2016/06/16 Javascript
JavaScript DOM节点操作实例小结(新建,删除HTML元素)
2017/01/19 Javascript
vue2.0 elementUI制作面包屑导航栏
2018/02/22 Javascript
解决vue-cli + webpack 新建项目出错的问题
2018/03/20 Javascript
实现elementUI表单的全局验证的方法步骤
2019/04/29 Javascript
前端插件之Bootstrap Dual Listbox使用教程
2019/07/23 Javascript
createObjectURL方法实现本地图片预览
2019/09/30 Javascript
Angular利用HTTP POST下载流文件的步骤记录
2020/07/26 Javascript
JS时间戳与日期格式互相转换的简单方法示例
2021/01/30 Javascript
python爬取网站数据保存使用的方法
2013/11/20 Python
Python中的赋值、浅拷贝、深拷贝介绍
2015/03/09 Python
python使用pyqt写带界面工具的示例代码
2017/10/23 Python
python 3.5实现检测路由器流量并写入txt的方法实例
2017/12/17 Python
对python3 urllib包与http包的使用详解
2018/05/10 Python
解决tensorflow测试模型时NotFoundError错误的问题
2018/07/27 Python
Python 如何反方向迭代一个序列
2020/07/28 Python
python中scrapy处理项目数据的实例分析
2020/11/22 Python
python实现经典排序算法的示例代码
2021/02/07 Python
Clarria化妆品官方网站:购买天然和有机化妆品系列
2018/04/08 全球购物
酒店前台接待岗位职责
2013/12/03 职场文书
知识就是力量演讲稿
2014/09/13 职场文书
党的群众路线教育实践活动对照检查材料(四风)
2014/09/27 职场文书
2014年高校辅导员工作总结
2014/12/09 职场文书
承诺书范本
2015/01/21 职场文书
西湖英语导游词
2015/02/06 职场文书
Java集成swagger文档组件
2021/06/28 Java/Android
再谈python_tkinter弹出对话框创建
2022/03/20 Python
Python学习之迭代器详解
2022/04/01 Python