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实现table单双行不同显示并能单行选中
Jul 25 Javascript
javascript与CSS复习(二)
Jun 29 Javascript
jQuery写fadeTo示例代码
Feb 21 Javascript
JavaScript判断用户是否对表单进行了修改的方法
Mar 18 Javascript
基于Bootstrap的UI扩展 StyleBootstrap
Jun 17 Javascript
JS实现列表的响应式排版(推荐)
Sep 01 Javascript
微信小程序  checkbox组件详解及简单实例
Jan 10 Javascript
Bootstrap模态框插入视频的实现代码
Jun 25 Javascript
JS实现图片放大镜插件详解
Nov 06 Javascript
Vue下的国际化处理方法
Dec 18 Javascript
原生JS实现$.param() 函数的方法
Aug 10 Javascript
vue-router命名视图的使用讲解
Jan 19 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基础知识:类与对象(1)
2006/12/13 PHP
PHP curl CURLOPT_RETURNTRANSFER参数的作用使用实例
2015/02/07 PHP
纯PHP代码实现支付宝批量付款
2015/12/24 PHP
php中引用&的用法分析【变量引用,函数引用,对象引用】
2016/12/12 PHP
PHP批斗大会之缺失的异常详解
2019/07/09 PHP
PHP Swoole异步读取、写入文件操作示例
2019/10/24 PHP
js调用图片隐藏&显示实现代码
2013/09/13 Javascript
jCallout 轻松实现气泡提示功能
2013/09/22 Javascript
JS下载文件|无刷新下载文件示例代码
2014/04/17 Javascript
JavaScript定义类和对象的方法
2014/11/26 Javascript
本人自用的global.js库源码分享
2015/02/28 Javascript
JavaScript实战(原生range和自定义特效)简单实例
2016/08/21 Javascript
浅谈Web页面向后台提交数据的方式和选择
2016/09/23 Javascript
学习vue.js条件渲染
2016/12/03 Javascript
three.js实现围绕某物体旋转
2017/01/25 Javascript
Node.js安装配置图文教程
2017/05/10 Javascript
Vue进度条progressbar组件功能
2018/04/17 Javascript
JS内部事件机制之单线程原理
2018/07/02 Javascript
ES6 Symbol数据类型的应用实例分析
2019/06/26 Javascript
微信小程序 scroll-view 水平滚动实现过程解析
2019/10/12 Javascript
零基础写python爬虫之爬虫的定义及URL构成
2014/11/04 Python
python在Windows8下获取本机ip地址的方法
2015/03/14 Python
Python中endswith()函数的基本使用
2015/04/07 Python
python实现烟花小程序
2019/01/30 Python
django如何自己创建一个中间件
2019/07/24 Python
python使用正则表达式(Regular Expression)方法超详细
2019/12/30 Python
Python把图片转化为pdf代码实例
2020/07/28 Python
python 实现表情识别
2020/11/21 Python
基于HTML5新特性Mutation Observer实现编辑器的撤销和回退操作
2016/01/11 HTML / CSS
Bailey帽子官方商店:Bailey Hats
2018/09/25 全球购物
BookOutlet加拿大:在网上书店购买廉价折扣图书和小说
2018/10/05 全球购物
广告创意求职信
2014/03/17 职场文书
会计电算化专业求职信
2014/06/10 职场文书
党员先进性教育整改措施
2014/09/18 职场文书
教师对照四风自我剖析材料
2014/09/30 职场文书
个人工作作风整改措施思想汇报
2014/10/13 职场文书