在浏览器中,不同的请求应该作出不同的响应

我们可以从请求req中的url获得请求的内容

然后我们就可以通过判断请求的url来做响应

代码如下:

//根据用户的不同请求,服务器做出不同的响应
//
//1.加载http模块
//
var http=require('http'); //2.创建http服务,监听
http.createServer(function(req,res){
//获取用户请求req.url
//console.log(req.url);
//结束响应
//res.end();
res.setHeader('Content-Type','text/plain;charset=utf-8');
//通过req.url获取用户请求的路径,获得不同的响应
if(req.url==='/'||req.url==='/index')
res.end('hello index');
else if(req.url==='/login')
res.end('hello login');
else if(req.url==='/list')
res.end('hello list');
else
res.end('404'); }).listen(8080,function(){
console.log('http://localhost:8080'); })

如果需要响应html文件,需要有fs,path模块

代码如下

//根据用户请求不同,响应不同的html
var http=require('http');
//加载fs模块
var fs=require('fs');
//加载path模块
var path=require('path'); http.createServer(function(req,res){ if(req.url==='/'||req.url==='/index')
{
//如果这里传utf-8,返回的data是字符串,但我们不需要将其转为字符串。因为我们读取的是二进制,我们不需要将二进制转为字符串再将字符串转为二进制
fs.readFile(path.join(__dirname,'html','xx1.html'),function(err,data){
if(err)
{
console.log(err);
}
//把读取的html发送
res.end(data);//这里面不会乱码,因为html文件了已经有utf-8了
})
}
else if(req.url==='/login')
{
fs.readFile(path.join(__dirname,'html','xx2.html'),function(err,data){
if(err)
{
console.log(err);
}
//把读取的html发送
res.end(data);//这里面不会乱码,因为html文件了已经有utf-8了
})
}
else if(res.url==='/list')
{
fs.readFile(path.join(__dirname,'html','xx3.html'),function(err,data){
if(err)
{
console.log(err);
}
//把读取的html发送
res.end(data);//这里面不会乱码,因为html文件了已经有utf-8了
})
}
else
res.end('404'); }).listen(9090,function(){
console.log('http://localhost:9090');
})

如果响应的html文件里面有图片请求,例如

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<body>
<img src="../pic/1.png" /> </body>
</html>

这样是解析不了图片的

因为在请求该html文件的时候,也请求了图片,请求图片的url如下图,而我们的判断中是没有url==='/pic/1.png'的,所以我们应该在代码中加上这个判断

else if(req.url==='/pic/1.png')//要单独请求图片
{
fs.readFile(path.join(__dirname,'pic','1.png'),function(err,data){
if(err)
{
console.log(err);
}
res.setHeader('Content-Type','image/png');//要加请求头 res.end(data);
})
}

css文件也可以这样请求,但是我们实际上不可能每个请求都要写在代码里,这样十分低效,我们可以将这些文件存在一个或者几个文件夹内,然后通过路径拼接来实现

//http加载
var http=require('http');
var path=require('path');
var fs=require('fs');
var mime=require('mime');
http.createServer(function(req,res){
//1.获取用户请求路径
//req.url
///css/index.css
///2.获取public目录完整路径
var publicDir=path.join(__dirname,'public');
//3.根据public的路径和用户请求,最终获得完整路径
var filename=path.join(publicDir,req.url);
console.log(filename);
//res.end('over');
//4.根据文件路径去读取文件,如果读取到,就将文件返回给用户,如果读取不到,返回404
fs.readFile(filename,function(err,data){
if(err){
res.end('文件不存在404');
}else{
//通过第三方模块minme,来判断不同资源对应的Content-Type类型
//filemane只要有后缀进行
res.setHeader('Content-Type',mime.getType(filename));
//如果找到了用户要读取的文件,那么直接把该文件返回给用户
res.end(data);
}
})
}).listen(9090,function(){
console.log('http://localhost:9090');
})

其中mime

node——服务器根据不同请求作出不同响应+响应html文件等文件的更多相关文章

  1. node——进阶版服务器根据不同请求作出不同响应+响应html文件等文件

    文件目录结构如下 resource文件里面放了css文件和图片等,view文件里面是html文件 <!DOCTYPE html> <html lang="en"& ...

  2. 图解HTTP权威指南(三)| Web服务器对HTTP请求的处理和响应

    作者简介   李先生(Lemon),高级运维工程师(自称),SRE专家(目标),梦想在35岁买一辆保时捷.喜欢钻研底层技术,认为底层基础才是王道.一切新技术都离不开操作系统(CPU.内存.磁盘).网络 ...

  3. http请求报文格式和响应报文格式

    转载 出处 超文本传输协议(Hypertext Transfer Protocol,简称HTTP)是应用层协议.HTTP 是一种请求/响应式的协议,即一个客户端与服务器建立连接后,向服务器发送一个请求 ...

  4. Node fs, url, http 组合小型的服务器 ( 满足html请求, get, post 传值 )

    <script type="text/javascript"> /* * 引入模块 */ var http = require('http'); var url = r ...

  5. Node.js之HTTP请求与响应

    在C#.OC中也是客户端发起一个请求,服务端作出响应.我们可以把这个过程抽象理解 . 1.客户端给服务端发起请求相当于向服务端写入一个流(writable) 2.服务端读取客户端的流(readable ...

  6. Ajax--Ajax基于原生javascript:创建Ajax对象、链接服务器、发送请求、接受响应结果

    Ajax概述 异步:指某段程序执行时不会阻塞其它程序执行,其表现形式为程序的执行顺序不依赖程序本身的书写顺序,相反则为同步. 同步请求: 请求是由浏览器发送 页面会刷新 异步请求: 请求是由浏览器的一 ...

  7. 2、node服务器

    一.简单的node服务器搭建 1.首先新建一个名为server.js的文件(文件名随意,后缀名必须是.js) 2.粘贴进文件以下内容 //引入http模块 const http = require(& ...

  8. HTTP请求过程和状态响应码

    HTTP请求过程 我们在浏览器中输入一个URL,回车之后便可以在浏览器中观察到页面内容.实际上,这个过程是浏览器向网站所在的服务器发送了一个请求,网站服务器接收到这个请求后进行处理和解析,然后返回对应 ...

  9. nodejs向远程服务器发送post请求----融云Web SDK/客户端获取token

    最近要用到一个叫融云的及时通讯的SDK,在获取token这个步骤的时候有点卡顿,以防以后碰到类似的问题,再此记录一下. 客户端通过融云 SDK 每次连接服务器时,都需要向服务器提供 Token,以便验 ...

随机推荐

  1. HMM隐马尔可夫模型(词语粘合)

    HMM用于自然语言处理(NLP)中文分词,是用来描述一个含有隐含未知参数的马尔可夫过程,其目的是希望通过求解这些隐含的参数来进行实体识别,说简单些也就是起到词语粘合的作用. HMM隐马尔可夫模型包括: ...

  2. 获取Linux ip

    第一种方法: 在终端输入命令:ifconfig ip显示为红线标注的部分. 第二种方法: 在终端输入命令:hostname -I 第三种方法: 在终端输入:ip addr show|grep &quo ...

  3. Scrum敏捷开发过程

    首先来说一下什么是敏捷开发: 敏捷开发(Agile Development)是一种以人为核心.迭代.循序渐进的开发方法. 怎么理解呢?首先,我们要理解它不是一门技术,它是一种开发方法,也就是一种软件开 ...

  4. deep learning 经典网络模型之Alexnet、VGG、Googlenet、Resnet

    CNN的发展史 上一篇回顾讲的是2006年Hinton他们的Science Paper,当时提到,2006年虽然Deep Learning的概念被提出来了,但是学术界的大家还是表示不服.当时有流传的段 ...

  5. 【ACM-ICPC 2018 南京赛区网络预赛 E】AC Challenge

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 写个DP 设f[j]表示已经做的题的状态为j的情况下接着选能获得的最大分数. 显然是个倒推. 记忆化搜索一波 dfs(i,j) 表示 ...

  6. RGB 与 (RGB转 YCbCr再转为 RGB)的图像

           RGB 与 (RGB转 YCbCr再转为 RGB)的图像   不可逆,能够从 矩阵的逆运算看出来. 附上 matlab 代码:         clc,clear; Source=imr ...

  7. boost::tuple 深入学习解说

    #include<iostream> #include<string> #include<boost/tuple/tuple.hpp> #include<bo ...

  8. HDU 1269 -- 迷宫城堡【有向图求SCC的数目 &amp;&amp; 模板】

    迷宫城堡 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submi ...

  9. Android 中View的绘制机制源代码分析 二

    尊重原创:http://blog.csdn.net/yuanzeyao/article/details/46842891 本篇文章接着上篇文章的内容来继续讨论View的绘制机制,上篇文章中我们主要解说 ...

  10. [Android 性能优化系列]内存之基础篇--Android怎样管理内存

    大家假设喜欢我的博客,请关注一下我的微博,请点击这里(http://weibo.com/kifile),谢谢 转载请标明出处(http://blog.csdn.net/kifile),再次感谢 原文地 ...