国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

node學習系列之簡單文件上傳

Achilles / 2847人閱讀

摘要:此為看完入門寫的小自己實現了一遍,借助的外部模塊只有的模塊的使用原代碼倉庫

此為看完node入門寫的小demo,自己實現了一遍,借助的外部模塊只有formidable
Node.js的Formidable模塊的使用

index.js

const server = require("./server");
const router = require("./router.js");
const requestHandler = require("./requestHandler.js");

var handle = {};
handle["/"] = requestHandler.start;
handle["/start"] = requestHandler.start;
handle["/upload"] = requestHandler.upload;
handle["/show"] = requestHandler.show;

server.start(router.route, handle);

server.js

const http = require("http");
const url = require("url");

const start = (route, handle) => {
    http.createServer((request, response) => {
        let pathname = url.parse(request.url).pathname;
        let postData = "";
        console.log("request from" + pathname + "received");

        route(handle, pathname, response, request);

    }).listen(8888);
}

console.log("server has started");

module.exports = {
    start: start
}

router.js

const route = (handle, pathname, response, request) => {
    console.log("about to route a request for" + pathname);
    if(typeof handle[pathname] === "function") {
        handle[pathname](response, request);
    }else {
        console.log("no request handle found for " + pathname);
        response.writeHead(404, {"Conten-Type": "text/plain"});
        response.write("404 not found");
        response.end();
    }
}

module.exports = {
    route: route
}

requestHandler.js

const querystring = require("querystring");
const fs = require("fs");
const formidable = require("formidable");

const start = (response, request) => {
    console.log("request handle "start" was called");
    let body = `
                
                    
                    Document
                
                
                    
`; response.writeHead(200, {"Conten-Type" : "text/html"}); response.write(body); response.end(); } const upload = (response, request) => { console.log("request handle "upload" was called"); let form = new formidable.IncomingForm(); form.uploadDir = "./upload/tmp"; form.parse(request, (err, fields, files) => { console.log("parse done"); let body = ` Document `; fs.renameSync(files.upload.path, "/tmp/test.png") response.writeHead(200, {"Content6-Type" : "text/html"}); response.write(body); response.end(); }) } const show = (response) => { console.log("request handle "show" was called"); fs.readFile("/tmp/test.png", "binary", (err, file) => { if(err) { response.writeHead(500, {"Conten-Type" : "text/plain"}); response.write(err); response.end(); }else { response.writeHead(200, {"Conten-Type" : "image/png"}); response.write(file, "binary"); response.end(); } }) } module.exports = { start: start, upload: upload, show: show }
原代碼倉庫

learn-node/upload

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/91046.html

相關文章

  • Express系列multer

    摘要:目前覺得對我有用的是和。后者可以在本地調試頁面,對于手機頁面尤其有用。這次主要說一下,我并沒有實現所有的功能,只是實現單圖片上傳這一個功能,其他的再摸索嘍。目前就這樣,下次弄出來了多圖片上傳我再接著更新。 這兩天在看《nodejs權威指南》,這本書看了好久了,但是讀的一直不細,這次才好好看了一遍。 收獲還是蠻多的,主要在于wenpack使用的一些細節問題,有點茅塞頓悟的體驗吧,另外在n...

    Null 評論0 收藏0
  • JavaScript精編干貨

    摘要:老姚淺談怎么學鑒于時不時,有同學私信問我老姚,下同怎么學前端的問題。擼碼聽歌,全局控制。 淺析用 js 解析 xml 的方法 由于項目上需要解析 xml,于是各種百度,然后自己總結了下各個主流瀏覽器解析 xml 的方法,只能是很淺顯的知道他的用法,但是還沒有深層次的研究。 裝 X - 建立自己的斗圖網站庫 之前加過一個斗圖群,看到很多經典的表情,然后就收藏到了 QQ, 迫于本屌絲開不起...

    Fourierr 評論0 收藏0
  • H5學習

    摘要:為此決定自研一個富文本編輯器。本文,主要介紹如何實現富文本編輯器,和解決一些不同瀏覽器和設備之間的。 對ES6Generator函數的理解 Generator 函數是 ES6 提供的一種異步編程解決方案,語法行為與傳統函數完全不同。 JavaScript 設計模式 ② 巧用工廠模式和創建者模式 我為什么把他們兩個放在一起講?我覺得這兩個設計模式有相似之處,有時候會一個設計模式不能滿...

    aristark 評論0 收藏0
  • 前端每周清單第 41 期 : Node 與 Rust、OpenCV 的火花,網絡安全二三事

    摘要:的網站仍然使用有漏洞庫上周發布了開源社區安全現狀報告,發現隨著開源社區的日漸活躍,開源代碼中包含的安全漏洞以及影響的范圍也在不斷擴大。與應用安全是流行的服務端框架,本文即是介紹如何使用以及其他的框架來增強應用的安全性。 showImg(https://segmentfault.com/img/remote/1460000012181337?w=1240&h=826); 前端每周清單專注...

    syoya 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<