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 相关文章推荐
js不完美解决click和dblclick事件冲突问题
Jul 16 Javascript
JavaScript中的字符串操作详解
Nov 12 Javascript
解决Jquery鼠标经过不停滑动的问题
Mar 03 Javascript
JavaScript实现向右伸出的多级网页菜单效果
Aug 25 Javascript
基于javascript实现动态时钟效果
Aug 18 Javascript
JavaScript实现九九乘法表的简单实例
Jun 07 Javascript
Vue.js 2.0中select级联下拉框实例
Mar 06 Javascript
jQuery使用EasyUi实现三级联动下拉框效果
Mar 08 Javascript
React为 Vue 引入容器组件和展示组件的教程详解
May 03 Javascript
Vue父子组建的简单通信之控制开关Switch的实现
Jun 04 Javascript
js实现滑动进度条效果
Aug 21 Javascript
vue数据字典取键值项目的字典问题
Apr 12 Vue.js
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下载文件名中解决乱码的问题
2013/06/20 PHP
PHP解密Unicode及Escape加密字符串
2015/05/17 PHP
PHP导出Excel实例讲解
2016/01/24 PHP
Yii2.0中的COOKIE和SESSION用法
2016/08/12 PHP
php多文件打包下载的实例代码
2017/07/12 PHP
科讯商业版中用到的ajax空间与分页函数
2007/09/02 Javascript
extjs 的权限问题 要求控制的对象是 菜单,按钮,URL
2010/03/09 Javascript
jQuery EasyUI API 中文文档 - ComboBox组合框
2011/10/07 Javascript
jquery实现table鼠标经过变色代码
2013/09/25 Javascript
javascript中解析四则运算表达式的算法和示例
2014/08/11 Javascript
jQuery中addClass()方法用法实例
2015/01/05 Javascript
angular中使用路由和$location切换视图
2015/01/23 Javascript
Angularjs中controller的三种写法分享
2016/09/21 Javascript
NW.js 简介与使用方法
2018/02/01 Javascript
微信小程序获取地理位置及经纬度授权代码实例
2019/09/18 Javascript
vue组件传值的实现方式小结【三种方式】
2020/02/05 Javascript
Javascript如何实现双指控制图片功能
2020/02/25 Javascript
Python利用字典将两个通讯录文本合并为一个文本实例
2018/01/16 Python
对Python函数设计规范详解
2019/07/19 Python
Python实现线性插值和三次样条插值的示例代码
2019/11/13 Python
Django更新models数据库结构步骤
2020/04/01 Python
Python截图并保存的具体实例
2021/01/14 Python
HTML5到底会有什么发展?HTML5的前景展望
2015/07/07 HTML / CSS
Chinti & Parker官网:奢华羊绒女装和创新针织设计
2021/01/01 全球购物
一家外企的面试题目(C/C++面试题,C语言面试题)
2014/03/24 面试题
介绍一下grep命令的使用
2012/06/28 面试题
生物技术毕业生自荐信
2013/10/23 职场文书
总经理司机职责
2014/02/02 职场文书
《槐乡五月》教学反思
2014/04/25 职场文书
大学第二课堂活动总结
2014/07/08 职场文书
聚会通知怎么写
2015/04/23 职场文书
郭明义观后感
2015/06/08 职场文书
客户答谢会致辞
2015/07/30 职场文书
2016中秋节问候语
2015/11/11 职场文书
课改心得体会范文
2016/01/25 职场文书
golang http使用踩过的坑与填坑指南
2021/04/27 Golang