摘要:然后找了個例子,都成功實現了,一個是自已寫代碼,要處理好多問題,比如我的網頁是,是搞了半天裝了個庫安裝編碼轉換結果可以運行了,中文路徑的問題也搞定了,但是圖片問題還沒搞定,也變成了文字讀取。
初學NODEJS,從網站下載了一個單文件的node.exe,簡單JS測試可以了,但是需要用到一些庫就完全不行了
什么npm命令,輸了都無效,想安裝npm也不知咋弄
后面下載了最新版本,安裝的msi版本,結果裝了好幾分鐘自動回退,最后在虛擬機中先裝好,再復制出來,整整弄了半天,不容易呀。
然后找了2個例子,都成功實現了,一個是自已寫代碼,要處理好多問題,比如我的網頁是GB2312,NODE.js是UTF-8,
搞了半天裝了3個庫:安裝編碼轉換--npm install iconv
npm install iconv-lite
后面別人說可以下載其他庫,然后又找了一個例子,這個沒用什么庫,但是代碼比較全面,改動就可以用了。
不過改改也花了幾小時,一切不會呀從頭學的。
中文路徑名,還有一些文件編碼是ANSI的,結果htm中指定是"utf-8"這樣也顯示不出來
我改好的完美版,基本上大家粘上就直接能用了,還需要加一些目錄默認文件,比如打開一個新目錄
www.abc.com/aa/bbb/
一般應該顯示index.htm,如果沒有就顯示一個錯誤頁或文字,這功能還沒加上,還有原作者他連“.htm”后綴的格式都沒加上,直接顯示成了文本htm代碼。
【 "htm": "text/html",】這一行是我加的
var PORT = 3000; var http = require("http"); var url=require("url"); var fs=require("fs"); var mine=require("./mine").types; var path=require("path"); var RequestUrl=""; var RootPath="www";//網站根目錄 var server = http.createServer(function (request, response) { RequestUrl=request.url; //默認頁面 if (RequestUrl=="" || RequestUrl=="/"){ RequestUrl="/index.htm"; } else { RequestUrl=decodeURIComponent(RequestUrl); } console.log("請求網址:" +RequestUrl); var realfile=RootPath+RequestUrl; console.log(realfile); var ext = path.extname(realfile); ext = ext ? ext.slice(1) : "unknown"; console.log("請求類型:exr= " + ext); fs.exists(realfile, function (exists) { if (!exists) { response.writeHead(404, { "Content-Type": "text/plain" }); response.write("This request URL " + realfile + " was not found on this server."); response.end(); } else { fs.readFile(realfile, "binary", function (err, file) { if (err) { response.writeHead(500, { "Content-Type": "text/plain" }); response.end(err); } else { var contentType = mine[ext] || "text/plain"; response.writeHead(200, { "Content-Type": contentType }); response.write(file, "binary"); response.end(); } }); } }); }); server.listen(PORT); console.log("Server runing at port: " + PORT + ".");
代碼比較長有1517個字左右,格式化了一下,還是覺的很精美的,還有SUBLIME這個編輯工具才20M,可以支持編輯幾十種語言或格式,很強大呀。
‘=======================
以下是原作者的文章:來源:http://www.cnblogs.com/shawn-...
nodejs搭建本地http服務器
由于不做php相關的東西,懶得裝apache,干脆利用nodejs搭建一個本地的服務器用于測試。
nodejs這玩意兒吧,對做前端的介入后端簡直就是一把利器。而且目前,nodejs也越來越有商用價值。
nodejs其實是非常底層的,從功能上說,它既是apache也是php。像搭建http服務器這種功能,本來是apache已經封裝好的,但nodejs需要我們手動來搭建。其實在實際應用中,我們可以使用現成的框架。但這里,我想手動搭建,也加深一下對http服務器的理解。
我們node執行下面這個文件,我命名為http.js,它將創建一個httpServer并監聽3000端口。
var PORT = 3000; var http = require("http"); var url=require("url"); var fs=require("fs"); var mine=require("./mine").types; var path=require("path"); var server = http.createServer(function (request, response) { var pathname = url.parse(request.url).pathname; var realPath = path.join("assets", pathname); //console.log(realPath); var ext = path.extname(realPath); ext = ext ? ext.slice(1) : "unknown"; fs.exists(realPath, function (exists) { if (!exists) { response.writeHead(404, { "Content-Type": "text/plain" }); response.write("This request URL " + pathname + " was not found on this server."); response.end(); } else { fs.readFile(realPath, "binary", function (err, file) { if (err) { response.writeHead(500, { "Content-Type": "text/plain" }); response.end(err); } else { var contentType = mine[ext] || "text/plain"; response.writeHead(200, { "Content-Type": contentType }); response.write(file, "binary"); response.end(); } }); } }); }); server.listen(PORT); console.log("Server runing at port: " + PORT + ".");
上面我們還引入了一個mine.js,這是我自己寫的,里面存儲的是名值對,用于定義不同后綴的文件所對應的返回方式:
exports.types = { "css": "text/css", "gif": "image/gif", "html": "text/html", "htm": "text/html", "ico": "image/x-icon", "jpeg": "image/jpeg", "jpg": "image/jpeg", "js": "text/javascript", "json": "application/json", "pdf": "application/pdf", "png": "image/png", "svg": "image/svg+xml", "swf": "application/x-shockwave-flash", "tiff": "image/tiff", "txt": "text/plain", "wav": "audio/x-wav", "wma": "audio/x-ms-wma", "wmv": "video/x-ms-wmv", "xml": "text/xml" };
fs模塊是用于讀取文件的,提供讀取文件的方法,其實仔細研究文檔會發現,它有同步和異步兩種讀取方式。fs.exists這個方法網上很多文章寫作path.exists,,現在推薦寫作fs.exists這個方法。否則會報警:
需要注意的是,不僅瀏覽器訪問html文件會形成一次訪問,里面鏈接的js,css等外部文件也會分別形成一次http訪問。所以,http.createServer的回調其實是在一次頁面訪問中執行了多次的。我們console.log(realPath)一下就可以看到:
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/83656.html
摘要:提示,如果需要通過實現服務器自動化部署,推薦使用會更方便一些然后在目錄初始化本地倉庫并提交到這時候上已經有我提交的代碼了。再新建一個文件處理部署相關腳本,內容如下將新增的與兩個文件到服務器。 這篇文章將如何搭建hexo,以及如何通過git webhooks實現遠程vps的自動部署 這篇文章適合的條件: 簡單的用于個人博客、公司博客展示,hexo的定位是靜態博客,要實現動態服務器的功能...
閱讀 3380·2021-11-22 09:34
閱讀 650·2021-11-19 11:29
閱讀 1350·2019-08-30 15:43
閱讀 2232·2019-08-30 14:24
閱讀 1867·2019-08-29 17:31
閱讀 1223·2019-08-29 17:17
閱讀 2617·2019-08-29 15:38
閱讀 2729·2019-08-26 12:10