此文主要是為了舉例nodejs的一些相關(guān)包用法總結(jié),沒(méi)有nodejs環(huán)境可以先到官網(wǎng)下載安裝洋幻。nodejs實(shí)質(zhì)就是寫js文件郁轻,根據(jù)一些包快速開(kāi)發(fā)。這里只是列舉其中一小部用法文留,詳細(xì)的還需要各位去看看官網(wǎng)的API好唯,這里只是提供給大家做個(gè)了解。
目錄
1燥翅、http模塊
2骑篙、fs模塊
3、querystring模塊
4森书、url模塊
5靶端、express模塊
6、body-parser模塊
7凛膏、cookie-parser和cookie-session模塊
8杨名、ejs和jade模板引擎
9、multer和path模塊
10猖毫、consolidate模塊
11台谍、mysql模塊
12、package管理
1吁断、http模塊
//http模塊可以創(chuàng)建服務(wù)器應(yīng)用實(shí)例趁蕊,也能發(fā)送http請(qǐng)求
const http = require('http');
//request請(qǐng)求 respone響應(yīng)
var server = http.createServer(function(req, res) {
// console.log(req.url);
switch (req.url) {
case '/1.html':
// statements_1
break;
default:
// statements_def
break;
}
res.write('abc'); //反饋內(nèi)容
res.end(); //請(qǐng)求結(jié)束
});
//監(jiān)聽(tīng)--端口--數(shù)字
server.listen(8081);
2、fs模塊
// fs模塊用于對(duì)系統(tǒng)文件及目錄進(jìn)行讀寫操作
const fs = require('fs');
//readFile(文件名仔役,回調(diào)函數(shù)) 讀文件
fs.readFile('./data/a.txt', function(err, data){
if(err){
console.log('讀取失敗');
}else{
console.log(data.toString());
}
});
//writeFile(文件名掷伙,內(nèi)容,回調(diào)函數(shù)) 寫文件
fs.writeFile('./data/b.txt', 'asfasfd2123asdafsd', function(err){
console.log(err);
});
3骂因、querystring模塊
//querystring從字面上的意思就是查詢字符串,一般是對(duì)http請(qǐng)求所帶的數(shù)據(jù)進(jìn)行解析
//form.html get請(qǐng)求
<body>
<form action="http://localhost:8081" method="get">
用戶:<input type="text" name="user" value=""> <br/>
密碼:<input type="password" name="pass" value=""> <br/>
<input type="submit" value="提交">
</form>
</body>
//server.js
const http = require('http');
const querystring = require('querystring');
http.createServer(function(req, res){
//req獲取前臺(tái)的數(shù)據(jù)
console.log(req.url);
var GET = {};
var url = req.url;
if(req.url.indexOf('?') != -1){
var arr = req.url.split('?');
url = arr[0];
GET = querystring.parse(arr[1]);
}
console.log(url, GET);
res.write('aaa');
res.end();
}).listen(8081);
//form.html post請(qǐng)求
<body>
<form action="http://localhost:8081" method="post">
用戶:<input type="text" name="user" value=""> <br/>
密碼:<input type="password" name="pass" value=""> <br/>
<input type="submit" value="提交">
</form>
</body>
//server.js
const http = require('http');
http.createServer(function(req, res){
var str = ''; //接收數(shù)據(jù)
//data 有一段數(shù)據(jù)多次到達(dá),當(dāng)數(shù)據(jù)量大自動(dòng)幫切段
var i = 0;
req.on('data', function(data){
console.log(`第${i++}次收到數(shù)據(jù)`);
str += data;
});
//data 數(shù)據(jù)全部到達(dá)(一次)
req.on('end', function(data){
console.log(str);
});
}).listen(8081);
4赃泡、url模塊
//用于URL解析寒波、處理等操作
const http = require('http');
const urlLib = require('url');
http.createServer(function(req, res){
//req獲取前臺(tái)的數(shù)據(jù)
console.log(req.url);
var obj = urlLib.parse(req.url, true); //為true時(shí)將使用查詢模塊分析查詢字符串,默認(rèn)為false
var url = obj.pathname;
var GET = obj.query;
console.log(url, GET);
res.write('aaa');
res.end();
}).listen(8081);
5升熊、express模塊
const express = require('express');
const expressStatic = require('express-static');
var server = express();
server.get('/', function(){
console.log('有g(shù)et請(qǐng)求');
});
server.post('/', function(){
console.log('有post請(qǐng)求');
});
server.use('/', function(){
console.log('有use');
});
server.use('/a.html', function(req, res){
res.send('abc');
res.end();
});
server.use('/b.html', function(req, res){
res.send('123');
res.end();
});
var users = {
'xx': '123456',
'cc': '789012'
}
server.listen(8081);
server.get('/login', function(req, res){
// var user = req.query;
var user = req.query['user'];
var pass = req.query['pass'];
if(users[user] == null){
res.send({ok: false, msg: '此用戶不存在'});
}else{
if(users[user] != pass){
res.send({ok: false, msg:'密碼錯(cuò)誤'});
}else{
res.send({ok: true, msg:'成功'});
}
}
})
server.use(expressStatic('./www'));
//express_router路由
const express = require('express');
var server = express();
//目錄 /user/
var routerUser = express.Router();
routerUser.get('/1.html', function(req, res){
res.send('user111');
});
routerUser.get('/2.html', function(req, res){
res.send('user222');
});
server.use('/user', routerUser);
//目錄2 /article/
var articleRouter = express.Router();
articleRouter.get('/1001.html', function(req, res){
res.send('adfasdfasdfaf');
});
server.use('/article', articleRouter);
server.listen(8081);
6俄烁、body-parser模塊
中間件,用于處理 JSON, Raw, Text 和 URL 編碼的數(shù)據(jù)
const express = require('express');
const bodyParser = require('body-parser');
var server = express();
server.listen(8081);
//在這里幫你包裝了req.body级野,form表單提交get用req.query页屠。提交post方式用req.body
//有兩個(gè)參數(shù) extended 拓展 limit 限制
server.use(bodyParser.urlencoded({}));
// server.use(bodyParser.urlencoded({
// extended: true, //拓展模式
// limit: 2*1024*1024 //默認(rèn)100KB,限制成2MB
// }));
server.use('/', function(req, res){
console.log(req.body);
});
7、cookie-parser和cookie-session模塊
解析Cookie的工具辰企,通過(guò)req.cookies可以取到傳過(guò)來(lái)的cookie风纠,并把它們轉(zhuǎn)成對(duì)象。
const express = require('express');
const cookieParser = require('cookie-parser');
const cookieSession = require('cookie-session');
var server = express();
//cookie
//server.use(cookieParser(sdfasdfasdfasd)); //簽名密鑰
server.use(cookieParser());
server.use(cookieSession({
name: 'sess',
keys: ['aaa', 'bbb', 'ccc'], //加密數(shù)組牢贸,越多越難破解
maxAge: 2*3600*1000
}));
server.use('/aaa/a.html', function(req, res){
//res.cookie('test', 'xxlai'); //可以帶參數(shù)
// res.cookie('test', 'xxlai', {path: '/aaa', maxAge: 30*24*3600*1000}); //某個(gè)路徑下才可以訪問(wèn)cookie竹观,過(guò)期時(shí)間30天
req.secret = 'sdfasdfasdfasd'; //加密,簽名密鑰
res.cookie('test', 'xxlai', {signed: true}); //簽名不能加密潜索,但可以防止篡改值
// console.log(req.cookies);
console.log("簽名cookies:", req.signedCookies);
console.log("無(wú)簽名cookies:", req.cookies);
if(req.session['count'] == null){
req.session['count'] = 1;
}else{
req.session['count']++;
}
console.log(req.session['count']);
//delete req.session['count']; //刪除
res.send('ok');
});
server.listen(8081);
8臭增、ejs和jade模板引擎
//test.ejs
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
我的名字叫:<%= name %>
<% for(var i=0; i<json.arr.length; i++) { %>
<div>用戶名: <%= json.arr[i].user %> 密碼: <% json.arr[i].pass %></div>
<% } %>
<%
var str = "<div></div>"
%>
<%- str %>
<% include ../a.txt %>
</body>
</html>
//ejs.js
const ejs = require('ejs');
//可以傳參渲染模板,=代表是轉(zhuǎn)義輸出竹习,-代表不轉(zhuǎn)義輸出
ejs.renderFile('./views/1.ejs', {name: 'xxlai'}, function(err, data){
if(err)
console.log('編輯失敗', err);
else
console.log(data);
});
//test.jade
doctype
html
head
meta(charset="utf-8")
title jade測(cè)試頁(yè)面
body
//jade.js
const jade = require('jade');
const fs = require('fs');
//var str = jade.render('html'); //生成 <html></html>
//1誊抛、jade模板引擎以每行縮進(jìn)作為層級(jí)關(guān)系
//2、屬性放在()里整陌,逗號(hào)分隔
//3拗窃、內(nèi)容空一格,直接往后堆
//4蔓榄、.點(diǎn)代表原樣輸出 類似style.
//5并炮、數(shù)據(jù)傳遞模板用#{name},style和css特殊,可省略 甥郑, span #{a}等價(jià)于 span=a
//6逃魄、|開(kāi)頭的代表不是標(biāo)簽,原樣輸出
//7澜搅、-開(kāi)頭的跟|類似伍俘,代表的也不是標(biāo)簽,表示這是代碼勉躺,不輸出癌瘾。可做for循環(huán)使用饵溅。 可以只寫一個(gè)-代表接下來(lái)的都是代碼妨退。不轉(zhuǎn)義,有點(diǎn)區(qū)別=
//8蜕企、加!代表不需要轉(zhuǎn)義 div!=content
var str = jade.renderFile('./views/1.jade', {pretty: true, name: 'xxlai', a: 12, b: 5,
json: {width: '200px', height: '200px', background: 'red'},
arr: ['aaa', 'bbb', 'ccc'],
content: '<h2>title</h2><p>asdlkfjalsadfaf</p>'
}); //pretty格式化排版
console.log(str);
fs.writeFile('./build/output.html', str, function(err){
if(err)
console.log('寫入失敗');
else
console.log('寫入成功');
})
9咬荷、multer和path模塊
作為中間件進(jìn)行數(shù)據(jù)處理,例如對(duì)附件上傳下載轻掩。
//upload.html
<body>
<!-- 注意enctype有3種值幸乒,這里是用multipart -->
<form action="http://localhost:8080/" method="post" enctype="multipart/form-data">
文件:<input type="file" name="f1" /><br>
<input type="submit" value="上傳">
</form>
</body>
//upload.js
const express=require('express');
const bodyParser=require('body-parser');
const multer=require('multer');
const fs=require('fs');
const pathLib=require('path');
var objMulter=multer({dest: './www/upload/'});
var server=express();
//錯(cuò)誤
//server.use(bodyParser.urlencoded({extended: false}));
server.use(objMulter.any());
server.post('/', function (req, res){
//1.獲取原始文件擴(kuò)展名
//2.重命名臨時(shí)文件
var newName=req.files[0].path+pathLib.parse(req.files[0].originalname).ext;
fs.rename(req.files[0].path, newName, function (err){
if(err)
res.send('上傳失敗');
else
res.send('成功');
});
});
server.listen(8080);
10、consolidate模塊
consolidate模塊可以說(shuō)是一個(gè)各種模板引擎的結(jié)合體唇牧。它包括了我們之前的jade和ejs罕扎。通過(guò)配置就可以使用多種模板引擎聚唐。
const express=require('express');
const static=require('express-static');
const cookieParser=require('cookie-parser');
const cookieSession=require('cookie-session');
const bodyParser=require('body-parser');
const multer=require('multer');
const consolidate = require('consolidate');
var server=express();
server.listen(8080);
//1.解析cookie
server.use(cookieParser('sdfasl43kjoifguokn4lkhoifo4k3'));
//2.使用session
var arr=[];
for(var i=0;i<100000;i++){
arr.push('keys_'+Math.random());
}
server.use(cookieSession({name: 'zns_sess_id', keys: arr, maxAge: 20*3600*1000}));
//3.post數(shù)據(jù)
server.use(bodyParser.urlencoded({extended: false}));
server.use(multer({dest: './www/upload'}).any());
//4、配置模板引擎
//輸出什么東西
server.set('view engine', 'html');
//模板文件放在哪兒
server.set('views', './views');
//哪種模板引擎
server.set('html', consolidate.ejs);
//用戶請(qǐng)求
// server.use('/', function (req, res, next){
// console.log(req.query, req.body, req.files, req.cookies, req.session);
// });
//接收用戶請(qǐng)求
server.use('/index', function(req, res){
res.render('1.ejs', { name: 'xxlai'});
});
//4.static數(shù)據(jù)
server.use(static('./www'));
11腔召、mysql模塊
const express=require('express');
consot mysql = require('mysql');
var server=express();
server.listen(8080);
//連接數(shù)據(jù)庫(kù)
//createConection(哪臺(tái)服務(wù)器杆查, 用戶名, 密碼宴咧, 庫(kù))
var db = mysql.createConection({
host: 'localhost',
port: '3306'
user: 'test',
password: '123456',
database: 'jeecg'
});
//連接池 可以限制連接數(shù)根灯,不用一直保持連接
//createPool(哪臺(tái)服務(wù)器, 用戶名掺栅, 密碼烙肺, 庫(kù))
// var db = mysql.createPool({
// host: 'localhost',
// port: '3306'
// user: 'test',
// password: '123456',
// database: 'jeecg'
// });
console.log(db);
//2、查詢
//query(干什么氧卧, 回調(diào)函數(shù))
db.query('select * from user_table;', (err, data) => {
if(err)
console.log('出錯(cuò)了', err);
else
console.log('成功了', data);
});
//接收用戶請(qǐng)求桃笙,鏈?zhǔn)讲僮鳎琻ext()走下一個(gè)步驟
server.get('/', (req, res, next)=>{
//查詢banner的東西
db.query("SELECT * FROM banner_table", (err, data)=>{
if(err){
res.status(500).send('database error').end();
}else{
res.banners=data;
next();
}
});
});
server.get('/', (req, res, next)=>{
//查詢文章列表
db.query('SELECT ID,title,summery FROM article_table', (err, data)=>{
if(err){
res.status(500).send('database error').end();
}else{
res.articles=data;
next();
}
});
});
server.get('/', (req, res)=>{
res.render('index.ejs', {banners: res.banners, articles: res.articles});
});
server.get('/article', (req, res)=>{
res.render('conText.ejs', {});
});
12沙绝、package管理
如果你覺(jué)得你有比較包可以提供給其它人使用搏明,可以上傳到這里。你只需要注冊(cè)個(gè)帳戶即可闪檬,可以發(fā)布和刪除星著。 注意有版本號(hào)區(qū)別。
//平常自己寫模塊化管理粗悯,需要注意引入問(wèn)題虚循,需要添加"./",對(duì)外輸出東西必須加給exports
//require 1.如果有"./" 從當(dāng)前目錄找 2.如果沒(méi)有"./" 先從系統(tǒng)模塊样傍,再?gòu)膎ode_modules找
//如果對(duì)npm命令不太熟悉横缔,可以打npm help查看相關(guān)指令
//常用命令:
//npm install 名字 安裝
//npm uninstall 名字 卸載
1.注冊(cè)、登錄用戶
npm adduser
npm login
2.檢查
npm whoami
3.建立package
npm init
4.發(fā)布
npm publish
*再次發(fā)布——加版本號(hào)衫哥,每次發(fā)布需要修改版本號(hào)以作區(qū)分
5.刪除發(fā)布
npm --force unpulish //刪除當(dāng)前版本號(hào)茎刚,根據(jù)package.json里指定
npm unpublish 名字 --force //刪除整個(gè)包,慎重