Image 2 Image 3 Image 3 Image 3

写一个简单的server

频道:行业资讯 日期: 浏览:749

服务器我们也有了,就是我们的电脑。但我们还没有提供HTTP的程序,用脚本就可以提供HTTP服务,不管是Bash脚本还是Node.js脚本都可以做到,不过貌似Bash脚本非常反人类,那我们就用node.js脚本试试吧~重点:熟悉server运行过程,不是熟悉js语法!

一、Node.js server

1、接收请求

mkdir node-demo

cd node-demo

touch server.js

编辑server.js,这里我们直接用curl命令将网页下载进去就好 →代码
写一个简单的server

接着我们来用cat命令查看一下是否已经下载进去了~

写一个简单的server

我们可以看到一大堆代码已经打印进去啦~

好了,那我们就赶紧node 一下运行看看吧

写一个简单的server

会出现报错,然后根据报错调整指令就好啦(至于为什么会报错?当然是为了让你记住node的时候不要忘记写上端口啊,多加了一行if端口不存在的指令你心里没点数吗hhhhhhh)

好了,如图我们已经成功运行了,接下来呢?没有接下来了,这个服务器会保持运行,无法退出,所以我们新开一个bash窗口吧~

目前此服务器只有一个功能,打印路径,查询字符串的功能接下来,我们就发送请求到服务器(自己向自己发送请求,听起来有点怪,但也没办法,我们又不能财大气粗的去买个服务器(摊手))curl http://localhost

: 8888

localhost是你的本地IP127.0.0.1

所以你也可以:

curl http://127.0.0.1 :8888

我们马上就得到了server打印出的路径,说明我们收到了curl发出的请求,但是server没有发出回应,而我们的curl就一直等着~

写一个简单的server

2、发出响应

接下来别让我们的curl傻傻的等待了,我们来让server回应吧

1. 编辑server.js

2. 在中间标注区 添加下面话

response.write(hi)

response.end()

这两句话意思就是,回应hi,然后回应结束。我们快来试试~

中断先前的server,用<kbd>ctrl</kbd>+<kbd>c</kbd>终止,编辑完毕后,重新node

我们来看看会发生什么:

写一个简单的server

我们收到了hi ,也看到了完整的请求和回应~(这个可以输入curl -s -v -- ""命令来查看)

接下来我们来做一个真正的响应网页ba

当我们请求 / 时,会返回 html 内容

该 html 内容里面由一个 css link 和一个 script

css link 会请求 /style.css,返回 css 内容

script 会请求 /main.js,返回 js 内容

请求 / /style.css /main.js 这三个以外的路径,则一律返回 404 状态码
if(path == /style.css){ //如果路径是style.css,那么执行下面 response.setHeader(Content-Type , text/css; charset=utf-8) //规定格式为css response.write(body{background-color: #ccc;}h1{color: pink;}) //写入内容 response.end() }else if(path == /main.js){ //如果路径为main.js,那么执行下面 response.setHeader(Content-Type , text/javascript; charset=utf-8) //规定格式js response.write(alert("我是JS执行的")) response.end() }else if(path == / ){ //如果路径是/ ,那么执行下面,你看,后缀没有用的,我们是下面定义格式的。 response.setHeader(content-Type , text/html; charset=utf-8) //规定格式html response.write(<!DOCTYPE>\n<html> + <head><link rel="stylesheet" href="/style.css"> + </head><body><h1>你好 cy</h1> + <script src="/script"></script> + </body></html>) }else { response.statusCode = 404 //返回状态404 response.end()}
写一个简单的server

好,我们运行server,然后curl一下~

请求style.css ,是不是返回了我们写入的内容

写一个简单的server

请求 / 是不是返回了内容~

写一个简单的server

再试一下其他路径,看能不能返回404状态码

写一个简单的server

也成功啦~

那我们网站访问一下吧~

ok~大功告成~(欢迎纠错~)

0 留言

评论

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。
验证码