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变量作用域及可访问性的探讨
Nov 23 Javascript
js+css使DIV始终居于屏幕中间 左下 左上 右上 右下的代码集合
Mar 10 Javascript
利用了jquery的ajax实现二级联互动菜单
Dec 02 Javascript
JavaScript 实现打印,打印预览,打印设置
Dec 30 Javascript
C++中的string类的用法小结
Aug 07 Javascript
ajax实现动态下拉框示例
Jan 10 Javascript
canvas时钟效果
Feb 16 Javascript
Node.js获取前端ajax提交的request信息
Feb 20 Javascript
Vue计算属性的学习笔记
Mar 22 Javascript
JS面向对象编程实现的拖拽功能案例详解
Mar 03 Javascript
详解JavaScript作用域、作用域链和闭包的用法
Sep 03 Javascript
如何在现代JavaScript中编写异步任务
Jan 31 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 单引号与双引号的区别
2009/11/24 PHP
解析php中array_merge与array+array的区别
2013/06/21 PHP
thinkphp ajaxfileupload实现异步上传图片的示例
2017/08/28 PHP
原生JS实现Ajax通过POST方式与PHP进行交互的方法示例
2018/05/12 PHP
Laravel5.5 动态切换多语言的操作方式
2019/10/25 PHP
基于jQuery UI CSS Framework开发Widget的经验
2010/08/21 Javascript
JavaScript设计模式之观察者模式(发布者-订阅者模式)
2014/09/24 Javascript
jQuery动画出现连续触发、滞后反复执行的解决方法
2015/01/28 Javascript
js+css实现导航效果实例
2015/02/10 Javascript
深入浅析Bootstrap列表组组件
2016/05/03 Javascript
Angular2库初探
2017/03/01 Javascript
vue实现导航栏效果(选中状态刷新不消失)
2017/12/13 Javascript
VS Code转换大小写、修改选中文字或代码颜色的方法
2017/12/15 Javascript
浅谈Redux中间件的实践
2018/07/27 Javascript
Vue实现拖放排序功能的实例代码
2019/07/08 Javascript
微信小程序可滑动月日历组件使用详解
2019/10/21 Javascript
vue配置多代理服务接口地址操作
2020/09/08 Javascript
vue 里面的 $forceUpdate() 强制实例重新渲染操作
2020/09/21 Javascript
[44:15]国士无双DOTA2 6.82版本详解(上)
2014/09/28 DOTA
Python ORM框架SQLAlchemy学习笔记之关系映射实例
2014/06/10 Python
python开发之IDEL(Python GUI)的使用方法图文详解
2015/11/12 Python
Python的mysql数据库的更新如何实现
2017/07/31 Python
Python3单行定义多个变量或赋值方法
2018/07/12 Python
对Python中for复合语句的使用示例讲解
2018/11/01 Python
pytorch程序异常后删除占用的显存操作
2020/01/13 Python
django执行数据库查询之后实现返回的结果集转json
2020/03/31 Python
python实现人像动漫化的示例代码
2020/05/17 Python
Tommy Hilfiger美国官网:美国高端休闲领导品牌
2019/01/14 全球购物
材料加工工程求职信
2014/02/19 职场文书
银行先进个人事迹材料
2014/05/11 职场文书
对领导班子的意见和建议
2015/06/08 职场文书
小学运动会通讯稿
2015/07/18 职场文书
2015年学校少先队工作总结
2015/07/20 职场文书
2016年小学推普宣传周活动总结
2016/04/06 职场文书
SQL之各种join小结详细讲解
2021/08/04 MySQL
mysql中varchar类型的日期进行比较、排序等操作的实现
2021/11/17 MySQL