设为首页 收藏本站
查看: 549|回复: 0

[经验分享] nodejs使用nodejs创建简单的静态文件服务器

[复制链接]

尚未签到

发表于 2017-2-21 11:32:36 | 显示全部楼层 |阅读模式
  转自:http://blog.csdn.net/zxsrendong/article/details/16804867
在开始之前,应该好好规划一下项目的文件目录了。我的目录结构如下:
DSC0000.jpg
assets放置网站的静态文件css,js,img等;common存放项目的配置文件和一些通用文件;server存放服务处理文件,将要创建的静态文件服务就是放在此目录中; tpl放置的是模板文件也就是网页文件。
文件的下载格式主要是由'Content-Type'的值决定的,要想下载的文件能够正常工作就应该正确的设置不同文件的'Content-Type'值。mime.js文件存放了一些常用mime值:

[javascript] view plaincopy 



  • exports.mime = {  
  •     "html" : "text/html",  
  •     "css"  : "text/css",  
  •     "js"   : "text/javascript",  
  •     "json" : "application/json",  
  •     "ico"  : "image/x-icon",  
  •     "gif"  : "image/gif",  
  •     "jpeg" : "image/jpeg",  
  •     "jpg"  : "image/jpeg",  
  •     "png"  : "image/png",  
  •     "pdf"  : "application/pdf",  
  •     "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"  
  • };  

  先来看server.js和FServer.js的类容:
 
 
[javascript] view plaincopy 



  • //  server.js    
  •     var config = require('./common/config');    
  •     var http   = require('http');    
  •     var fs     = require('fs');    
  •     var url    = require('url');    
  •     var path   = require('path');    
  •     var FServer   = require('./server/FServer');    
  •     function index(){    
  •         var indexPath = config.ui + '/index.html';    
  •         fs.exists(indexPath, function(exists){    
  •             if( !exists ) {    
  •                 throw err;    
  •             } else {    
  •                 fs.readFile(indexPath, function(err, data){    
  •                     if (err) {    
  •                         throw err;      
  •                     } else {    
  •                         function onRequest(req, res){    
  •                             // 取得文件路径    
  •                             var pathname = url.parse(req.url).pathname;    
  •                             // 获取文件扩展名(包含前置.)    
  •                             var extname = path.extname( pathname );    
  •                             var type = extname.slice(1);    
  •                             // 获取下载文件在磁盘上的路径,    
  •                             var realPath = config.root + pathname;    
  •                             if ( extname === '' ) {    
  •                                 res.writeHead(200, {'Content-Type':'text/html'});    
  •                                 res.write(data);    
  •                                 res.end();    
  •                             } else {    
  •                                 FServer.filesLoad(realPath, type, req, res);    
  •                             }    
  •                         }    
  •                         http.createServer(onRequest).listen(config.port);    
  •                     }    
  •                 })    
  •             }    
  •         })    
  •      }    
  •     exports.index = index;    
  •     
  •     // FServer.js    
  •     var fs   = require('fs');    
  •     var mime = require('../common/mime').mime;    
  •     function filesLoad(filePath, type, req, res){    
  •         fs.exists(filePath, function(exists){    
  •             if ( !exists ) {    
  •                 res.writeHead(404, {'Content-Type''text/plain'});    
  •                 // res.write();    
  •                 res.end();    
  •             } else {    
  •                 fs.readFile(filePath, 'binary'function(err, file){    
  •                     if ( err ) {    
  •                         res.writeHead(500, {'Content-Type''text/plain'});    
  •                         // res.write();    
  •                         res.end();    
  •                     } else {    
  •                         res.writeHead(200, {'Content-Type': mime[type]});    
  •                         res.write(file, 'binary');    
  •                         res.end();    
  •                     }    
  •                 });    
  •             }    
  •         })    
  •     }    
  •     exports.filesLoad = filesLoad;    

  上面引入了nodejs的内置模块http、fs、url、path,config和FServer是自定义模块,要读取文件首先要知道文件在磁盘上是否存在,还应当知道文件的类型才能达到想要的效果。运行程序可以发现css和javascript都下载正确,并且css效果在页面上正确渲染(javascript还没有写效果)
   
 

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-345218-1-1.html 上篇帖子: Nodejs的express路由规则 下篇帖子: dojo charting on nodejs
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表