zoukankan      html  css  js  c++  java
  • node.js实际应用【模拟Apache服务器】【原生模块】

    1. 编写js文件
    var http = require('http');
    var fs = require('fs');
    var template = require('art-template');
    var path = require('path');
    
    var port = 5000;
    var server = http.createServer();
    
    server.on('request',function(request, response){
      var url = request.url;
      var wwwDir = '.';
      fs.readFile('./src/template.html', function(error, data){
        if (error) {
          console.log(error);
          return response.end('404 Not Found');
        }
    
        if (url !== '/') {
          wwwDir += url;
        }
        var dirList = [];
        var fileList = [];
        var fileEnd = path.extname(wwwDir);
        if (fileEnd !== '') {
          fs.readFile(wwwDir, function(error, data){
            if (error) {
              console.log(error);
              return response.end('404 Not Found');
            }
            if (fileEnd === '.txt') {
              response.setHeader('Content-Type', 'text/plain; charset=utf-8');
            }
            if (fileEnd === '.jpg') {
              response.setHeader('Content-Type', 'image/jpeg');
            }
            if (fileEnd === '.mp4') {
              response.setHeader('Content-Type', 'video/mpeg4');
            }
            response.end(data);
          });
        } else {
          fs.readdir(wwwDir, function(error, files){
            if (error) {
              return response.end('Can not find this dir');
            }
            var dirList = [];
            var fileList =[];
            files.forEach(function(iterm){
              var fullPath =  path.join(wwwDir,iterm);
    
              // 异步 
              // fs.stat(fullPath, function(err, data){
              //   if (err) {
              //       console.log(err);
              //   } else {
              //       if (data.isFile()){
              //         fileList.push(iterm)
              //         // console.log('file: ',fileList)
              //       }else{
              //         dirList.push(iterm)
              //       }
              //   }
              // });
    
              // 同步 
              var stat = fs.lstatSync(fullPath);
              console.log(fullPath,stat.mtime)
              if (stat.isFile()){
                fileList.push({'fullPath':fullPath,'fileSise':stat.size,'mtime':stat.mtime});
              }else{
                console.log(fullPath)
                dirList.push(fullPath);
              }
    
            });
            var htmlStr = template.render(data.toString(), {
              title: wwwDir,
              files: files,
              dirList:dirList,
              fileList:fileList,
            });
            response.end(htmlStr);
          });
        }
      });
    });
    server.listen(port, function(){
      console.log(`服务器已经开启,您可以通过 http://127.0.0.1:${port} 访问....`);
    });
    
    1. 编写template文件
    
    <html dir="ltr" lang="zh" i18n-processed="">
    
    <head>
      <meta charset="utf-8">
      <meta name="google" value="notranslate">
      
      <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>
      <title id="title">{{ title }}</title>
    </head>
    
    <body>
      <h1 id="header">索引</h1>
      <div id="parentDirLinkBox">
        <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">
          <!-- file list -->
          {{each fileList}}
          <tr>
            <td data-value="{{ $value.fullPath }}"><a class="icon file" draggable="true"  href="/{{ $value.fullPath }}" >{{ $value['fullPath'] }}</a></td>
            <td class="detailsColumn" data-value="0">{{ $value.fileSise }}</td>
            <td class="detailsColumn" data-value="{{ $value.mtime }}">{{ $value.mtime }}</td>
          </tr>
          {{/each}}
          <!-- dir list -->
          {{each dirList}}
          <tr>
            <td data-value="{{ $value }}"><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>
    
    
    1. 使用Content-Type模块
    https://www.cnblogs.com/OrochiZ-/p/11653527.html
    
  • 相关阅读:
    微软首届Power Platform开发黑客松大赛
    PowerApps 简介
    PowerBI KPI 演示
    什么是Power Platform低代码
    利用Microsoft PowerApps模板,一分钟创建Service Desk服务程序
    Power Platform
    Microsoft Power Platform 低代码开发平台
    登录监听Enter键
    代理配置
    Enjoy the pain about Moloch
  • 原文地址:https://www.cnblogs.com/amize/p/14869323.html
Copyright © 2011-2022 走看看