青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Benjamin

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

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 編碼的數據。
cookie-parser - 這就是一個解析Cookie的工具。通過req.cookies可以取到傳過來的cookie,并把它們轉成對象。
multer - node.js 中間件,用于處理 enctype="multipart/form-data"(設置表單的MIME編碼)的表單數據。
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("應用實例,訪問地址為 http://%s:%s", host, port)
 
})
在瀏覽器中訪問 http://127.0.0.1:8081,會顯示hello world
Request 對象 - request 對象表示 HTTP 請求,包含了請求查詢字符串,參數,內容,HTTP 頭部等屬性
.獲取客戶ip地址:request.ip
.獲取上傳的文件:request.files
Response 對象 - response 對象表示 HTTP 響應,即在接收到請求時向客戶端發送的 HTTP 響應數據
重定向redirect
    response.redirect("/hello/anime");//重定向到/hello/anime
.發送文件sendFile
   response.sendFile("/path/to/anime.mp4");
.渲染網頁模板render,即把變換的內容加載到網頁.
    response.render("index", { message: "Hello World" });//將message變量傳入index模板,值為"Hello World"渲染成HTML網頁
    
2、路由決定了由誰(指定腳本)去響應客戶端請求。
//  /del_user 頁面響應
app.get('/del_user', function (req, res) {
   console.log("/del_user 響應 DELETE 請求");
   res.send('刪除頁面');
})
// 對頁面 abcd, abxcd, ab123cd, 等響應 GET 請求
app.get('/ab*cd', function(req, res) {   
   console.log("/ab*cd GET 請求");
   res.send('正則匹配');
})
3、靜態文件express.static 中間件來設置靜態文件路徑。例如,如果你將圖片, CSS, JavaScript 文件放在 public 目錄下,可以這么寫:
app.use('/public', express.static('public'));
4、GET 、post方法:
index.html內容
<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("應用實例,訪問地址為 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 
重啟應用即可
8、中間件:處理HTTP請求的函數.
參數為:
.四個的時候---第一個為錯誤處理,第二個為客戶請求request,第三個為服務器響應respond,第四個為next中間件. 如function(error, request, response, next){}
.三個的時候---第一個客戶請求request,第二個為服務器響應respond,第三個為next中間件. 如function(request, response, next){}
.兩個的時候---第一個客戶請求request,第二個為服務器響應respondfunction. 如function(request, response){}
中間件use
app.use(express.bodyParser());//使用body參數
app.use(express.methodOverride());//使用函數覆蓋
app.use(app.router);//使用路由
app.use(function(err, req, res, next){
 console.error(err.stack);
 res.send(500, 'Something broke!');
});//錯誤內容顯示
9、動態網頁模板views
res.render('index',{title:"最近文章"});
npm install -g express-generator
npm update -g express
express APP_NAME  //創建項目
express APP_NAME -e  //以ejs作為模板引擎創建項目
將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;//在項目文件夾
每次修改代碼后,需要手動重啟服務,可以使用nodemon進行自動重啟
npm install -g nodemon
將package.json文件中的代碼修改為:
"start": "nodemon ./bin/www

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

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产视频久久久久| 久久成年人视频| 亚洲欧美日韩电影| 正在播放亚洲一区| 亚洲欧美日本国产有色| 亚洲欧美另类久久久精品2019| 亚洲午夜精品在线| 另类春色校园亚洲| 欧美精品高清视频| 国产精品另类一区| 韩国三级在线一区| 亚洲精品一区二区网址 | 国产亚洲成精品久久| 国产区二精品视| 亚洲电影第三页| 亚洲视频在线一区| 久久色在线播放| 亚洲国产视频a| 亚洲深夜影院| 久久久久一区二区三区四区| 欧美精品日韩www.p站| 国产精品午夜久久| 亚洲精品国产精品国自产在线 | 国产精品男人爽免费视频1 | 香蕉久久夜色精品国产| 欧美福利视频网站| 亚洲欧美国产日韩中文字幕| 免费观看日韩av| 国产伦精品一区二区| 亚洲黄色成人久久久| 欧美在线看片a免费观看| 亚洲国产裸拍裸体视频在线观看乱了中文| 一区二区国产精品| 女仆av观看一区| 国产亚洲综合性久久久影院| 日韩亚洲欧美成人| 蜜桃久久av| 午夜视频一区在线观看| 欧美另类亚洲| 亚洲国产综合在线看不卡| 久久精品道一区二区三区| 亚洲美女精品久久| 欧美成年人网站| 亚洲大胆女人| 久久久不卡网国产精品一区| 一区二区三区国产精华| 欧美日韩精品欧美日韩精品一 | 性18欧美另类| 欧美视频第二页| 亚洲精品小视频| 亚洲国产精品一区二区第四页av| 午夜精品久久久久影视| 国产精品免费在线| 欧美一区二区大片| 亚洲视频香蕉人妖| 国产精品v亚洲精品v日韩精品| 亚洲另类一区二区| 欧美激情在线有限公司| 美国三级日本三级久久99| 久久天堂av综合合色| 国产精品羞羞答答| 欧美在线播放视频| 欧美在线国产精品| 国内自拍视频一区二区三区| 久久精品99国产精品酒店日本| 欧美亚洲系列| 激情欧美一区二区三区| 欧美成年视频| 欧美精品v日韩精品v国产精品 | 久久免费视频在线观看| 午夜欧美大片免费观看| 国产一区二区三区久久久| 久久国产日韩欧美| 久久久精品999| 亚洲国产成人精品久久| 亚洲人体偷拍| 国产美女精品| 欧美成人资源| 欧美日韩日日骚| 久久国产色av| 欧美刺激性大交免费视频| 亚洲香蕉伊综合在人在线视看| 中文在线资源观看网站视频免费不卡| 国产精品剧情在线亚洲| 久久琪琪电影院| 欧美福利电影在线观看| 午夜国产精品视频免费体验区| 久久se精品一区精品二区| 亚洲品质自拍| 亚洲女人天堂成人av在线| 亚洲大片一区二区三区| 在线亚洲伦理| 亚洲国产乱码最新视频| 一区二区电影免费观看| 一区精品在线播放| 一本久久a久久免费精品不卡 | 亚洲深夜福利| 欧美一区二区视频在线| 99re66热这里只有精品4| 午夜精品久久久久久久久久久久| 亚洲国产日韩欧美在线图片| 亚洲午夜免费视频| 伊人婷婷欧美激情| 亚洲天堂av电影| 亚洲免费播放| 久久嫩草精品久久久精品一| 亚洲综合视频1区| 女人天堂亚洲aⅴ在线观看| 欧美一区二视频在线免费观看| 欧美+日本+国产+在线a∨观看| 久久精品国产99| 欧美久久久久久| 免费视频最近日韩| 国产欧美日韩另类一区 | 午夜亚洲性色福利视频| 免费亚洲一区| 久久久久久久欧美精品| 国产精品久久久999| 亚洲国产精品电影在线观看| 久久久久国产精品一区二区| 亚洲视频狠狠| 欧美电影资源| 欧美大尺度在线观看| 国产自产精品| 欧美影院在线| 欧美在线free| 国产精品永久免费观看| 国产精品一区二区久久国产| 国产乱理伦片在线观看夜一区| 亚洲电影观看| 羞羞漫画18久久大片| 亚洲欧美成人综合| 欧美全黄视频| 亚洲国产精品高清久久久| 国内精品久久久久久久果冻传媒| 亚洲一区二区三区在线播放| 一区二区国产在线观看| 欧美大尺度在线观看| 亚洲韩国青草视频| 亚洲乱码久久| 欧美精品一级| 亚洲三级观看| 一区二区三区欧美视频| 欧美日韩美女在线观看| 99国内精品久久| 亚洲一本大道在线| 欧美三区不卡| 亚洲天堂av图片| 久久国产视频网| 国产有码一区二区| 久久九九有精品国产23| 久久婷婷综合激情| 影音先锋亚洲电影| 欧美激情片在线观看| 亚洲欧洲一区二区三区| 亚洲国产天堂久久综合网| 卡通动漫国产精品| 亚洲国产精品小视频| 国产亚洲成av人片在线观看桃| 欧美一区91| 女仆av观看一区| 亚洲激情专区| 欧美四级在线观看| 久久aⅴ国产欧美74aaa| 亚洲精品欧美一区二区三区| 亚洲一区二区三区中文字幕在线| 国产精品久久久一区麻豆最新章节| 亚洲女爱视频在线| 欧美高潮视频| 欧美一级网站| 在线看视频不卡| 欧美日韩午夜激情| 欧美伊人久久久久久午夜久久久久 | 久久嫩草精品久久久精品| 牛牛影视久久网| 在线一区二区三区四区五区| 国产乱码精品一区二区三区五月婷| 久久精品国产免费| 亚洲精品国精品久久99热| 欧美一级久久| 亚洲精品欧洲精品| 国产综合色精品一区二区三区| 美女主播精品视频一二三四| 亚洲视频二区| 欧美顶级少妇做爰| 久久激情婷婷| 亚洲美女黄色| 免费成人黄色片| 亚洲专区在线视频| 亚洲高清在线精品| 国产亚洲一区二区三区在线播放| 免费日韩av片| 午夜精品一区二区三区电影天堂 | **性色生活片久久毛片| 欧美吻胸吃奶大尺度电影| 久久免费午夜影院| 亚洲欧美日韩国产一区二区| 欧美激情精品久久久久久| 久久精品在线视频| 欧美一级专区免费大片|