博客
关于我
从0到1学习node(七)之express搭建简易论坛
阅读量:464 次
发布时间:2019-03-06

本文共 3252 字,大约阅读时间需要 10 分钟。

Express论坛搭建指南

应用生成器

使用Express框架搭建论坛的首选工具是应用生成器。通过以下命令创建一个完整的开发框架:

npm install -g express-generatorexpress node_express_forum

生成后进入目录,安装必要依赖:

cd node_express_forumnpm install --save-dev

启动服务器并进入开发环境:

npm start

访问 127.0.0.1:3000 查看默认页面。

准备工作

完成框架搭建后,进行以下准备工作:

模板引擎

替换默认的Jade模板引擎,选择EJS:

npm install ejs --save-dev

app.js 中设置:

app.set('view engine', 'ejs');

数据库模型

创建用户、主题和回复三张表,定义模型文件:

// models/user.jsmodule.exports = {  hash: function(str) {    return crypto.createHmac('sha1', str).update('love').digest('hex');  },  reg: function(username, password, regtime, cb) {    pool.getConnection(function(err, connection) {      if (err) throw err;      connection.query('SELECT `id` FROM `user` WHERE `username` = ?', [username], function(err, result) {        if (err) throw err;        if (result.length) {          cb({ isExisted: true });        } else {          connection.query('INSERT INTO `user` SET ?', { username, password, regtime }, function(err, result) {            cb(result);          });        }      });    });  },  login: function(username, password, cb) {    pool.getConnection(function(err, connection) {      if (err) throw err;      connection.query('SELECT `id` FROM `user` WHERE `username` = ? AND `password` = ?', [username, password], cb);    });  }};

注册与登录

数据库连接

安装MySQL模块并创建数据库连接池:

npm install mysql --save-dev

创建 db.js 文件:

var mysql = require('mysql');var pool = mysql.createPool({  host: '127.0.0.1',  user: 'root',  password: '123',  database: 'forum'});module.exports = pool;

登录功能

routes/user.js 中定义登录路由:

router.post('/login', function(req, res, next) {  var username = req.body.username || '';  var password = req.body.password || '';  var password_hash = user_m.hash(password);  user_m.login(username, password_hash, function(result) {    if (result.length) {      req.session.user = { uid: result[0].id, username };      res.redirect('/');    } else {      res.render('login', { errmsg: '用户名或密码错误' });    }  });});

首页及详情页

主题列表

创建 list.js 模型:

module.exports = {  getIndexList: function(cb) {    pool.getConnection(function(err, connection) {      connection.query('SELECT `list`.*, username FROM `list`, `user` WHERE `list`.`uid` = `user`.`id`', function(err, result) {        cb(result);      });    });  }};

发表主题

routes/list.js 中添加路由:

router.get('/addtopic', function(req, res) {  if (req.session.user) {    var title = req.query.title, content = req.query.content;    list_m.addTopic({ uid: req.session.user.uid, title, content, createtime: Date.now() / 1000 }, function(result) {      if (result.affectedRows) {        res.json({ code: 0, msg: '添加成功', data: { url: '/list/' + result.insertId + '.html', title, author: req.session.user.username, createtime: result.insertId } });      } else {        res.json({ code: 2, msg: '添加失败,请重新尝试' });      }    });  } else {    res.json({ code: 1, msg: '您还未登录' });  }});

详情页

routes/list.js 中定义路由:

router.get('/:pid.html', function(req, res) {  var pid = req.params.pid;  async.parallel([    function(cb) {      list_m.getListById(pid, cb);    },    function(cb) {      list_m.getReplyById(pid, cb);    }  ], function(err, results) {    res.render('list', { data: results });  });});

总结

通过以上步骤,我们成功搭建了一个基于Express的简易论坛系统,涵盖了注册、登录、发布主题和回复主题等核心功能。完整的代码和文档可在我的GitHub上获取:[链接]

转载地址:http://vqvbz.baihongyu.com/

你可能感兴趣的文章
Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
查看>>
Nginx配置如何一键生成
查看>>
Nginx配置实例-负载均衡实例:平均访问多台服务器
查看>>
NHibernate学习[1]
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
查看>>
NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
查看>>
NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
查看>>
NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
查看>>
NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
查看>>
NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
查看>>
NIH发布包含10600张CT图像数据库 为AI算法测试铺路
查看>>
Nim教程【十二】
查看>>
Nim游戏
查看>>