Node.js学习笔记
接上篇https://mp.csdn.net/mdeditor/86604509
连接池
-使用连接池管理所有的连接,这样可以方便共享单个连接。
//mysql1.js
//1.加载mysql模块
var mysql = require('mysql');
//2.创建连接池
var pool = mysql.createPool({
database:'web1701',
user:'root',
password:'root'
});
//3.从连接池中获取链接对象
pool.getConnection(function(err,connection){
if(err){
throw err;
} else {
var sql = "select * from course";
connection.query(sql,function(err,results){
if(err){
throw err;
} else {
console.log(results);
}
//释放链接对象到链接池中
connection.release();
//当连接不需要的时候销毁连接
connection.destroy();
//关闭连接池中所有连接
pool.end();
});
}
});
连接池参数
- createConnection的所有参数
- connectionLimit—于指定连接池中最大的连接数,默认为10
- queryLimit—用于指定允许挂起的最大连接数,如果挂起连接数超过该数值,将抛出异常。默认为0
- waitForConnections—指定当连接池中已经没有可用连接,且当前在用的连接数已等于连接池的最大连接数时所执行的处理。如果值为true,则挂起数据库连接请求,直到一个当前在用的数据库连接释放数据库连接。如果为false,抛出异常,默认为true
express模块
-
Express是一个可以在Node.js中使用的MVC框架 ,该框架现在已经得到了广泛 的利用,可以使用该框架中的各种特性为方便快捷的开发出一个完整的Web应用程序。
-
使用
1.安装$npm install express
2.加载
var express = require('express');
3.配置路由
var app = express(); app.get('/', function (req, res,next) { res.send('Hello World!')); //路由
4.设置监听
app.listen(3000, function () {console.log("端口号为3000的服务器已经开启")});
-
路由
在Express框架中使用路由来根据客户端请求所提交的不同URL地址返回不同的服务器端响应结果。
单个路由- - -直接定义在服务器对象上var app=express(); app.get(url,callback(req,resp){});//接收get请求 app.post(url,callback(req,resp){});//接收post请求 app.delete(url,callback(req,resp){});//接收delete请求 app.put(url,callback(req,resp){});//接收put请求 app.all(url,callback(req,resp){});//接收所有类型的请求
其中回调函数中的参数req是用来获取请求信息的对象,resp是用来回应请求信 息的对 象,next用于调用下一个路由
路由中间件
在路由中间件对象上定义子路由var app=express(); var userRoute = express.Router ();//创建路由中间件对象 userRoute.get(callback(){});//定义中间件 userRoute.post(callback(){}); userRoute.delete(callback(){}); userRoute.put(callback(){}); app.use("/user",userRoute);使用中间件
路由中指定参数
app.get("/findBook/:id/:name",callback);
如果用户的请求是http://localhost:8888/findBook/1001/terry’即可以完成匹配,通过req.params获取参数组成的对象。
-
参数获取
get请求中的参数获取app.get("/login",function(req,resp){ var obj = url.parse(req.url); var params=querystring.parse(obj.query); resp.write(JSON.stringify(req.query)); resp.end(); });
post请求中的参数获取
app.post("/login",function(req,resp){ var buff = new Buffer(0); req.on("data",function(data){ buff += data; }); req.on("end",function(){ var params = querystring.parse(buff.toString()); resp.send(JSON.stringify(params)); }); });
-
回应请求
通过回调函数中的response对象回应请求
res.send([body]) ----- 发送http请求,body可以为流,字符串,对象,或者数组
res.json([body]) ----- 与send方法参数相同,可以将其他类型参数转换为json
res.end([data] [, encoding]) ----- 结束响应进程
res.redirect(path) ----- 重定向 -
静态文件托管
通过Express内置的express.static可以 方便 地托管静态文件,例如图片、CSS、JavaScript 文件 等。将 静态资源文件所在的目录作为 参数传 递给express.static中间件就可以提供静态资源文件的访问了。例如,假设在public 目录放置了 图片 、CSS和JavaScript文件, 你就可以app.use(express.static(‘public’));
npm介绍
Npm是的Js开发者能够更方便的分 享和复用以 及更 新代码,被复用的代码被称为包或者模块,一个模块中包含了一 到多个js文件。在模块中一般还会包含一个package.json的文件,该文件中包含了该模块的配置信息。一个完整的项目, 需要依赖很多个模块。
-
创建一个模块
创建模块从创建package.json文件开始,package.json是模块的配置文件。
1.可以使用npm init
命令来初始化package.json文件$ npm init
name 模块名称 version 模块版本 description 描述 main 指定模块入口文件 Dependencies 依赖关系 engines 指定node版本 devDependencies 环境依赖或测试依赖 optionalDependencies 可选择依赖 script 定义当前模块脚本,使用npm run来运行所定义的脚本 2.使用-y参数创建 默认package.json文件
$ npm init-y
-
安装npm
npm会随着node一起被安装到本地。可以使用以下命令来更新npm
$npm install npm@latest -g
1.安装淘宝镜像
由于默认npm的仓库在国外,下载起来很慢,可以使用淘宝镜像来加快下载速度。
$ npm install -g cnpm --registry=https://registry.npm.taobao.org
Registry注册中心
官方:https://registry.npmjs.org
淘宝 :https://registry.npm.taobao.org
私有:http://localIP:port
通过npm config list
查看npm的下载路径
2.修改npm权限
执行npm的时候有时会遇到权限不足的情况,可以通过以下方式进行修正。
$npm config get prefix
$sudo chown -R $(whoami) $(npm config get prefix)/{lib/node_modules,bin,share}
-
安装模块
$npm install安装所有项目依赖的模块,依赖的模块定义在package.json中
— 安装模块时,默认会将所安装的模块写入到package.json中的dependencies属性,通过添加一些参数改变这个特性。
-D, --save-dev: 安装包将出现在devDependencies中。.
-O, --save-optional: 包将出现在optionalDependencies中.
–no-save: 防止保存到依赖项
-E, --save-exact: 保存的依赖项将配置为精确的版本,而不是使用npm的默认semver range操作符。 -
模块更新
全局更新依赖的模块
$npm update <module_name>
-
模块删除
从node_modules中删除不需要的模块
$npm uninstall -g <package_name>
不仅删除node_modules中的依赖 ,还需要删除package.json中的信息,可以使用—save参数
$npm uninstall –save -g <package_name>
-
搭建本地npm仓库(sinopia)
1.安装$npm install -g sinopia
2.配置$npm set registry http://localhost:4873/
3.添加用户$npm adduser --registry http://localhost:4873/
4.发布模块$npmpublish<module_name>
5.启动$sinopia
访问http://localhost:4873/就可以了