Go语言HTTP/2探险之旅

本文探讨Go语言如何实现HTTP/2服务器及客户端功能。默认情况下,Go的HTTP服务器支持HTTP/2,通过创建 TLS 连接启用。文中详细介绍了启用HTTP/2服务器和客户端的步骤,包括解决自签名证书问题。此外,还讨论了HTTP/2的服务器推送和全双工通信特性,虽然Go的标准库客户端目前不支持服务器推送,但能实现全双工通信。最后,文章提供了一些代码示例来展示这些功能的实现。
摘要由CSDN通过智能技术生成

女主宣言

大家都知道,Go的标准库HTTP服务器默认支持HTTP/2。那么,在这篇文章中,我们将首先展示Go的http/2服务器功能,并解释如何将它们作为客户端使用。

PS:丰富的一线技术、多元化的表现形式,尽在“HULK一线技术杂谈”,点关注哦!

在这篇文章中,我们将首先展示Go的http/2服务器功能,并解释如何将它们作为客户端使用。Go的标准库HTTP服务器默认支持HTTP/2。

 

HTTP/2 服务器

首先,让我们在Go中创建一个http/2服务器!根据http/2文档,所有东西都是为我们自动配置的,我们甚至不需要导入Go的标准库http2包:

HTTP/2强制使用TLS。为了实现这一点,我们首先需要一个私钥和一个证书。在Linux上,下面的命令执行这个任务。

openssl req -newkey rsa:2048 -nodes -keyout server.key -x509 -days 365 -out server.crt

该命令将生成两个文件:server.key 以及 server.crt

现在,对于服务器代码,以最简单的形式,我们将使用Go的标准库HTTP服务器,并启用TLS与生成的SSL文件。

package main

import (
   "log"
   "net/http"
)

func main()
{
   // 在 8000 端口启动服务器
   // 确切地说,如何运行HTTP/1.1服务器。

   srv := &http.Server{Addr:":8000", Handler: http.HandlerFunc(handle)}
   // 用TLS启动服务器,因为我们运行的是http/2,它必须是与TLS一起运行。
   // 确切地说,如何使用TLS连接运行HTTP/1.1服务器。    log.Printf("Serving on https://0.0.0.0:8000")
   log.Fatal(srv.ListenAndServeTLS(
"server.crt", "server.key")) }

func handle(w http.ResponseWriter, r *http.Request) {
   // 记录请求协议    log.Printf("Got connection: %s", r.Proto)
   // 向客户发送一条消息    w.Write([]byte("Hello")) }
 

HTTP/2 客户端

在go中,标准 http.Client 也用于http/2请求。惟一的区别是在客户端的Transport字段,使用 http2.Transport 代替 http.Transport。

我们生成的服务器证书是“自签名”的,这意味着它不是由一个已知的证书颁发机构(CA)签署的。这将导致我们的客户端不相信它:

package main

import (
   "fmt"
   "net/http"
)

const url
= "https://localhost:8000"

func main() {    _, err := http.Get(url)
   fmt.Println(err) }

让我们试着运行它:

$ go run h2-client.go 
Get https://localhost:8000: x509: certificate signed by unknown authority
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值