node项目的总结(node,koa2,ejs)实现的一个博客项目
因为项目算是挺大的想看的就可以到这里下载https://gitee.com/kajian/web.git
所以下里面有意思的东西吧
md5的算法加密
-
crypto包
md5 (buffer) { let obj = crypto.createHash('md5') obj.update(buffer) return obj.digest('hex') }
crypto.createHash('md5')
创建一个md5的加密对象,更新传入的二进制数据obj.update(buffer)
,返回更新后的十六进制return obj.digest('hex')
session keys的制造
随便创建多个key
- fs包,文件处理包,用于生成一个keys文件方便读取
const fs = require('fs')
const KEY_LEN = 1024
const KEY_COUNT = 2048
const CHARS ='abcdefghijklmnopqrstuvwsyzABCDEFGHIJKLMNOPQRSTUVWSYZ0123456789/*-+,./[]|<>?{}":;!@~#$%^&*()_='
let arr =[]
for(let i = 0 ; i < KEY_COUNT ; i ++){
let key = ''
for(let j = 0 ; j<KEY_LEN ; j++){
key += CHARS[Math.floor(Math.random()*CHARS.length)]
}
arr.push(key)
}
fs.writeFileSync('.keys', arr.join('\n'))
console.log(`generated ${KEY_COUNT} key`)
创建2048个长度为1024的key,这样子别人想破解根本不可能,fs.writeFileSync('.keys', arr.join('\n'))
生成.keys文件并用\n空格符隔开每个key
session的加密操作
server.keys = fs.readFileSync('.keys').toString().split('\n')
server.use(session({
maxAge : 7*86400*1000,
renew : true
}, server))
读取.keys文件并且变成数组,并且进行session加密
详细的代码大家可以到上面的网站去下载哦