写一个简单的server

作者: 长鲸向南 | 来源:发表于2018-07-09 14:10 被阅读3次
  1. 服务器我们也有了,就是我们的电脑。

  2. 但我们还没有提供HTTP的程序,用脚本就可以提供HTTP服务,不管是Bash脚本还是Node.js脚本都可以做到,不过貌似Bash脚本非常反人类,那我们就用node.js脚本试试吧~

  3. 重点:熟悉server运行过程,不是熟悉js语法!

一、Node.js server

1、接收请求

mkdir node-demo cd node-demo touch server.js 编辑server.js,这里我们直接用curl命令将网页下载进去就好 →代码

image

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

image

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

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

image

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

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

  • 目前此服务器只有一个功能,打印路径,查询字符串的功能

  • 接下来,我们就发送请求到服务器(自己向自己发送请求,听起来有点怪,但也没办法,我们又不能财大气粗的去买个服务器(摊手))

curl http://localhost : 8888 localhost是你的本地IP127.0.0.1

所以你也可以:

curl http://127.0.0.1 :8888

image

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

image

2、发出响应

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

1. 编辑server.js

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

response.write('hi') response.end()

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

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

我们来看看会发生什么:

image

我们收到了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()}
image

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

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

image

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

image

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

image

也成功啦~

那我们网站访问一下吧~

image

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

相关文章

  • Socket 入门使用

    简单的写一个Socket Server: Socket Client:

  • 写一个简单的server

    服务器我们也有了,就是我们的电脑。 但我们还没有提供HTTP的程序,用脚本就可以提供HTTP服务,不管是Bash脚...

  • aidl的一个简单demo

    demo目的:写两个简单demo,Client和Server,Server提供计算两数之和的服务,Client去调...

  • 用java写一个最简单的http Server

    How to create HTTP Server in Java 建立web server,监听8080端口上的...

  • Cookie与登录注册

    首先,写一个简单的注册页面sign_up.html(前端) 把用户输入的内容放到一个哈希中(前端) 给server...

  • socket-学习

    1.一个简单的socket连接 server client

  • 写一个简易的server

    在桌面创建一个server.js文件并写下如下代码: 运行node server 启动这个服务器 新开一个bash...

  • 创建一个简单的server

  • webpack跨域

    webpack数据获取问题实践 新建server.js写一个简单的后台服务 1.跨域在devServer中添加 2...

  • Netty简单入门

    软件要求 最新版本Netty JDK1.6以上 写一个Discard Server 在这个世界上最简单的协议不是 ...

网友评论

    本文标题:写一个简单的server

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