Node入门 模块化

Node入门 模块化

参考:https://www.nodebeginner.org/index-zh-cn.html

1. 处理post请求(提交表单)

目录结构

目录结构

index.js
var server = require("./server");
var router = require("./router");
var requestHandlers = require("./requestHandlers");

// 请求处理程序的集合
var handle = {}
handle["/"] = requestHandlers.start;
handle["/start"] = requestHandlers.start;
handle["/upload"] = requestHandlers.upload;
server.start(router.route, handle);
server.js
// 引入http模块
var http = require("http");
var url = require("url");
function start(route, handle) {
  http.createServer(function(request, response) {
    // 浏览器都会在你访问 http://localhost:8888/ 时尝试读取 http://localhost:8888/favicon.ico
    var pathname = url.parse(request.url).pathname;
    console.log("收到 " + pathname + " 请求。");

    // 为了整个过程非阻塞,Node.js会将POST数据拆分成很多小的数据块
    // 通过触发特定的事件将这些小数据块传递给回调函数
    // data事件表示新的小数据块到达了
    // end事件表示所有数据都已经接收完毕
    var postData = "";
    request.setEncoding("utf-8");
    request.addListener("data", function(postDataChunk) {
      postData += postDataChunk;
      console.log("接收的POST数据块:" + postDataChunk);
    })

    request.addListener("end", function() {
      route(handle, pathname, response, postData);
    })
    
    // response.writeHead(200, {"Content-Type": "text/plain"});
    // response.write("Hello World");
    // response.end();
  }).listen(8888);
  
  console.log("服务器已启动。");
}
exports.start = start;
router.js
function route(handle, pathname, response, postData) {
  console.log("将传送的请求是:" + pathname);
  if(typeof handle[pathname] === 'function') {
    handle[pathname](response, postData);
  } else {
    console.log("找不到的请求处理程序:" + pathname);
    response.writeHead(404, {"Content-Type": "text/html"});
    response.write("404 Not Found");
    response.end();
  }
}
exports.route = route;
requestHandlers.js
var querystring = require("querystring");
function start(response, postData) {
  console.log("已调用请求处理程序“start”。");
  var body = '<html>'+
  '<head>'+
    '<meta http-equiv="Content-Type" content="text/html;charset=UTF-8"/>'+
  '</head>'+
  '<body>'+
    '<form action="/upload" method="post">'+
      '<textarea name="text" rows="20" cols="60"></textarea>'+
      '<input type="submit" value="Submit text" />'+
    '</form>'+
  '</body>'+
'</html>';
  
  response.writeHead(200, {"Content-Type": "text/html"});
  response.write(body);
  response.end();
}

function upload(response, postData) {
  console.log("已调用请求处理程序“upload”。");
  response.writeHead(200, {"Content-Type": "text/plain"});
  // response.write("You've sent: " + postData); // text=postData
  response.write("You've sent: " + querystring.parse(postData).text);
  response.end();
}

exports.start = start;
exports.upload = upload;

2. 上传图片并显示

首先导入模块:npm install formidable

目录结构

目录结构

index.js
var server = require("./server");
var router = require("./router");
var requestHandlers = require("./requestHandlers");

// 请求处理程序的集合
var handle = {}
handle["/"] = requestHandlers.start;
handle["/start"] = requestHandlers.start;
handle["/upload"] = requestHandlers.upload;
handle["/show"] = requestHandlers.show;

server.start(router.route, handle);
server.js
// 引入http模块
var http = require("http");
var url = require("url");
function start(route, handle) {
  http.createServer(function(request, response) {
    var pathname = url.parse(request.url).pathname;
    console.log("收到 " + pathname + " 请求。");
    route(handle, pathname, response, request);
  }).listen(8888);
  console.log("服务器已启动。");
}
exports.start = start;
router.js
function route(handle, pathname, response, request) {
  console.log("将传送的请求是:" + pathname);
  if(typeof handle[pathname] === 'function') {
    handle[pathname](response, request);
  } else {
    console.log("找不到的请求处理程序:" + pathname);
    response.writeHead(404, {"Content-Type": "text/html"});
    response.write("404 Not Found");
    response.end();
  }
}
exports.route = route;
requestHandlers.js
var fs = require("fs");
var formidable = require("formidable");

function start(response) {
  console.log("已调用请求处理程序“start”。");
  var body = '<html>'+
  '<head>'+
    '<meta http-equiv="Content-Type" content="text/html;charset=UTF-8"/>'+
  '</head>'+
  '<body>'+
    '<form action="/upload" enctype="multipart/form-data" method="post">'+
      '<input type="file" name="upload" />'+
      '<input type="submit" value="Upload file" />'+
    '</form>'+
  '</body>'+
'</html>';
  
  response.writeHead(200, {"Content-Type": "text/html"});
  response.write(body);
  response.end();
}

function upload(response, request) {
  console.log("已调用请求处理程序“upload”。");

  var form = new formidable.IncomingForm();
  console.log("即将解析");
  form.parse(request, function(error, fields, files) {
    console.log("解析完毕");
    fs.renameSync(files.upload.path, "./tmp/test.png", function(err) {
      if(err) {
        fs.unlink("/tmp/test.png");
        fs.rename(files.upload.path, "./tmp/test.png");
      }
    });
    response.writeHead(200, {"Content-Type": "text/html"});
    response.write("received image:<br/>");
    response.write("<img src='/show' />");
    response.end();
  })
}

function show(response) {
  console.log("已调用请求处理程序“show”。");
  response.writeHead(200, {"Content-Type": "image/png"});
  fs.createReadStream("./tmp/test.png").pipe(response);
  // fs.readFile("./tmp/test.png", "binary", function(error, file) {
  //   if(error) {
  //     response.writeHead(500, {"Content-Type": "text/plain"});
  //     response.write(error+"\n");
  //     response.end();
  //   } else {
  //     response.writeHead(200, {"Content-Type": "image/png"});
  //     response.write(file, "binary");
  //     response.end();
  //   }
  // });
}

exports.start = start;
exports.upload = upload;
exports.show = show;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值