• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Benjamin

            靜以修身,儉以養(yǎng)德,非澹薄無以明志,非寧靜無以致遠。
            隨筆 - 398, 文章 - 0, 評論 - 196, 引用 - 0
            數(shù)據(jù)加載中……

            nodejs的express模塊(web框架)使用

            安裝cnpm:
            npm config set registry https://registry.npm.taobao.org(永久使用)
            npm --registry https://registry.npm.taobao.org install express(臨時使用)
            1、安裝 Express
            cnpm install express --save 安裝Express并將其保存到依賴列表中
            body-parser - node.js 中間件,用于處理 JSON, Raw, Text 和 URL 編碼的數(shù)據(jù)。
            cookie-parser - 這就是一個解析Cookie的工具。通過req.cookies可以取到傳過來的cookie,并把它們轉(zhuǎn)成對象。
            multer - node.js 中間件,用于處理 enctype="multipart/form-data"(設(shè)置表單的MIME編碼)的表單數(shù)據(jù)。
            cnpm install body-parser --save
            cnpm install cookie-parser --save
            cnpm install multer --save
            cnpm list express 安裝完后,我們可以查看下 express 使用的版本號:
            2、簡單使用
            //express_demo.js 文件
            var express = require('express');
            var app = express();
             
            app.get('/', function (req, res) {
               res.send('Hello World');
            })
             //var server = app.listen(3456, "127.0.0.1", function () {})指定ip,一般用的是127.0.0.1
            var server = app.listen(8081, function () {
             
              var host = server.address().address
              var port = server.address().port
             
              console.log("應(yīng)用實例,訪問地址為 http://%s:%s", host, port)
             
            })
            在瀏覽器中訪問 http://127.0.0.1:8081,會顯示hello world
            Request 對象 - request 對象表示 HTTP 請求,包含了請求查詢字符串,參數(shù),內(nèi)容,HTTP 頭部等屬性
            .獲取客戶ip地址:request.ip
            .獲取上傳的文件:request.files
            Response 對象 - response 對象表示 HTTP 響應(yīng),即在接收到請求時向客戶端發(fā)送的 HTTP 響應(yīng)數(shù)據(jù)
            重定向redirect
                response.redirect("/hello/anime");//重定向到/hello/anime
            .發(fā)送文件sendFile
               response.sendFile("/path/to/anime.mp4");
            .渲染網(wǎng)頁模板render,即把變換的內(nèi)容加載到網(wǎng)頁.
                response.render("index", { message: "Hello World" });//將message變量傳入index模板,值為"Hello World"渲染成HTML網(wǎng)頁
                
            2、路由決定了由誰(指定腳本)去響應(yīng)客戶端請求。
            //  /del_user 頁面響應(yīng)
            app.get('/del_user', function (req, res) {
               console.log("/del_user 響應(yīng) DELETE 請求");
               res.send('刪除頁面');
            })
            // 對頁面 abcd, abxcd, ab123cd, 等響應(yīng) GET 請求
            app.get('/ab*cd', function(req, res) {   
               console.log("/ab*cd GET 請求");
               res.send('正則匹配');
            })
            3、靜態(tài)文件express.static 中間件來設(shè)置靜態(tài)文件路徑。例如,如果你將圖片, CSS, JavaScript 文件放在 public 目錄下,可以這么寫:
            app.use('/public', express.static('public'));
            4、GET 、post方法:
            index.html內(nèi)容
            <html>
            <body>
            <form action="http://127.0.0.1:8081/process_get" method="GET">
            First Name: <input type="text" name="first_name">  <br>
             
            Last Name: <input type="text" name="last_name">
            <input type="submit" value="Submit">
            </form>
            </body>
            </html>
            server.js
            ar express = require('express');
            var app = express();
             
            app.use('/public', express.static('public'));
             
            app.get('/index.htm', function (req, res) {
               res.sendFile( __dirname + "/" + "index.htm" );
            })
             
            app.get('/process_get', function (req, res) {
             
               // 輸出 JSON 格式
               var response = {
                   "first_name":req.query.first_name,
                   "last_name":req.query.last_name
               };
               console.log(response);
               res.end(JSON.stringify(response));
            })
             
            var server = app.listen(8081, function () {
             
              var host = server.address().address
              var port = server.address().port
             
              console.log("應(yīng)用實例,訪問地址為 http://%s:%s", host, port)
             
            })
            5、上傳文件
            var express = require('express');
            var app = express();
            var fs = require("fs");
             
            var bodyParser = require('body-parser');
            var multer  = require('multer');
             
            app.use('/public', express.static('public'));
            app.use(bodyParser.urlencoded({ extended: false }));
            app.use(multer({ dest: '/tmp/'}).array('image'));
             
            app.get('/index.htm', function (req, res) {
               res.sendFile( __dirname + "/" + "index.htm" );
            })
            app.post('/file_upload', function (req, res) {
             
               console.log(req.files[0]);  // 上傳的文件信息
             
               var des_file = __dirname + "/" + req.files[0].originalname;
               fs.readFile( req.files[0].path, function (err, data) {
                    fs.writeFile(des_file, data, function (err) {
                     if( err ){
                          console.log( err );
                     }else{
                           response = {
                               message:'File uploaded successfully', 
                               filename:req.files[0].originalname
                          };
                      }
                      console.log( response );
                      //中文編碼處理
                      res.writeHead(200,{'Content-Type':'text/html;charset=utf-8'});
                      res.end( JSON.stringify( response ) );
                   });
               });
            })
            6、Cookie 管理
            var cookieParser = require('cookie-parser')
            var util = require('util');
             
            var app = express()
            app.use(cookieParser())
             
            app.get('/', function(req, res) {
                console.log("Cookies: " + util.inspect(req.cookies));
            })
            7、添加 favicon.ico 
            在  public/images 添加文件 favicon.ico 
            打開 myapp 下的 app.js 在其中添加
            var favicon = require('serve-favicon');
            app.use(favicon(__dirname+'/public/images/favicon.ico'));
            然后通過命令行安裝 serve-favicon 
            重啟應(yīng)用即可
            8、中間件:處理HTTP請求的函數(shù).
            參數(shù)為:
            .四個的時候---第一個為錯誤處理,第二個為客戶請求request,第三個為服務(wù)器響應(yīng)respond,第四個為next中間件. 如function(error, request, response, next){}
            .三個的時候---第一個客戶請求request,第二個為服務(wù)器響應(yīng)respond,第三個為next中間件. 如function(request, response, next){}
            .兩個的時候---第一個客戶請求request,第二個為服務(wù)器響應(yīng)respondfunction. 如function(request, response){}
            中間件use
            app.use(express.bodyParser());//使用body參數(shù)
            app.use(express.methodOverride());//使用函數(shù)覆蓋
            app.use(app.router);//使用路由
            app.use(function(err, req, res, next){
             console.error(err.stack);
             res.send(500, 'Something broke!');
            });//錯誤內(nèi)容顯示
            9、動態(tài)網(wǎng)頁模板views
            res.render('index',{title:"最近文章"});
            npm install -g express-generator
            npm update -g express
            express APP_NAME  //創(chuàng)建項目
            express APP_NAME -e  //以ejs作為模板引擎創(chuàng)建項目
            將ejs文件(EJS 是一套簡單的模板語言,用普通的 JavaScript 代碼生成 HTML 頁面)改為html
            var ejs = require('ejs');
            app.engine('.html', ejs.__express);
            app.set('view engine', 'html');  //app.set('view engine', 'ejs');
            npm install;//在項目文件夾
            每次修改代碼后,需要手動重啟服務(wù),可以使用nodemon進行自動重啟
            npm install -g nodemon
            將package.json文件中的代碼修改為:
            "start": "nodemon ./bin/www

            posted on 2019-06-05 09:55 Benjamin 閱讀(564) 評論(0)  編輯 收藏 引用 所屬分類: 雜談

            精品一久久香蕉国产线看播放| 久久无码AV中文出轨人妻| 亚洲精品无码久久千人斩| 麻豆精品久久久久久久99蜜桃| 久久精品免费一区二区| 久久精品国产亚洲麻豆| 欧美精品国产综合久久| 青青草国产精品久久| 欧美精品丝袜久久久中文字幕 | 69久久精品无码一区二区| 狠狠人妻久久久久久综合| 中文字幕无码精品亚洲资源网久久| 精品久久久久香蕉网| 亚洲国产成人久久笫一页| 精品久久久久久无码中文字幕一区| 91久久精品国产成人久久| 97精品依人久久久大香线蕉97| 久久99精品久久久久久齐齐| 欧美伊香蕉久久综合类网站| 久久亚洲欧美国产精品| 久久WWW免费人成一看片| 亚洲成av人片不卡无码久久| 品成人欧美大片久久国产欧美... 品成人欧美大片久久国产欧美 | 亚洲综合精品香蕉久久网| 久久精品成人欧美大片| 97久久国产亚洲精品超碰热| 久久久一本精品99久久精品88| 久久久久亚洲AV无码专区网站 | 久久久精品久久久久久 | 久久A级毛片免费观看| 久久亚洲国产精品成人AV秋霞| 久久久久久国产a免费观看不卡| 日本免费久久久久久久网站| 久久本道伊人久久| 日本久久久精品中文字幕| 国产国产成人久久精品| 99久久精品免费看国产一区二区三区 | 伊人久久综合热线大杳蕉下载| 久久亚洲国产中v天仙www | 亚洲国产天堂久久综合网站| 亚洲国产精品人久久|