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 相关文章推荐
utf8的编码算法 转载
Dec 27 Javascript
javascript学习笔记(九)javascript中的原型(prototype)及原型链的继承方式
Apr 12 Javascript
js转义字符介绍
Nov 05 Javascript
引用 js在IE与FF之间的区别详细解析
Nov 20 Javascript
js定时器的使用(实例讲解)
Jan 06 Javascript
window.location.href的用法(动态输出跳转)
Aug 09 Javascript
js实现二级菜单渐隐显示
Nov 03 Javascript
javascript如何实现360度全景照片问题汇总
Apr 04 Javascript
Javascript的无new构建实例详解
May 15 Javascript
JavaScript兼容性总结之获取非行间样式案例
Aug 07 Javascript
Vue.js 2.0学习教程之从基础到组件详解
Apr 24 Javascript
关于layui的动态图标不显示的解决方法
Sep 04 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 minixml详解
2008/07/19 PHP
让PHP支持断点续传的源码
2010/05/16 PHP
WordPress中用于获取文章作者与分类信息的方法整理
2015/12/17 PHP
php插件Xajax使用方法详解
2017/08/31 PHP
PHP共享内存使用与信号控制实例分析
2018/05/09 PHP
PHP封装的page分页类定义与用法完整示例
2018/12/24 PHP
PHP7内核之Reference详解
2019/03/14 PHP
PHP+redis实现微博的推模型案例分析
2019/07/10 PHP
php 函数中静态变量使用的问题实例分析
2020/03/05 PHP
JavaScript 继承详解(二)
2009/07/13 Javascript
JavaScript 函数式编程的原理
2009/10/16 Javascript
一行代码实现纯数据json对象的深度克隆实现思路
2013/01/09 Javascript
JavaScript实现列出数组中最长的连续数
2014/12/29 Javascript
jQuery实现设置、移除文本框默认值功能
2015/01/13 Javascript
jQuery仿淘宝网产品品牌隐藏与显示效果
2015/09/01 Javascript
3种js实现string的substring方法
2015/11/09 Javascript
jQuery on()方法绑定动态元素的点击事件实例代码浅析
2016/06/16 Javascript
request请求获取参数的实现方法(post和get两种方式)
2016/09/27 Javascript
使用Angular.js开发的注意事项
2016/10/19 Javascript
vue表单绑定实现多选框和下拉列表的实例
2017/08/12 Javascript
vue-cli3.0 特性解读
2018/04/22 Javascript
video.js 实现视频只能后退不能快进的思路详解
2018/08/09 Javascript
js实现蒙版效果
2020/01/11 Javascript
vue中解决chrome浏览器自动播放音频和MP3语音打包到线上的实现方法
2020/10/09 Javascript
Python中__new__与__init__方法的区别详解
2015/05/04 Python
Python获取运行目录与当前脚本目录的方法
2015/06/01 Python
使用python实现ANN
2017/12/20 Python
python编写简单端口扫描器
2019/09/04 Python
python pygame实现球球大作战
2019/11/25 Python
Python hashlib加密模块常用方法解析
2019/12/18 Python
python使用matplotlib:subplot绘制多个子图的示例
2020/09/24 Python
python 动态绘制爱心的示例
2020/09/27 Python
python subprocess pipe 实时输出日志的操作
2020/12/05 Python
python绘制高斯曲线
2021/02/19 Python
Hotels.com泰国:酒店预订网站
2019/11/20 全球购物
村官工作鉴定评语
2014/01/27 职场文书