0

0

如何使用Golang实现HTTP请求_Golang net/http包客户端方法

P粉602998670

P粉602998670

发布时间:2026-01-22 06:09:30

|

332人浏览过

|

来源于php中文网

原创

应显式构造带超时的 *http.Client,避免使用 http.Get;正确用 url.Values 拼接参数并 Set Header;禁用或自定义重定向逻辑;复用连接需配置 Transport 连接池;务必检查 resp.StatusCode 和 resp.Body。

如何使用golang实现http请求_golang net/http包客户端方法

Go 的 net/http 包自带的 HTTP 客户端足够轻量、可靠,不需要额外引入第三方库就能完成绝大多数请求任务;但直接用 http.Gethttp.Post 容易忽略超时控制、重定向策略、Header 设置等关键细节,导致线上请求卡死或行为异常。

如何避免 http.Get 导致程序永久阻塞

http.Get 底层使用的是默认的 http.DefaultClient,而它的 Timeout 字段为 0 —— 即不设超时。一旦目标服务无响应或网络中断,goroutine 就会一直挂起。

  • 永远不要在生产环境直接调用 http.Gethttp.Post
  • 必须显式构造带超时的 *http.Client,例如:
    client := &http.Client{
        Timeout: 10 * time.Second,
    }
  • 若需更精细控制(如分别设置连接、读、写超时),用 http.Transport 配置:
    client := &http.Client{
        Transport: &http.Transport{
            DialContext: (&net.Dialer{
                Timeout:   5 * time.Second,
                KeepAlive: 30 * time.Second,
            }).DialContext,
            TLSHandshakeTimeout: 5 * time.Second,
            ResponseHeaderTimeout: 5 * time.Second,
        },
    }

如何正确设置请求头与 URL 参数

Go 不像 Python 的 requests 那样自动拼接 query string 或合并 headers;所有手动构造都需谨慎,尤其注意键名大小写和编码

  • url.Values 是拼接 query 的标准方式,它会自动做 URL 编码:
    params := url.Values{}
    params.Set("q", "golang http")
    params.Set("page", "1")
    resp, err := client.Get("https://api.example.com/search?" + params.Encode())
  • Header 必须通过 req.Header.Set() 设置,且 key 会按规范首字母大写(如 "Content-Type"),不能直接赋值 req.Header["Content-Type"]
  • POST 表单请求应设 Content-Type: application/x-www-form-urlencoded,并用 strings.NewReader(params.Encode()) 传 body

如何处理重定向与 302/307 状态码

默认 http.Client 会自动跟随最多 10 次重定向,但某些场景(如调试登录跳转、抓取含中间页的资源)需要禁用或自定义逻辑。

Thiings
Thiings

免费的拟物化图标库

下载

立即学习go语言免费学习笔记(深入)”;

  • 禁用重定向:将 CheckRedirect 设为返回 http.ErrUseLastResponse
    client := &http.Client{
        CheckRedirect: func(req *http.Request, via []*http.Request) error {
            return http.ErrUseLastResponse
        },
    }
  • 若需记录跳转路径,可在 CheckRedirect 中打印 req.URL,但注意该函数在重定向前调用,req.URL 是下一个要访问的地址
  • 307 和 308 会保持原请求方法(如 POST 不会变 GET),而 301/302 默认转为 GET —— 这是 RFC 规范行为,不是 Go 特有

如何复用 TCP 连接提升性能

高频请求下,每次新建 TCP 连接开销显著;http.Transport 的连接池默认开启,但需确认配置未被意外关闭。

  • 确保没有设置 DisableKeepAlives: true
  • 调整连接池参数可应对高并发:
    Transport: &http.Transport{
        MaxIdleConns:        100,
        MaxIdleConnsPerHost: 100,
        IdleConnTimeout:     30 * time.Second,
    }
  • 注意:DefaultClient 的连接池是全局共享的,多个业务共用时可能相互影响;建议按用途分 Client 实例
  • HTTP/2 默认启用(只要服务端支持),无需额外配置,但要求 TLS 或 localhost 场景

最常被忽略的是:错误处理只检查 err != nil 不够,必须进一步检查 resp.StatusCoderesp.Body 是否为 nil;很多 “成功” 的 resp 其实是 4xx/5xx 状态,body 可能含错误详情。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

769

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

661

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

764

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

659

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1325

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

549

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

579

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

730

2023.08.11

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

1

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 11.4万人学习

Django 教程
Django 教程

共28课时 | 3.3万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号