node 之 apache

需要下载第三方模块 art-template

npm install art-template --save
var template = require('art-template');
var html = template(__dirname + '/tpl.art', {
    user: {
        name: 'aui',
        age:18
    }
});
console.log(html);

  

  

一.初步实现apache

//初步实现apache功能
const http = require("http");
const fs = require("fs");
const path = require("path");

//任意目录地址
const wwwdir = "D:黑马文件就业班训练
odeStyexpressapache";

const server = http.createServer();
server.listen("8808", () => {
  console.log("8808的服务端已经开启......");
});

server.on("request", function (req, res) {
  let url = req.url;
  if (url === "/") {
    fs.readFile(path.join(__dirname, "/index.html"), (err, data) => {
      if (err) {
        return res.end("404 not found");
      }
      res.end(data);
    });
  } else if (url === "/boy.html") {
    fs.readFile(path.join(__dirname, "/boy.html"), (err, data) => {
      if (err) {
        return res.end("404 not found");
      }
      res.end(data);
    });
  } else if (url === "/plus/login.html") {
    fs.readFile(path.join(__dirname, "/plus/login.html"), (err, data) => {
      if (err) {
        return res.end("404 not found");
      }
      res.end(data);
    });
  }
});

分析思考:

1/每一次请求都需要去判断if...else...

2/const url = req.url  //这句可以获取请求地址

//初步实现apache功能
const http = require("http");
const fs = require("fs");
const path = require("path");
//创建服务
const server = http.createServer();
//启动服务
server.listen("8808", () => {
  console.log("8808的服务端已经开启......");
});
//监听请求
server.on("request", function (req, res) {
  const filePath = path.join(__dirname, req.url);
  let url = req.url;
  fs.readFile(filePath, (err, data) => {
    if (err) {
      return res.end("404 not found");
    }
    res.end(data);
  });
});

  

使用apache实例一个文件管理页面demo

const http = require("http");
const fs = require("fs");
const path = require("path");
const template = require("art-template");
//创建服务
const server = http.createServer();
//启动服务
server.listen("8808", () => {
  console.log("8808的服务端已经开启......");
});
//监听请求
server.on("request", function (req, res) {
  let url = req.url;
  let urlPath = path.join(__dirname, url);

  fs.stat(urlPath, (err, stats) => {
    if (err) {
      return res.end("404 not found");
    }
    console.log(stats.isFile());
    if (stats.isFile()) {
      //如果是普通文件

      fs.readFile(urlPath, function (err, data) {
        if (err) {
          return res.end("404 not found");
        }
        res.end(data);
      });
    } else if (stats.isDirectory()) {
      //表示一个文件系统目录,则返回true
      let templateStr = fs.readFileSync("./template.html").toString();
      let files = fs.readdirSync(urlPath);

      let htmlStr = template.render(templateStr, { files: files });
      res.end(htmlStr);
    }
  });

html页面

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8" />
    <title id="title">hello</title>
    <style>
      h1 {
        border-bottom: 1px solid #c0c0c0;
        margin-bottom: 10px;
        padding-bottom: 10px;
        white-space: nowrap;
      }

      table {
        border-collapse: collapse;
      }

      th {
        cursor: pointer;
      }

      td.detailsColumn {
        -webkit-padding-start: 2em;
        text-align: end;
        white-space: nowrap;
      }

      a.icon {
        -webkit-padding-start: 1.5em;
        text-decoration: none;
      }

      a.icon:hover {
        text-decoration: underline;
      }

      a.file {
        background: url(" ")
          left top no-repeat;
      }

      a.dir {
        background: url(" ")
          left top no-repeat;
      }

      a.up {
        background: url(" ")
          left top no-repeat;
      }

      html[dir="rtl"] a {
        background-position-x: right;
      }

      #parentDirLinkBox {
        margin-bottom: 10px;
        padding-bottom: 10px;
      }

      #listingParsingErrorBox {
        border: 1px solid black;
        background: #fae691;
        padding: 10px;
        display: none;
      }
    </style>
  </head>

  <body>
    <div id="listingParsingErrorBox">
      糟糕!Google Chrome无法解读服务器所发送的数据。请<a
        href="http://code.google.com/p/chromium/issues/entry"
        >报告错误</a
      >,并附上<a href="LOCATION">原始列表</a></div>
    <h1 id="header">www 目录</h1>
    <div id="parentDirLinkBox" style="display: none">
      <a id="parentDirLink" class="icon up">
        <span id="parentDirText">[上级目录]</span>
      </a>
    </div>
    <table>
      <thead>
        <tr class="header" id="theader">
          <th onclick="javascript:sortTable(0);">名称</th>
          <th class="detailsColumn" onclick="javascript:sortTable(1);">大小</th>
          <th class="detailsColumn" onclick="javascript:sortTable(2);">
            修改日期
          </th>
        </tr>
      </thead>
      <tbody id="tbody">
        {{each files}}
        <tr>
          <td data-value="apple/">
            <a class="icon dir" href="{{$value}}">{{$value}}</a>
          </td>
          <td class="detailsColumn" data-value="0"></td>
          <td class="detailsColumn" data-value="1509589967">
            2017/11/2 上午10:32:47
          </td>
        </tr>
        {{/each}}
      </tbody>
    </table>
  </body>
</html>
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8" />
    <title id="title">hello</title>
    <style>
      h1 {
        border-bottom: 1px solid #c0c0c0;
        margin-bottom: 10px;
        padding-bottom: 10px;
        white-space: nowrap;
      }

      table {
        border-collapse: collapse;
      }

      th {
        cursor: pointer;
      }

      td.detailsColumn {
        -webkit-padding-start: 2em;
        text-align: end;
        white-space: nowrap;
      }

      a.icon {
        -webkit-padding-start: 1.5em;
        text-decoration: none;
      }

      a.icon:hover {
        text-decoration: underline;
      }

      a.file {
        background: url(" ")
          left top no-repeat;
      }

      a.dir {
        background: url(" ")
          left top no-repeat;
      }

      a.up {
        background: url(" ")
          left top no-repeat;
      }

      html[dir="rtl"] a {
        background-position-x: right;
      }

      #parentDirLinkBox {
        margin-bottom: 10px;
        padding-bottom: 10px;
      }

      #listingParsingErrorBox {
        border: 1px solid black;
        background: #fae691;
        padding: 10px;
        display: none;
      }
    </style>
  </head>

  <body>
    <div id="listingParsingErrorBox">
      糟糕!Google Chrome无法解读服务器所发送的数据。请<a
        href="http://code.google.com/p/chromium/issues/entry"
        >报告错误</a
      >,并附上<a href="LOCATION">原始列表</a></div>
    <h1 id="header">www 目录</h1>
    <div id="parentDirLinkBox" style="display: none">
      <a id="parentDirLink" class="icon up">
        <span id="parentDirText">[上级目录]</span>
      </a>
    </div>
    <table>
      <thead>
        <tr class="header" id="theader">
          <th onclick="javascript:sortTable(0);">名称</th>
          <th class="detailsColumn" onclick="javascript:sortTable(1);">大小</th>
          <th class="detailsColumn" onclick="javascript:sortTable(2);">
            修改日期
          </th>
        </tr>
      </thead>
      <tbody id="tbody">
        {{each files}}
        <tr>
          <td data-value="apple/">
            <a class="icon dir" href="{{$value}}">{{$value}}</a>
          </td>
          <td class="detailsColumn" data-value="0"></td>
          <td class="detailsColumn" data-value="1509589967">
            2017/11/2 上午10:32:47
          </td>
        </tr>
        {{/each}}
      </tbody>
    </table>
  </body>
</html>

  

 参考网址:https://blog.csdn.net/lucky541788/article/details/83903964

  

原文地址:https://www.cnblogs.com/zmztya/p/14363679.html