此文主要是為了舉例nodejs的一些相關包用法總結,沒有nodejs環境可以先到官網下載安裝。nodejs實質就是寫js文件,根據一些包快速開發。這里只是列舉其中一小部用法,詳細的還需要各位去看看官網的API,這里只是提供給大家做個了解。
目錄
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模塊可以創建服務器應用實例,也能發送http請求
const http = require('http');
//request請求 respone響應
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'); //反饋內容
res.end(); //請求結束
});
//監聽--端口--數字
server.listen(8081);
2、fs模塊
// fs模塊用于對系統文件及目錄進行讀寫操作
const fs = require('fs');
//readFile(文件名,回調函數) 讀文件
fs.readFile('./data/a.txt', function(err, data){
if(err){
console.log('讀取失敗');
}else{
console.log(data.toString());
}
});
//writeFile(文件名,內容,回調函數) 寫文件
fs.writeFile('./data/b.txt', 'asfasfd2123asdafsd', function(err){
console.log(err);
});
3、querystring模塊
//querystring從字面上的意思就是查詢字符串,一般是對http請求所帶的數據進行解析
//form.html get請求
<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獲取前臺的數據
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請求
<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 = ''; //接收數據
//data 有一段數據多次到達,當數據量大自動幫切段
var i = 0;
req.on('data', function(data){
console.log(`第${i++}次收到數據`);
str += data;
});
//data 數據全部到達(一次)
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獲取前臺的數據
console.log(req.url);
var obj = urlLib.parse(req.url, true); //為true時將使用查詢模塊分析查詢字符串,默認為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('有get請求');
});
server.post('/', function(){
console.log('有post請求');
});
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:'密碼錯誤'});
}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 編碼的數據
const express = require('express');
const bodyParser = require('body-parser');
var server = express();
server.listen(8081);
//在這里幫你包裝了req.body,form表單提交get用req.query。提交post方式用req.body
//有兩個參數 extended 拓展 limit 限制
server.use(bodyParser.urlencoded({}));
// server.use(bodyParser.urlencoded({
// extended: true, //拓展模式
// limit: 2*1024*1024 //默認100KB,限制成2MB
// }));
server.use('/', function(req, res){
console.log(req.body);
});
7、cookie-parser和cookie-session模塊
解析Cookie的工具,通過req.cookies可以取到傳過來的cookie,并把它們轉成對象。
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'], //加密數組,越多越難破解
maxAge: 2*3600*1000
}));
server.use('/aaa/a.html', function(req, res){
//res.cookie('test', 'xxlai'); //可以帶參數
// res.cookie('test', 'xxlai', {path: '/aaa', maxAge: 30*24*3600*1000}); //某個路徑下才可以訪問cookie,過期時間30天
req.secret = 'sdfasdfasdfasd'; //加密,簽名密鑰
res.cookie('test', 'xxlai', {signed: true}); //簽名不能加密,但可以防止篡改值
// console.log(req.cookies);
console.log("簽名cookies:", req.signedCookies);
console.log("無簽名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');
//可以傳參渲染模板,=代表是轉義輸出,-代表不轉義輸出
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測試頁面
body
//jade.js
const jade = require('jade');
const fs = require('fs');
//var str = jade.render('html'); //生成 <html></html>
//1、jade模板引擎以每行縮進作為層級關系
//2、屬性放在()里,逗號分隔
//3、內容空一格,直接往后堆
//4、.點代表原樣輸出 類似style.
//5、數據傳遞模板用#{name},style和css特殊,可省略 , span #{a}等價于 span=a
//6、|開頭的代表不是標簽,原樣輸出
//7、-開頭的跟|類似,代表的也不是標簽,表示這是代碼,不輸出。可做for循環使用。 可以只寫一個-代表接下來的都是代碼。不轉義,有點區別=
//8、加!代表不需要轉義 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模塊
作為中間件進行數據處理,例如對附件上傳下載。
//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();
//錯誤
//server.use(bodyParser.urlencoded({extended: false}));
server.use(objMulter.any());
server.post('/', function (req, res){
//1.獲取原始文件擴展名
//2.重命名臨時文件
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模塊可以說是一個各種模板引擎的結合體。它包括了我們之前的jade和ejs。通過配置就可以使用多種模板引擎。
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數據
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);
//用戶請求
// server.use('/', function (req, res, next){
// console.log(req.query, req.body, req.files, req.cookies, req.session);
// });
//接收用戶請求
server.use('/index', function(req, res){
res.render('1.ejs', { name: 'xxlai'});
});
//4.static數據
server.use(static('./www'));
11、mysql模塊
const express=require('express');
consot mysql = require('mysql');
var server=express();
server.listen(8080);
//連接數據庫
//createConection(哪臺服務器, 用戶名, 密碼, 庫)
var db = mysql.createConection({
host: 'localhost',
port: '3306'
user: 'test',
password: '123456',
database: 'jeecg'
});
//連接池 可以限制連接數,不用一直保持連接
//createPool(哪臺服務器, 用戶名, 密碼, 庫)
// var db = mysql.createPool({
// host: 'localhost',
// port: '3306'
// user: 'test',
// password: '123456',
// database: 'jeecg'
// });
console.log(db);
//2、查詢
//query(干什么, 回調函數)
db.query('select * from user_table;', (err, data) => {
if(err)
console.log('出錯了', err);
else
console.log('成功了', data);
});
//接收用戶請求,鏈式操作,next()走下一個步驟
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管理
如果你覺得你有比較包可以提供給其它人使用,可以上傳到這里。你只需要注冊個帳戶即可,可以發布和刪除。 注意有版本號區別。
//平常自己寫模塊化管理,需要注意引入問題,需要添加"./",對外輸出東西必須加給exports
//require 1.如果有"./" 從當前目錄找 2.如果沒有"./" 先從系統模塊,再從node_modules找
//如果對npm命令不太熟悉,可以打npm help查看相關指令
//常用命令:
//npm install 名字 安裝
//npm uninstall 名字 卸載
1.注冊、登錄用戶
npm adduser
npm login
2.檢查
npm whoami
3.建立package
npm init
4.發布
npm publish
*再次發布——加版本號,每次發布需要修改版本號以作區分
5.刪除發布
npm --force unpulish //刪除當前版本號,根據package.json里指定
npm unpublish 名字 --force //刪除整個包,慎重