5-廖雪峰-node-http

作者: _panda | 来源:发表于2017-08-07 18:00 被阅读65次

    使用node的http模块

    用Node.js实现一个HTTP服务器程序非常简单。我们来实现一个最简单的Web程序hello.js,它对于所有请求,都返回Hello world!:

    'use strict';
    
    // 导入http模块:
    var http = require('http');
    
    // 创建http server,并传入回调函数:
    var server = http.createServer(function (request, response) {
        // 回调函数接收request和response对象,
        // 获得HTTP请求的method和url:
        console.log(request.method + ': ' + request.url);
        // 将HTTP响应200写入response, 同时设置Content-Type: text/html:
        response.writeHead(200, {'Content-Type': 'text/html'});
        // 将HTTP响应的HTML内容写入response:
        response.end('<h1>Hello world!</h1>');
    });
    
    // 让服务器监听8080端口:
    server.listen(8080);
    
    console.log('Server is running at http://127.0.0.1:8080/');
    //在命令提示符下运行该程序,可以看到//以下输出:
    
    //$ node hello.js 
    //Server is running at http://127.0.0.1:8080/
    

    不要关闭命令提示符,直接打开浏览器输入http://localhost:8080,即可看到服务器响应的内容:

    http-hello-sample
    

    同时,在命令提示符窗口,可以看到程序打印的请求信息:

    GET: /
    GET: /favicon.ico
    

    当然但我们要扩展我们的node服务器,做成一个文件服务器。我们需要解析==request.url==中的路径。

    现在我们要用到node的url,path模块


    最后,我们实现一个文件服务器file_server.js:

    'use strict';
    
    var
        fs = require('fs'),
        url = require('url'),
        path = require('path'),
        http = require('http');
    
    // 从命令行参数获取root目录,默认是当前目录:
    var root = path.resolve(process.argv[2] || '.');
    
    console.log('Static root dir: ' + root);
    
    // 创建服务器:
    var server = http.createServer(function (request, response) {
        // 获得URL的path,类似 '/css/bootstrap.css':
        var pathname = url.parse(request.url).pathname;
        // 获得对应的本地文件路径,类似 '/srv/www/css/bootstrap.css':
        var filepath = path.join(root, pathname);
        // 获取文件状态:
        fs.stat(filepath, function (err, stats) {
            if (!err && stats.isFile()) {
                // 没有出错并且文件存在:
                console.log('200 ' + request.url);
                // 发送200响应:
                response.writeHead(200);
                // 将文件流导向response:
                fs.createReadStream(filepath).pipe(response);
            } else {
                // 出错了或者文件不存在:
                console.log('404 ' + request.url);
                // 发送404响应:
                response.writeHead(404);
                response.end('404 Not Found');
            }
        });
    });
    
    server.listen(8080);
    
    console.log('Server is running at http://127.0.0.1:8080/');
    

    问题详情

    我们想测试一下node 的http模块

    'use strict';
    
    // 导入http模块:
    var http = require('http');
    
    // 创建http server,并传入回调函数:
    var server = http.createServer(function(request, response) {
        // 回调函数接收request和response对象,
        // 获得HTTP请求的method和url:
        console.log(request.method + ': ' + request.url);
        // 将HTTP响应200写入response, 同时设置Content-Type: text/html:
        response.writeHead(200, { 'Content-Type': 'text/html' });
        // 将HTTP响应的HTML内容写入response:
        response.end('<h1>Hello world!</h1>');
    });
    
    // 让服务器监听8080端口:
    server.listen(8080);
    
    console.log('Server is running at http://127.0.0.1:8080/');
    

    我遇到一些问题,cmd报错了

    Server is running at http://127.0.0.1:8080/
    GET: /__webpack_hmr
    GET: /__webpack_hmr
    GET: /__webpack_hmr
    GET: /__webpack_hmr
    GET: /__webpack_hmr
    //hmr就是hot module replacement
    //模块热替换,这也就是为什么你不刷新页面就可以更
    //新视图的原因,所以,肯定是一直请求的
    

    最后发现是最常用的端口8080被占用了,然后我们把

    server.listen(8000);
    //然后在浏览器中打开http://127.0.0.1:8000就可以了
    

    相关文章

      网友评论

        本文标题:5-廖雪峰-node-http

        本文链接:https://www.haomeiwen.com/subject/zuvalxtx.html