经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » JavaScript » 查看文章
用nodejs创建服务器显示html页面
来源:cnblogs  作者:王不留形  时间:2019/5/15 9:14:08  对本文有异议

nodejs版本:v10.14.2

1.首先准备一个简单的html页面

  1. 1 <!DOCTYPE html>
  2. 2 <html lang="en">
  3. 3 <head>
  4. 4 <meta charset="UTF-8">
  5. 5 <title>nodejs显示html</title>
  6. 6 </head>
  7. 7 <body>
  8. 8 <h1>看到这句话表示html页面成功显示了。</h1>
  9. 9 </body>
  10. 10 </html>
index.html

2.接着准备一个index.js,跟index.html放在同一目录下

(1)导入需要用到的模块,都是nodejs自带的模块

  1. const http = require("http"),
  2. fs = require("fs"),
  3. path = require("path"),
  4. url = require("url");

创建服务器当然需要http模块了,fs模块用来读写html的,path模块用来获取当前目录的,url模块用来解析输入的url的

(2)获取当前目录

  1. // 获取当前目录
  2. var root = path.resolve();

因为index.html和index.js是放在一起的,属于同级,直接获取当前目录就行了。

(3)创建服务器

  1. // 创建服务器
  2. var sever = http.createServer(function(request,response){
  3. var pathname = url.parse(request.url).pathname;
  4. var filepath = path.join(root,pathname);
  5. // 获取文件状态
  6. fs.stat(filepath,function(err,stats){
  7. if(err){
  8. // 发送404响应
  9. response.writeHead(404);
  10. response.end("404 Not Found.");
  11. }else{
  12. // 发送200响应
  13. response.writeHead(200);
  14. // response是一个writeStream对象,fs读取html后,可以用pipe方法直接写入
  15. fs.createReadStream(filepath).pipe(response);
  16. }
  17. });
  18. });
  19. sever.listen(8080);
  20. console.log('Sever is running at http://127.0.0.1:8080/');
createServer方法创建一个sever,每次请求从request拿到url,解析后找到文件,获取成功后写入response。
失败则发送404.
代码部分到此结束,接下来是测试
(4)测试
打开cmd,找到文件所在目录(当然用VS Code之类更方便,敲代码测试都在一起),键入node index.js
可以看到输出Sever is running at http://127.0.0.1:8080/,表示服务器已经搭建好了。
接着打开浏览器,输入http://127.0.0.1:8080/index.html
成功了!

原文链接:http://www.cnblogs.com/wblx/p/10863592.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号