Skip to content

基于node+mongoose+koa2+ejs 开发的个人博客

Notifications You must be signed in to change notification settings

hu949277923/blog

Repository files navigation

blog

基于node+mongoose+koa2+ejs 开发的个人

环境搭建

  • node.js
  • mongoose
  • redis
  • pm2
  • nginx

总结

登录功能(具体实现如下)

  1. 将session存储到redis中,涉及中间件有koa-session2、ioredis;并且需要安装并启动redis 默认端口6379
  2. 每个页面都需要获取session来判断登录状态,故通过ctx.state将session传递给所有模板(页面)
// app.js
const session = require("koa-session2")
const Store = require("./utils/store")
// session 中间件
app.use(session({
  key: 'sessionKey',   //default "koa:sess"
  store: new Store()
}));

app.use(async (ctx, next) => {
  ctx.state = Object.assign(ctx.state, { session: ctx.session});
  await next()
})

app.use(ctx => {
    let user = ctx.session.user; // 获取session中的user
 
    ctx.session.user = "bill"; // 添加session字段user
});
// index.ejs
<%= session.user%>

时间过滤器

引入moment.js,将moment对象传递至前端视图(ejs)

// app.js
const moment = require('moment')
app.use(async (ctx, next) => {
  ctx.state = Object.assign(ctx.state, { moment: moment });
  
  await next()
})

静态资源缓存

项目上线后,发现每次访问都很慢,经测试发现,静态资源每次都会重新发起请求,后来找到koa-static-cache插件,可以将静态资源缓存,具体如下:

$npm install koa-static-cache

const staticCache = require('koa-static-cache')
app.use(staticCache(pathPublic, {
  maxAge: 365 * 24 * 60 * 60,
  gzip: true
}))

引入markdown文本编辑器

<script src="/javascripts/markdown-it.min.js"></script>
<script src="/javascripts/ace/ace.js"></script>
// markdown 创建
var acen_edit = ace.edit('mdeditor'); 
acen_edit.setTheme('ace/theme/chrome');
acen_edit.setFontSize(20);
acen_edit.getSession().setMode('ace/mode/markdown');
acen_edit.renderer.setShowPrintMargin(false);
// markdown 文本键入时
$("#mdeditor").keyup(function() {
  var md = window.markdownit();
  var result = md.render(acen_edit.getValue());
    $("#preview").html(result);
});

About

基于node+mongoose+koa2+ejs 开发的个人博客

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published