18.1 HTTP服务器-极简服务器、请求与响应

2024-06-11 08:52

本文主要是介绍18.1 HTTP服务器-极简服务器、请求与响应,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 极简服务器

大道至简。使用Go语言构建世界上最简单HTTP服务器,仅需四行代码。

标准库的net/http包提供了多种用于创建HTTP服务器的方法,其中包括:

  • http.HandleFunc("/", rootHandler)

第一参数:访问的url

第二参数:处理请求的函数创建路由,为不同的访问路径指定不同的处理函数

  • http.ListenAndServe(":8000", nil)
    • 启动服务,侦听给定的通信端口

针对给定访问路径的处理函数需要自己实现,该函数形如:

  • func rootHandler(w http.ResponseWriter, r *http.Request) {
  •         w.Write([]byte("Hello World!"))
  • }
  • 该函数必然包括两个参数http.ResponseWriter*http.Request
  • 该函数的两个参数一个代表响应,即用于构造响应包的写入器,用于写入返回给浏览器的信息;另一个则代表请求。
  • 该函数的核心任务就是根据请求中的各种输入数据,进行业务处理,产生响应输出。
// 最简单的HTTP服务器
// 标准库的net/http包提供了多种创建HTTP服务器的方法,它还提供了一个基本的路由器 
package mainimport "net/http"func rootHandler(w http.ResponseWriter,	// 定义路由处理函数r *http.Request) {w.Write([]byte("Hello World!"))
}func main() {http.HandleFunc("/", rootHandler)	// web资源访问地址为 "资源根路径/"http.ListenAndServe(":8000", nil)
}

 2.请求与响应

(一)使用curl发送请求:

除了通过浏览器向HTTP服务器发起请求并接收响应以外,还可以使用更专业化的工具,比如curl来查看往返于客户端和服务器之间请求响应数据包

Linux和macOS操作系统通常都预先安装了curl工具,Windows操作系统虽然没有预先安装,但可以从这里免费下载并安装:

  • https://curl.haxx.se/windows

curl安装好以后,就可以在开发HTTP服务器时,用它做客户端向服务器发送各种请求,并查看服务器的响应。

  • 首先启动前面编写的"极简服务器"程序。
    • go run main.go
  • 打开终端或命令提示符窗口,输入如下命令:
    • curl -is "http://localhost:8000"
    • 选项-is指定打印包头,并忽略一些次要信息
  • 如果命令执行成功,将看到来自HTTP服务器的响应,其中包含响应头响应体。

服务器返回的响应头包含了如下信息:

  • HTTP/1.1 200 OK //协议状态码状态描述
  • Date: Sat, 29 Dec 2018 06:28:05 GMT //发送响应的日期和时间(格林威治时间)
  • Content-Length: 12 //内容长度共12个字节
  • Content-Type: text/plain; charset=utf-8 //内容类型为使用UTF-8编码的纯文本

服务器返回的响应体包含了如下信息:

  • Hello World! //由12字节UTF-8编码纯文本构成的响应内容

(二)路由 

HandleFunc函数用于注册响应给定URL地址映射的处理函数。

  • http.HandleFunc("/", rootHandler)
  • http.HandleFunc("/users/", usersHandler)
  • http.HandleFunc("/projects/", projectsHandler)

服务器依据如下路由规则,将对特定URL地址的访问路由到相应的处理函数

  • URL地址必须完全匹配,包括大小写和斜杠。
    • 对"/projects"的访问,不会被路由到与"/projects/"相对应的处理函数projectsHandler。
  • 如果找不到严格匹配的URL地址,则一律按"/"处理,因此"/"也被称为缺省路由。
  • 路由与请求类型无关,只负责调用与URL地址相对应的函数。
    • 对每一种请求类型(GET、POST、PUT、DELETE等)的具体处理在处理函数的内部实现。

附录:CURL命令相关参数

// 附录:CURL命令的相关参数,具体使用实例不做赘述。
-a/--append 上传文件时,附加到目标文件  -A/--user-agent <string>  设置用户代理发送给服务器  - anyauth   可以使用“任何”身份验证方法  -b/--cookie <name=string/file> cookie字符串或文件读取位置  - basic 使用HTTP基本验证  -B/--use-ascii 使用ASCII /文本传输  -c/--cookie-jar <file> 操作结束后把cookie写入到这个文件中  -C/--continue-at <offset>  断点续转  -d/--data <data>   HTTP POST方式传送数据  --data-ascii <data>  以ascii的方式post数据  --data-binary <data> 以二进制的方式post数据  --negotiate     使用HTTP身份验证  --digest        使用数字身份验证  --disable-eprt  禁止使用EPRT或LPRT  --disable-epsv  禁止使用EPSV  -D/--dump-header <file> 把header信息写入到该文件中  --egd-file <file> 为随机数据(SSL)设置EGD socket路径  --tcp-nodelay   使用TCP_NODELAY选项  -e/--referer 来源网址  -E/--cert <cert[:passwd]> 客户端证书文件和密码 (SSL)  --cert-type <type> 证书文件类型 (DER/PEM/ENG) (SSL)  --key <key>     私钥文件名 (SSL)  --key-type <type> 私钥文件类型 (DER/PEM/ENG) (SSL)  --pass  <pass>  私钥密码 (SSL)  --engine <eng>  加密引擎使用 (SSL). "--engine list" for list  --cacert <file> CA证书 (SSL)  --capath <directory> CA目录 (made using c_rehash) to verify peer against (SSL)  --ciphers <list>  SSL密码  --compressed    要求返回是压缩的形势 (using deflate or gzip)  --connect-timeout <seconds> 设置最大请求时间  --create-dirs   建立本地目录的目录层次结构  --crlf          上传是把LF转变成CRLF  -f/--fail          连接失败时不显示http错误  --ftp-create-dirs 如果远程目录不存在,创建远程目录  --ftp-method [multicwd/nocwd/singlecwd] 控制CWD的使用  --ftp-pasv      使用 PASV/EPSV 代替端口  --ftp-skip-pasv-ip 使用PASV的时候,忽略该IP地址  --ftp-ssl       尝试用 SSL/TLS 来进行ftp数据传输  --ftp-ssl-reqd  要求用 SSL/TLS 来进行ftp数据传输  -F/--form <name=content> 模拟http表单提交数据  -form-string <name=string> 模拟http表单提交数据  -g/--globoff 禁用网址序列和范围使用{}和[]  -G/--get 以get的方式来发送数据  -h/--help 帮助  -H/--header <line>自定义头信息传递给服务器  --ignore-content-length  忽略的HTTP头信息的长度  -i/--include 输出时包括protocol头信息  -I/--head  只显示文档信息  从文件中读取-j/--junk-session-cookies忽略会话Cookie  - 界面<interface>指定网络接口/地址使用  - krb4 <级别>启用与指定的安全级别krb4  -j/--junk-session-cookies 读取文件进忽略session cookie  --interface <interface> 使用指定网络接口/地址  --krb4 <level>  使用指定安全级别的krb4  -k/--insecure 允许不使用证书到SSL站点  -K/--config  指定的配置文件读取  -l/--list-only 列出ftp目录下的文件名称  --limit-rate <rate> 设置传输速度  --local-port<NUM> 强制使用本地端口号  -m/--max-time <seconds> 设置最大传输时间  --max-redirs <num> 设置最大读取的目录数  --max-filesize <bytes> 设置最大下载的文件总量  -M/--manual  显示全手动  -n/--netrc 从netrc文件中读取用户名和密码  --netrc-optional 使用 .netrc 或者 URL来覆盖-n  --ntlm          使用 HTTP NTLM 身份验证  -N/--no-buffer 禁用缓冲输出  -o/--output 把输出写到该文件中  -O/--remote-name 把输出写到该文件中,保留远程文件的文件名  -p/--proxytunnel   使用HTTP代理  --proxy-anyauth 选择任一代理身份验证方法  --proxy-basic   在代理上使用基本身份验证  --proxy-digest  在代理上使用数字身份验证  --proxy-ntlm    在代理上使用ntlm身份验证  -P/--ftp-port <address> 使用端口地址,而不是使用PASV  -Q/--quote <cmd>文件传输前,发送命令到服务器  -r/--range <range>检索来自HTTP/1.1或FTP服务器字节范围  --range-file 读取(SSL)的随机文件  -R/--remote-time   在本地生成文件时,保留远程文件时间  --retry <num>   传输出现问题时,重试的次数  --retry-delay <seconds>  传输出现问题时,设置重试间隔时间  --retry-max-time <seconds> 传输出现问题时,设置最大重试时间  -s/--silent静音模式。不输出任何东西  -S/--show-error   显示错误  --socks4 <host[:port]> 用socks4代理给定主机和端口  --socks5 <host[:port]> 用socks5代理给定主机和端口  --stderr <file>  -t/--telnet-option <OPT=val> Telnet选项设置  --trace <file>  对指定文件进行debug  --trace-ascii <file> Like --跟踪但没有hex输出  --trace-time    跟踪/详细输出时,添加时间戳  -T/--upload-file <file> 上传文件  --url <URL>     Spet URL to work with  -u/--user <user[:password]>设置服务器的用户和密码  -U/--proxy-user <user[:password]>设置代理用户名和密码  -v/--verbose  -V/--version 显示版本信息  -w/--write-out [format]什么输出完成后  -x/--proxy <host[:port]>在给定的端口上使用HTTP代理  -X/--request <command>指定什么命令  -y/--speed-time 放弃限速所要的时间。默认为30  -Y/--speed-limit 停止传输速度的限制,速度时间'秒  -z/--time-cond  传送时间设置  -0/--http1.0  使用HTTP 1.0  -1/--tlsv1  使用TLSv1(SSL)  -2/--sslv2 使用SSLv2的(SSL)  -3/--sslv3         使用的SSLv3(SSL)  --3p-quote      like -Q for the source URL for 3rd party transfer  --3p-url        使用url,进行第三方传送  --3p-user       使用用户名和密码,进行第三方传送  -4/--ipv4   使用IP4  -6/--ipv6   使用IP6  -#/--progress-bar 用进度条显示当前的传送状态

 

 

 

 

 

这篇关于18.1 HTTP服务器-极简服务器、请求与响应的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1050713

相关文章

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

BUUCTF靶场[web][极客大挑战 2019]Http、[HCTF 2018]admin

目录   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 [web][HCTF 2018]admin 考点:弱密码字典爆破 四种方法:   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 访问环境 老规矩,我们先查看源代码

Linux服务器Java启动脚本

Linux服务器Java启动脚本 1、初版2、优化版本3、常用脚本仓库 本文章介绍了如何在Linux服务器上执行Java并启动jar包, 通常我们会使用nohup直接启动,但是还是需要手动停止然后再次启动, 那如何更优雅的在服务器上启动jar包呢,让我们一起探讨一下吧。 1、初版 第一个版本是常用的做法,直接使用nohup后台启动jar包, 并将日志输出到当前文件夹n

【Linux】应用层http协议

一、HTTP协议 1.1 简要介绍一下HTTP        我们在网络的应用层中可以自己定义协议,但是,已经有大佬定义了一些现成的,非常好用的应用层协议,供我们直接使用,HTTP(超文本传输协议)就是其中之一。        在互联网世界中,HTTP(超文本传输协议)是一个至关重要的协议,他定义了客户端(如浏览器)与服务器之间如何进行通信,以交换或者传输超文本(比如HTML文档)。

深入理解RxJava:响应式编程的现代方式

在当今的软件开发世界中,异步编程和事件驱动的架构变得越来越重要。RxJava,作为响应式编程(Reactive Programming)的一个流行库,为Java和Android开发者提供了一种强大的方式来处理异步任务和事件流。本文将深入探讨RxJava的核心概念、优势以及如何在实际项目中应用它。 文章目录 💯 什么是RxJava?💯 响应式编程的优势💯 RxJava的核心概念

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

速盾:直播 cdn 服务器带宽?

在当今数字化时代,直播已经成为了一种非常流行的娱乐和商业活动形式。为了确保直播的流畅性和高质量,直播平台通常会使用 CDN(Content Delivery Network,内容分发网络)服务器来分发直播流。而 CDN 服务器的带宽则是影响直播质量的一个重要因素。下面我们就来探讨一下速盾视角下的直播 CDN 服务器带宽问题。 一、直播对带宽的需求 高清视频流 直播通常需要传输高清视频

Anaconda 中遇到CondaHTTPError: HTTP 404 NOT FOUND for url的问题及解决办法

最近在跑一个开源项目遇到了以下问题,查了很多资料都大(抄)同(来)小(抄)异(去)的,解决不了根本问题,费了很大的劲终于得以解决,记录如下: 1、问题及过程: (myenv) D:\Workspace\python\XXXXX>conda install python=3.6.13 Solving environment: done.....Proceed ([y]/n)? yDownloa

简单的角色响应鼠标而移动

actor类 //处理移动距离,核心是找到角色坐标在世界坐标的向量的投影(x,y,z),然后在世界坐标中合成,此CC是在地面行走,所以Y轴投影始终置为0; using UnityEngine; using System.Collections; public class actor : MonoBehaviour { public float speed=0.1f; CharacterCo

一种改进的red5集群方案的应用、基于Red5服务器集群负载均衡调度算法研究

转自: 一种改进的red5集群方案的应用: http://wenku.baidu.com/link?url=jYQ1wNwHVBqJ-5XCYq0PRligp6Y5q6BYXyISUsF56My8DP8dc9CZ4pZvpPz1abxJn8fojMrL0IyfmMHStpvkotqC1RWlRMGnzVL1X4IPOa_  基于Red5服务器集群负载均衡调度算法研究 http://ww