首页 / 更多教程 / 用node写个简单的静态服务器
用node写个简单的静态服务器
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了用node写个简单的静态服务器,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1712字,纯文字阅读大概需要3分钟。
内容图文
直接上代码吧,我把它命名为 app.js, 只要在该文件所在目录下,控制台运行 node app.js 即可启动一个本地服务器了。
/** * 服务器 * Author jervy * Date */ var MINE_TYPES = { 'html': 'text/html', 'xml': 'text/xml', 'txt': 'text/plain', 'css': 'text/css', 'js': 'text/javascript', 'json': 'application/json', 'pdf': 'application/pdf', 'swf': 'application/x-shockwave-flash', 'svg': 'image/svg+xml', 'tiff': 'image/tiff', 'png': 'image/png', 'gif': 'image/gif', 'ico': 'image/x-icon', 'jpg': 'image/jpeg', 'jpeg': 'image/jpeg', 'wav': 'audio/x-wav', 'wma': 'audio/x-ms-wma', 'wmv': 'video/x-ms-wmv', 'woff2': 'application/font-woff2' }; var PORT = 3000; var http = require('http'); var url = require('url'); var fs = require('fs'); var path = require('path'); var root = process.cwd(); var server = http.createServer(function(request, response) { var pathname = decodeURIComponent(url.parse(request.url).pathname); var realPath = path.join(root, pathname); var ext = path.extname(realPath); if (!ext) { realPath = path.join(realPath, '/index.html'); ext = '.html' } fs.exists(realPath, function(exists) { if (exists) { fs.readFile(realPath, 'binary', function(err, file) { if (!err) { response.writeHead(200, { 'Content-Type': MINE_TYPES[ext.slice(1)] || 'text/plain' }); response.write(file, 'binary'); response.end(); } else { response.writeHead(500, { 'Content-Type': 'text/plain' }); response.write('ERROR, the reason of error is ' + err.code + '; Error number is ' + err.errno + '.'); response.end(); } }) } else { response.writeHead(404, { 'Content-Type': 'text/plain' }); response.write('This request URL ' + pathname + ' was not found on this server.'); response.end(); } }); }); server.listen(PORT); console.log("server running at port " + PORT);
内容总结
以上是互联网集市为您收集整理的用node写个简单的静态服务器全部内容,希望文章能够帮你解决用node写个简单的静态服务器所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。