1、Node.js 创建的第一个应用

var http=require("http")
http.createServer(function (req,res) {
res.writeHead(200,{"Content-Type":"text/html;charset='utf8'"})
res.write("<head><meta charset='UTF-8'></head>")
res.write("hello,Node.js!!!")
res.end()
}).listen(8081)

2、WEB 服务器介绍

Web 服务器一般指网站服务器,是指驻留于因特网上某种类型计算机的程序,可以向浏览
器等 Web 客户端提供文档,也可以放置网站文件,让全世界浏览;可以放置数据文件,让
全世界下载。目前最主流的三个 Web 服务器是 Apache Nginx IIS。

3、Nodejs 创建一个 WEB 服务器。

项目结构截图:

返回html页面示例:

firstServer.js代码(主程序):

//引入http模块:
var http = require("http");
//引入fs模块:
var fs = require("fs");
/**
* 引入path模块
* Node内置模块,可以拿到文件的后缀名
*console.log(path.extname("index.html"));----.html
*/
var path = require("path")
//引入加工响应头文件的自定义模块:
var getextname = require("./model/getExtName");
//console.log(getextname.getminiName(".css"));
/**
* 引入url模块,用来加工有些时候服务地址后面传值的情况:
* http://localhost:8081/index.html?name=tom
* 这个时候我们仅仅通过上边的模块加工是不够的
*/
var url = require("url");
http.createServer(function (req, res) {
//var urlStr = req.url;//获取浏览器输入的地址
/*
* 引入url模块,用来加工有些时候服务地址后面传值的情况:
* http://localhost:8081/index.html?name=tom
* 这个时候我们仅仅通过上边的模块加工是不够的,此时就需要借助下面的url模块解析:
*/
var urlStr = url.parse(req.url).pathname;
console.log(urlStr);
if (urlStr == '/') {//設置默认加载的頁面
urlStr == '/index.html';
}
if (urlStr != '/favicon.ico') { //过滤无效请求:/favicon.ico
var extname = path.extname(urlStr);
//下面通过文件操作模块读取静态页面内容:最后通过res返回给客户端
fs.readFile("html" + urlStr, function (err, data) {
if (err) {//没有这个文件
console.log("404");
fs.readFile("html/404.html", function (err, data404) {
//注意下面要修改响应头的状态码
res.writeHead(404, {"Content-Type": "text/html;charset='utf8'"})
res.write(data404)
res.end()
})
} else {
/**
* 大部分情况下我们不一定返回html文件,也可能返回css文件,js文件,xml文件等等,因此下面的头文件的
* "Content-Type": "text/html;charset='utf8'"不能写死,而应该动态随着请求的内容改变
*/
//res.writeHead(200, {"Content-Type": "text/html;charset='utf8'"})
res.writeHead(200, {"Content-Type": getextname.getminiName(extname) + ";charset='utf8'"})
res.write(data)
res.end()
}
})
}
}).listen(8081)

index.html文件代码:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<style>
div{
width: 100px;
height: 200px;
background-color: red;
margin: 0 auto;
}
</style>
<body>
<div></div>
</body>
</html>

自定义模块(功能类js):getExtName.js:

/**
* Created by Administrator on 2019/4/24.
*/
/**
* 自定义模块加工响应头文件类型
* @param extname
* @returns {*}
*/
module.exports.getminiName=function (extname) {
switch (extname){
case ".html":
return "text/html"
case ".css":
return"text/css"
case ".js":
return "text/js"
case ".xml":
return"text/xml"
default:
return"text/xml"
}
}

404.html页面代码:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<style>
div{
font-size: 30px;
font-weight: bolder;
color: red;
}
</style>
<body>
<div>404</div>
</body>
</html>

效果:

十七、创建一个 WEB 服务器(一)的更多相关文章

  1. 【重点突破】——使用Express创建一个web服务器

    一.引言 在自学node.js的过程中有一个非常重要的框架,那就是Express.它是一个基于NodeJs http模块而编写的高层模块,弥补http模块的繁琐和不方便,能够快速开发http服务器.这 ...

  2. python web编程 创建一个web服务器

    这里就介绍几个底层的用于创建web服务器的模块,其中最为主要的就是BaseHTTPServer,很多框架和web服务器就是在他们的基础上创建的 基础知识 要建立一个Web 服务,一个基本的服务器和一个 ...

  3. node(03)--利用 HTTP 模块 URl 模块 PATH 模块 FS 模块创建一个 WEB 服务器

    Web 服务器一般指网站服务器,是指驻留于因特网上某种类型计算机的程序,可以向浏览器等 Web 客户端提供文档,也可以放置网站文件,让全世界浏览:可以放置数据文件,让全世界下载.目前最主流的三个 We ...

  4. C#中自己动手创建一个Web Server(非Socket实现)

    目录 介绍 Web Server在Web架构系统中的作用 Web Server与Web网站程序的交互 HTTPListener与Socket两种方式的差异 附带Demo源码概述 Demo效果截图 总结 ...

  5. 用java写一个web服务器

    一.超文本传输协议 Web服务器和浏览器通过HTTP协议在Internet上发送和接收消息.HTTP协议是一种请求-应答式的协议——客户端发送一个请求,服务器返回该请求的应答.HTTP协议使用可靠的T ...

  6. 用C写一个web服务器(二) I/O多路复用之epoll

    .container { margin-right: auto; margin-left: auto; padding-left: 15px; padding-right: 15px } .conta ...

  7. 002.Create a web API with ASP.NET Core MVC and Visual Studio for Windows -- 【在windows上用vs与asp.net core mvc 创建一个 web api 程序】

    Create a web API with ASP.NET Core MVC and Visual Studio for Windows 在windows上用vs与asp.net core mvc 创 ...

  8. Tomcat源码分析 (一)----- 手写一个web服务器

    作为后端开发人员,在实际的工作中我们会非常高频地使用到web服务器.而tomcat作为web服务器领域中举足轻重的一个web框架,又是不能不学习和了解的. tomcat其实是一个web框架,那么其内部 ...

  9. 使用Node.js原生API写一个web服务器

    Node.js是JavaScript基础上发展起来的语言,所以前端开发者应该天生就会一点.一般我们会用它来做CLI工具或者Web服务器,做Web服务器也有很多成熟的框架,比如Express和Koa.但 ...

随机推荐

  1. MySQL的Innodb缓存相关优化

    MySQL的Innodb缓存相关优化 INNODB 状态的部分解释 通过 命令 SHOW STATUS LIKE  'Innodb_buffer_pool_%' 查看  Innodb缓存使用率  (I ...

  2. 1056 Mice and Rice

    题意:略 思路:利用queue来模拟一轮一轮的比赛.自己第一遍做的时候完全没有用queue做的意识,代码写的贼烦最后还只得了17分,非常郁闷.通过本题反映出对queue的应用场景季度不熟悉,STL里面 ...

  3. MFC学习(二)

    WinApp封装了程序的主入口WinMain,WinMain就和C语言的main函数地位一样,是Win32程序的入口.在MFC的封装中,一个程序启动,Windows调用WinMain,这个WinMai ...

  4. Linux - 用户的增删改查及组的相关操作

    useradd:新增一个用户 useradd 几个常用的参数: -u:指定用户的 uid -g:指定用户所属的组 -d:指定用户的家目录 -c:指定用户的备注信息 -s:指定用户所用的 shell [ ...

  5. springboot成神之——监视器

    Spring Boot 的监视器 依赖 配置 书写监视控制器 常用的一些内置endpoint 定义actuator/info特殊endpoint actuator/shutdown需要post请求才能 ...

  6. 解决git gnutls_handshake失败

    sudo apt-get install build-essential fakeroot dpkg-dev mkdir ~/git-openssl cd ~/git-openssl sudo apt ...

  7. Halcon的HWindowControl控件在WinForm程序中的使用介绍(重点解决图片缩放的问题)

     Halcon的HWindowControl控件在WinForm程序中的使用介绍(重点解决图片缩放的问题) 2016-12-04 20:11 362人阅读 评论(4) 收藏 举报  分类: Halco ...

  8. leetcode452

    public class Solution { public int FindMinArrowShots(int[,] points) { // multidimensional array cann ...

  9. Vulkan Tutorial 04 理解Validation layers

    操作系统:Windows8.1 显卡:Nivida GTX965M 开发工具:Visual Studio 2017 What are validation layers? Vulkan API的设计核 ...

  10. matlab GPU 操作

    从Matlab2013版本开始,matlab将可以直接调用gpu进行并行计算,而不再需要安装GPUmat库.这一改动的好处是原有的matlab内置函数都可以直接运用,只要数据格式是gpuArray格式 ...