DDR爱好者之家 Design By 杰米
最近在学习node.js,做了一个练手项目,使用node.js+express框架,配合mysql数据库和前端vue框架开发一个多人文档编辑系统。
node.js环境下express+mysql的服务端项目示例
首先是环境搭建:
node环境下
$ npm install -g express-generator $ express -e project
进入项目文件根目录安装依赖模块
$ npm install $ DEBUG=node-blog:* npm start
看看项目目录都有什么
看看生成的工程目录里面都有什么,
bin:存放可执行文件
node_modules:存放 package.json 中安装的模块,当你在 package.json 添加依赖的模块并安装后,存放在这个文件夹下
public:存放 image、css、js 等前端资源文件
routes:存放路由文件
views:存放视图文件或者说模版文件
app.js:启动文件,或者说入口文件
package.json:存储着工程的信息及模块依赖,当在 dependencies 中添加依赖的模块时,运行npm install ,npm 会检查当前目录下的 package.json,并自动安装所有指定的模块
下面开始安装数据库,这里我选择的是mysql。
npm install mysql --save-dev
安装完毕之后,开始配置数据库。
//mysql配置文件 mysql = { host: "xx.xxx.xx.xxx", //这是数据库的地址 user: "xxx", //需要用户的名字 password: "xxx", //用户密码 ,如果你没有密码,直接双引号就是 database: "xxx" //数据库名字 } //好了,这样我们就能连接数据库了 module.exports = mysql; //用module.exports暴露出这个接口, mysql连接池配置: //mysql连接池配置文件 var mysql = require('mysql'); var $dbConfig = require('../config/mysql');//注意改成自己项目中mysql配置文件的路径 // 使用连接池,避免开太多的线程,提升性能 var pool = mysql.createPool($dbConfig); /** * 对query执行的结果自定义返回JSON结果 */ function responseDoReturn(res, result, resultJSON) { if (typeof result === 'undefined') { res.json({ code: '201', msg: 'failed to do' }); } else { res.json(result); } }; /** * 封装query之sql带不占位符func */ function query(sql, callback) { pool.getConnection(function(err, connection) { connection.query(sql, function(err, rows) { callback(err, rows); //释放链接 connection.release(); }); }); } /** * 封装query之sql带占位符func */ function queryArgs(sql, args, callback) { pool.getConnection(function(err, connection) { connection.query(sql, args, function(err, rows) { callback(err, rows); //释放链接 connection.release(); }); }); } //exports module.exports = { query: query, queryArgs: queryArgs, doReturn: responseDoReturn }
操作数据库的过程比较灵活,我是使用模块化的思想,将一张数据表封装成一个模块暴露出去,通过该模块获取这张表的增删改查SQL语句。下面贴上示例代码:
let express = require('express'); let mysql = require('../common/basicConnection'); let qibu_task = { index: '', value: '', list: `SELECT * from qibu_task;`, //列表查询 insert(args) { qibu_task.index = ''; qibu_task.value = ''; args = filter(['id', 'task', 'name', 'created_at'], args) for (let key in args) { qibu_task.index = `${qibu_task.index}${key},` let re = /^[0-9]+.?[0-9]*/; if (re.test(args[key])) { qibu_task.value = `${qibu_task.value}${args[key]},` } else { qibu_task.value = `${qibu_task.value}'${args[key]}',` } } qibu_task.index = qibu_task.index.substr(0, qibu_task.index.length - 1); qibu_task.value = qibu_task.value.substr(0, qibu_task.value.length - 1); return `INSERT INTO qibu_task (${qibu_task.index}) VALUES(${qibu_task.value})`; }, //按需增加 select(index, value) { return `SELECT * from qibu_task where ${index}=${value};` //按需查询 }, delete(index, value) { return `DELETE from qibu_task where ${index}=${value};` //按需删除 }, update(index, args) { //提交修改 if (index in args) { qibu_task.value = ''; args = filter(['id', 'task', 'name', 'created_at'], args) for (let key in args) { let re = /^[0-9]+.?[0-9]*/; if (re.test(args[key])) { qibu_task.value = `${qibu_task.value}${key}=${args[key]},` } else { qibu_task.value = `${qibu_task.value}${key}='${args[key]}',` } } qibu_task.value = qibu_task.value.substr(0, qibu_task.value.length - 1) return `UPDATE qibu_task SET ${qibu_task.value} WHERE ${index}=${args[index]};` } }, }; //参数过滤 function filter(arguments, obj) { let newObj = {} arguments.forEach(every => { if (every in obj) { newObj[every] = obj[every] } }); return newObj; }; module.exports = qibu_task;
然后就可以在路由返回时进行数据库操作啦。具体代码就不贴啦。路由可以识别get、post方法,修改和删除通过传递参数模拟。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米
暂无评论...
更新日志
2024年11月25日
2024年11月25日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]