首发github/blog 欢迎大家评论给星

安装

首先假定你已经安装了 Node.js,接下来为你的应用创建一个目录,然后安装express-generator应用骨架

$ mkdir node-demo
$ npm install express-generator -g //mac需要加sudo

express -h

$ express -h
用法: express [options] [dir]
选项: -h, --help 输出使用信息
-V, --version 输出版本号
-e, --ejs 添加ejs引擎支持(默认为jade)
--hbs 添加handlebars引擎支持
-H, --hogan 添加hogan.js引擎支持
-c, --css <engine> 添加stylesheet <engine> 支持 (less|stylus|compass|sass) (默认为CSS)
--git 添加.gitignore
-f, --force 非空目录上的 force

express-generator 生成应用骨架

$ express node-demo

执行此命令后会有以下代码

warning: the default view engine will not be jade in future releases
warning: use `--view=jade' or `--help' for additional options //警告:默认的视图引擎在未来版本中不会是JADE
//警告:使用“-VIEW = JADE”或“帮助”选项 //这里我们重新生成骨架默认为ejs模板 使用以下命令 //express --view=ejs blog
//--view=模板引擎的名称,有很多种
//blog为项目文件夹名称 $ express --view=ejs node-demo 使用ejs模板引擎
// 出现以下信息,安装指示 一步一步进行
create : node-demo/
create : node-demo/public/
create : node-demo/public/javascripts/
create : node-demo/public/images/
create : node-demo/public/stylesheets/
create : node-demo/public/stylesheets/style.css
create : node-demo/routes/
create : node-demo/routes/index.js
create : node-demo/routes/users.js
create : node-demo/views/
create : node-demo/views/error.jade
create : node-demo/views/index.jade
create : node-demo/views/layout.jade
create : node-demo/app.js
create : node-demo/package.json
create : node-demo/bin/
create : node-demo/bin/www change directory:
$ cd node-demo install dependencies:
$ npm install run the app:
$ DEBUG=node-demo:* npm start

运行express

$ npm start 

//浏览器输入 http://localhost:3000/
//即可看到 //Express
//Welcome to Express

项目文件分析

项目创建成功之后,生成四个文件夹和两个文件,

  1. app.js

    • 这是它的初始形式,这个模块还要继续导出给bin文件夹下的www文件使用
  2. 配置信息文件packetage.json
  3. bin是项目的启动文件,配置以什么方式启动项目,默认 npm start
    • www文件:这里拥有着http服务器的基本配置
  4. public是项目的静态文件,放置js css img等文件
  5. routes是项目的路由信息文件,控制地址路由
  6. views是视图文件,放置模板文件ejs或jade等(其实就相当于html形式文件啦~)
  7. express这样的MVC框架模式,是一个Web项目的基本构成。

进化项目——连接数据库

$ npm install mysql --save

根目录sql文件夹 里面新建sqlConfig.js,内容如下:

// 引入mysql

var mysql = require('mysql');
var pool = mysql.createPool({
host: "localhost", //这是数据库的地址
port: "2000",
user: "root", //需要用户的名字
password: "12345", //用户密码 ,如果你没有密码,直接双引号就是
database: "huang" //数据库名字
}); /**
* @param {*} sql sql语句
* @param {*} callback 回调函数
*/
function query(sql, callback) {
pool.getConnection(function (err, connection) {
connection.query(sql, function (err, rows) {
callback(err, rows);
connection.release(); //释放链接
});
});
} exports.query = query;

routes文件夹下面新建admin_user.js对应 admin_user表模块 内容如下:

var express = require('express');
var router = express.Router(); //引入数据库包
var sql = require("../sql/sqlConfig.js");
/**
* 查询列表页
*/
router.get('/', function (req, res, next) {
sql.query('select * from admin_user', function (err, rows) {
if (err) {
console.log(err)
res.render('index.ejs', { title: 'Express', datas: [] });
} else {
res.render('index.ejs', { title: 'Express', datas: rows });
}
})
}); module.exports = router;

sql文件夹 继续新建 AdminUserSQL.js 内容如下:

//admin_user表 sql语句
var AdminUserSQL = {
queryAll: 'SELECT * FROM admin_user',
}; module.exports = AdminUserSQL;

进入app.js,加入一下代码:

//引入users模块
var AdminUsersRouter = require('./routes/admin_user');
app.use('/get-admin-users', AdminUsersRouter);

启动

http://localhost:3000/get-admin-users

Express
Welcome to Express userName 姓名
admin 超级管理员

总结

node.js配合express连接mysql获取admin_user表的简单demo完成。

通讯服务器搭建第一步完成,下一步我们将配合socket.io完成消息推送。欢迎大家评论交流。

源码见github

node+express+socket.io+mysql=通讯服务器搭建(一)的更多相关文章

  1. node+express+socket.io制作一个聊天室功能

    首先是下载包: npm install express npm install socket.io 建立文件: 服务器端代码:server.js var http=require("http ...

  2. node express+socket.io实现聊天室

    参照网址:https://www.jb51.net/article/135058.htm https://www.cnblogs.com/limitcode/p/7845168.html https: ...

  3. 使用Node.js+Socket.IO搭建WebSocket实时应用

    Web领域的实时推送技术,也被称作Realtime技术.这种技术要达到的目的是让用户不需要刷新浏览器就可以获得实时更新.它有着广泛的应用场景,比如在线聊天室.在线客服系统.评论系统.WebIM等. W ...

  4. (转)使用Node.js+Socket.IO搭建WebSocket实时应用

    Web领域的实时推送技术,也被称作Realtime技术.这种技术要达到的目的是让用户不需要刷新浏览器就可以获得实时更新.它有着广泛的应用场景,比如在线聊天室.在线客服系统.评论系统.WebIM等. W ...

  5. 使用Node.js+Socket.IO搭建WebSocket实时应用【转载】

    原文:http://www.jianshu.com/p/d9b1273a93fd Web领域的实时推送技术,也被称作Realtime技术.这种技术要达到的目的是让用户不需要刷新浏览器就可以获得实时更新 ...

  6. Express+Socket.IO 实现简易聊天室

    代码地址如下:http://www.demodashi.com/demo/12477.html 闲暇之余研究了一下 Socket.io,搭建了一个简易版的聊天室,如有不对之处还望指正,先上效果图: 首 ...

  7. 转载:node.js socket.io

    本文转自:http://www.xiaocai.name/post/cf1f9_7b6507  学习node.js socket.io 使用 用node.js(socket.io)实现数据实时推送 在 ...

  8. nodejs+express+socket.io

    其实官网文档清楚了  https://socket.io/get-started/chat/ 但是因为之前写的是nodejs+express, socket.io是后加的, 还是有小坑 服务器端: 官 ...

  9. node及socket.io实现简易websocket双向通信

    技术栈: vue2.0 + node + websocket( socket.io ) 1. 安装依赖 初始化vue项目后输入下方指令安装依赖包 // 推荐cnpm安装 npm i vue-socke ...

随机推荐

  1. joomla! 3.X 开发系列教程

    http://www.mengyunzhi.com/members-resource/joomla/87-joomla-menu-study.html 学习地址 http://blog.csdn.ne ...

  2. Canny边缘检测算法原理及其VC实现详解(一)

    转自:http://blog.csdn.net/likezhaobin/article/details/6892176 图象的边缘是指图象局部区域亮度变化显著的部分,该区域的灰度剖面一般可以看作是一个 ...

  3. 个人最常用的vim操作

    本文只记录个人工作中最常用到的vim快捷键,不是很全,但是已经覆盖了绝大多数功能. 参考:<鸟哥Linux私房菜>以及https://www.cnblogs.com/momofan/p/5 ...

  4. Creating a Cron Job in K8S

    Creating a Cron Job Cron jobs require a config file. This example cron job config .spec file prints ...

  5. ubuntu系统安装mysql二进制压缩包(tar.gz)以及navicat远程连接服务器(linux系统)

    一.ubuntu安装mysql5.6二进制压缩包(tar.gz) 准备 0. 获取 mysql-5.5.15-linux2.6-i686.tar.gz 二进制安装文件 mysql 官网下载页面选择 L ...

  6. 对java中继承、接口、组合的思考

    1.在c++中有继承和多重继承,而java中只有单继承.继承的好处在于可以复用一些东西,但缺陷在于后续不好扩展.此外,可读性方面继承也不好. 2.java中多了一个接口的概念,而接口的功能和其名字表达 ...

  7. [LeetCode] 30. Substring with Concatenation of All Words ☆☆☆

    You are given a string, s, and a list of words, words, that are all of the same length. Find all sta ...

  8. ZOJ 3774 二次剩余

    LINK 题意:简单粗暴,求菲波那契数列每个数的m次的前n项和模1e9+7 思路:斐波那契通项式, 注意到有很多根号5,求二次剩余为5模1e9+7的解,显然我们可以直接找一个(383008016),然 ...

  9. 【STSRM13】绵津见

    [算法]扫描线:差分+树状数组 [题意]转化模型后:求每个矩形覆盖多少点和每个点被多少矩形覆盖.n<=10^5. [题解]经典的扫描线问题(二维偏序,二维数点). 数点问题 将所有询问离线并离散 ...

  10. 【CodeForces】901 C. Bipartite Segments

    [题目]C. Bipartite Segments [题意]给定n个点m条边的无向连通图,保证不存在偶数长度的简单环.每次询问区间[l,r]中包含多少子区间[x,y]满足只保留[x,y]之间的点和边构 ...