欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

如何搭建nodejshttp服務器-創(chuàng)新互聯(lián)

這篇文章主要介紹如何搭建nodejs http服務器,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

創(chuàng)新互聯(lián)是專業(yè)的萬榮網(wǎng)站建設公司,萬榮接單;提供成都網(wǎng)站建設、成都做網(wǎng)站,網(wǎng)頁設計,網(wǎng)站設計,建網(wǎng)站,PHP網(wǎng)站建設等專業(yè)做網(wǎng)站服務;采用PHP框架,可快速的進行萬榮網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!

搭建簡單的nodejs服務器

通過一些簡單配置我們就可以搭建一臺基于nodejs的http服務器

通過switch配置url路由的方法

// 這是一個簡單的Node HTTP服務器,能處理當前目錄的文件
// 并能實現(xiàn)兩種特殊的URL用于測試
// 用HTTP://localhost:8000或http://127.0.0.1:8000連接這個服務器

// 首先加載所有需要用到的模塊
var http = require('http');    // 加載http服務api模塊
var fs = require('fs');      // 加載fs文件服務api模塊
var server = new http.Server();  // 創(chuàng)建新的HTTP服務器
var urlapi = require('url');    // 創(chuàng)建url路由api模塊
server.listen(8000);       // 監(jiān)聽端口8000

// 使用on方法注冊事件處理,該事件一直被監(jiān)聽,任何的請求都會進入回調(diào)函數(shù),執(zhí)行相應的操作
server.on('request', function(request, response) { // 當有request請求的時候觸發(fā)處理函數(shù)  
  // 解析請求的URL
  var url = urlapi.parse(request.url);

  //監(jiān)聽請求的網(wǎng)站,以當前腳本目錄為根目錄的url地址
  console.log(url.pathname);

  // 特殊URL會讓服務器在發(fā)送響應前先等待
  switch(url.pathname) {  //判斷請求的路徑信息
  case ''||'/' : // 處理請求的網(wǎng)站根目錄,指定加載對應的文件夾,一般以根目錄的index.html為默認,nodejs是高效流處理的方案,也可以通過配置文件來配置
    fs.readFile("./page/index.html", function(err, content){ //打開請求的文件
      if(err) { //輸出錯誤信息,也可以自定義錯誤信息
        response.writeHead(404, { 'Content-Type':'text/plain; charset="UTF-8"' });
        response.write(err.message);
        response.end();
      } else { //請求成功返回數(shù)據(jù)
        response.writeHead(200, { 'Content-Type' : 'text/html; charset=UTF-8' }); //告訴相應頭文件,返回數(shù)據(jù)的類型
        response.write(content); //返回的內(nèi)容,有時候還會加上buter數(shù)據(jù)類型
        response.end(); //結束響應,不寫的話,會一直處于響應狀態(tài),頁面不會顯示內(nèi)容
      }
    });
    break;
  case '/test/delay':// 此處用于模擬緩慢的網(wǎng)絡連接
    // 使用查詢字符串來獲取延遲時長,或者2000毫秒
    var delay = parseInt(url.query) || 2000;
    // 設置響應狀態(tài)和頭
    response.writeHead(200, {'Content-type':'text/plain; charset=UTF-8'});
    // 立即開始編寫響應主體
    response.write('Sleeping for' + delay + ' milliseconds...');
    // 在之后調(diào)用的另一個函數(shù)中完成響應
    setTimeout(function(){
      response.write('done.');
      response.end();
    }, delay);
    break;

  case '/test/mirror':// 如果請求是test/mirror,則原文返回它
    // 響應狀態(tài)和頭
    response.writeHead(200, {'Content-type':'text/plain; charset=UTF-8'});
    // 用請求的內(nèi)容開始編寫響應主體
    response.write(request.mothod + ' ' + request.url + ' HTTP/' + request.httpVersion + '\r\n');
    // 所有的請求頭
    for (var h in request.headers) {
      response.write(h + ':' + request.headers[h] + '\r\n');
    }
    response.write('\r\n');// 使用額外的空白行來結束頭
    // 在這些事件處理程序函數(shù)中完成響應
    // 當請求主體的數(shù)據(jù)塊完成時,把其寫入響應中
    request.on('data', function(chunk) { response.write(chunk); });
    // 當請求結束時,響應也完成
    request.on('end', function(chunk){ response.end(); });
    break;

  case '/json' : // 模擬JSON數(shù)據(jù)返回
    // 響應狀態(tài)和頭
    response.writeHead(200, {'Content-type':'application/json; charset=UTF-8'});
    response.write(JSON.stringify({test:'success'}));
    response.end();
    break;

  default:// 處理來自本地目錄的文件,主要是一些靜態(tài)資源文件,搭建靜態(tài)服務器還有其他的方法
    var filename = url.pathname.substring(1);  // 去掉前導'/'
    var type = getType(filename.substring(filename.lastIndexOf('.')+1));
    console.log(filename); //取得文件類型 css  js ....
    // 異步讀取文件,并將內(nèi)容作為單獨的數(shù)據(jù)模塊傳給回調(diào)函數(shù)
    // 對于確實很大的文件,使用流API fs.createReadStream()更好
    fs.readFile(filename, function(err, content){
      if(err) {
        response.writeHead(404, { 'Content-Type':'text/plain; charset="UTF-8"' });
        response.write(err.message);
        response.end();
      } else {
        response.writeHead(200, { 'Content-Type' : type });
        response.write(content);
        response.end();
      }
    });
    break;
  }   
});

//這里定義了一個用來判斷文件類型的函數(shù)
function getType(endTag){
  var type=null;
  switch(endTag){
  case 'html' :
     type = 'text/html; charset=UTF-8';
    break;
  case 'htm' :
    type = 'text/html; charset=UTF-8';
    break;
  case 'js' : 
    type = 'application/javascript; charset="UTF-8"';
    break;
  case 'css' :
    type = 'text/css; charset="UTF-8"';
    break;
  case 'txt' :
    type = 'text/plain; charset="UTF-8"';
    break;
  case 'manifest' :
    type = 'text/cache-manifest; charset="UTF-8"';
    break;
  default :
    type = 'application/octet-stream';
    break;
  }
  return type;
}

以上是“如何搭建nodejs http服務器”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關知識,歡迎關注創(chuàng)新互聯(lián)網(wǎng)站建設公司行業(yè)資訊頻道!

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)建站aaarwkj.com,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

分享文章:如何搭建nodejshttp服務器-創(chuàng)新互聯(lián)
標題路徑:http://aaarwkj.com/article32/ccossc.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供服務器托管、外貿(mào)網(wǎng)站建設域名注冊、網(wǎng)站改版搜索引擎優(yōu)化、網(wǎng)站導航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站建設網(wǎng)站維護公司
中文字幕人妻熟女在线| av在线免费观看美日韩| av在线亚洲网站区一| 国产精品大白屁股视频| 欧美一区二区三区人妻激情| 日日狠狠久久偷偷综合色| 丰满人妻熟妇乱精品视频| 国产精品国产三级丝袜| 成人欧美一区二区三区av| 熟妇人妻中文字幕在线| 年轻的母亲韩国三级| 丰满高潮少妇在线观看| 亚洲精品香蕉久久情趣| 韩国午夜理伦三级好看| 欧美亚洲另类不卡在线| 亚洲综合偷拍日韩av| 伦理在线视频免费观看视频| 亚洲热妇热女久久精品| 亚洲成av人天堂影院| 午夜精品人妻一区二区| 最新亚洲av熟女播放| 日本韩国三级理伦久久久| 亚洲日本香蕉视频观看视频| 国产成人亚洲合色婷婷| 亚洲黄香蕉视频免费看| 中文字幕一区精品日韩| 九九久久精品久久久精品| 欧美亚洲国语精品一区二区| 一本色桃子精品久久中文字幕| 青青草网站在线观看视频| 日韩成人三级一区二区| 国产经典午夜福利在线| 91啪在线观看91色| 国产一区二区视频在线| 国产成人av综合久久视色| 五月激情开心久久婷婷| 欧美经典三级一区二区三区| 亚洲综合实力最强的国家| 国产亚洲黄片免费在线观看| 亚洲av中文久久精品国内| 欧美精品一区二区三区在线|