nodejs相關包使用小結

此文主要是為了舉例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  //刪除整個包,慎重
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,836評論 6 540
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,275評論 3 428
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,904評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,633評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,368評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,736評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,740評論 3 446
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,919評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,481評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,235評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,427評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,968評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,656評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,055評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,348評論 1 294
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,160評論 3 398
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,380評論 2 379

推薦閱讀更多精彩內容