nodejs相關(guān)包使用小結(jié)

此文主要是為了舉例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è)包,慎重
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末撤逢,一起剝皮案震驚了整個(gè)濱河市膛锭,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌蚊荣,老刑警劉巖初狰,帶你破解...
    沈念sama閱讀 211,194評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異妇押,居然都是意外死亡跷究,警方通過(guò)查閱死者的電腦和手機(jī)姓迅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門敲霍,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)俊马,“玉大人,你說(shuō)我怎么就攤上這事肩杈〔裎遥” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,780評(píng)論 0 346
  • 文/不壞的土叔 我叫張陵扩然,是天一觀的道長(zhǎng)艘儒。 經(jīng)常有香客問(wèn)我,道長(zhǎng)夫偶,這世上最難降的妖魔是什么界睁? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,388評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮兵拢,結(jié)果婚禮上翻斟,老公的妹妹穿的比我還像新娘。我一直安慰自己说铃,他們只是感情好访惜,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著腻扇,像睡著了一般债热。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上幼苛,一...
    開(kāi)封第一講書(shū)人閱讀 49,764評(píng)論 1 290
  • 那天窒篱,我揣著相機(jī)與錄音,去河邊找鬼蚓峦。 笑死舌剂,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的暑椰。 我是一名探鬼主播霍转,決...
    沈念sama閱讀 38,907評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼一汽!你這毒婦竟也來(lái)了避消?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,679評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤召夹,失蹤者是張志新(化名)和其女友劉穎岩喷,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體监憎,經(jīng)...
    沈念sama閱讀 44,122評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡纱意,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了鲸阔。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片偷霉。...
    茶點(diǎn)故事閱讀 38,605評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡迄委,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出类少,到底是詐尸還是另有隱情叙身,我是刑警寧澤,帶...
    沈念sama閱讀 34,270評(píng)論 4 329
  • 正文 年R本政府宣布硫狞,位于F島的核電站信轿,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏残吩。R本人自食惡果不足惜财忽,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望泣侮。 院中可真熱鬧定罢,春花似錦、人聲如沸旁瘫。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,734評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)酬凳。三九已至惠况,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間宁仔,已是汗流浹背稠屠。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,961評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留翎苫,地道東北人权埠。 一個(gè)月前我還...
    沈念sama閱讀 46,297評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像煎谍,于是被迫代替她去往敵國(guó)和親攘蔽。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容