Go Web编程实战(9)----创建客户端

简介: Go Web编程实战(9)----创建客户端

创建一个客户端


Go语言的net/http包中,还提供了一个被称为Client的结构体。该结构体提供了Get()、Post()两个请求函数。下面,我们来分别使用代码实现这些请求。


Get()请求

首先,我们来看一下Get()请求函数的定义,以及其内部的调用逻辑:

func Get(url string) (resp *Response, err error) {
  return DefaultClient.Get(url)
}
func (c *Client) Get(url string) (resp *Response, err error) {
  req, err := NewRequest("GET", url, nil)
  if err != nil {
  return nil, err
  }
  return c.Do(req)
}


可以发现,其真实调用的函数其实是NewRequest(),其实Post请求也是一样,之需要将NewRequest()函数的第一个参数改为“POST”即可。


下面,我们来实现Get()请求:

package main
import (
  "fmt"
  "io/ioutil"
  "net/http"
)
func main() {
  resp, err := http.Get("https://blog.csdn.net/liyuanjinglyj")
  if err != nil {
  fmt.Println(err)
  }
  closer := resp.Body
  bytes, err := ioutil.ReadAll(closer)
  fmt.Println(string(bytes))
}


运行之后,控制台会打印我的CSDN主页的HTML文档内容。


Post()请求

Post()请求稍微比Get()请求复杂点,这里我们直接上代码:

package main
import (
  bytes2 "bytes"
  "fmt"
  "io/ioutil"
  "net/http"
)
func main() {
  url := "http://httpbin.org/post"
  body := "{\"name\",\"liyuanjing\",\"age\",29}"
  response, err := http.Post(url, "application/x-www-form-urlencoded", bytes2.NewBuffer([]byte(body)))
  if err != nil {
  fmt.Println(err)
  }
  bytes, err := ioutil.ReadAll(response.Body)
  fmt.Println(string(bytes))
}


运行之后,控制台会返回你传递的参数内容,这里就不展示了。


当然,还有PUT与DELETE请求。不过,在实际的应用中比较少,这里直接忽略。


请求头设置

在我们进行各种爬虫以及获取网页各种数据时,为了伪装自己是浏览器,常常需要设置各种类型的请求头。而Go语言给我们提供Header类型。


下面,我们来定义一个User-Agent请求头,因为我们是自己设置的Header,所以需要直接使用NewRequest()方法。

package main
import (
  "fmt"
  "io/ioutil"
  "net/http"
)
func main() {
  client := &http.Client{}
  request, err := http.NewRequest("Get", "https://www.baidu.com/", nil)
  request.Header.Add("User-Agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/99.0.4844.51 Safari/537.36")
  if err != nil {
  fmt.Println(err)
  }
  resp, _ := client.Do(request)
  closer := resp.Body
  bytes, err := ioutil.ReadAll(closer)
  fmt.Println(string(bytes))
  defer resp.Body.Close()
}
相关文章
|
1月前
|
存储 人工智能 Go
Go-Zero全流程实战即时通讯
Go-Zero 是一个功能丰富的微服务框架,适用于开发高性能的即时通讯应用。它具备中间件、工具库和代码生成器,简化开发流程。本文介绍其环境搭建、项目初始化及即时通讯功能实现,涵盖用户认证、消息收发和实时推送,帮助开发者快速上手。
164 0
|
1月前
|
数据采集 Go API
Go语言实战案例:多协程并发下载网页内容
本文是《Go语言100个实战案例 · 网络与并发篇》第6篇,讲解如何使用 Goroutine 和 Channel 实现多协程并发抓取网页内容,提升网络请求效率。通过实战掌握高并发编程技巧,构建爬虫、内容聚合器等工具,涵盖 WaitGroup、超时控制、错误处理等核心知识点。
|
1月前
|
Go 开发者
Go语言实战案例:使用select监听多个channel
本文为《Go语言100个实战案例 · 网络与并发篇》第5篇,详解Go并发核心工具`select`的使用。通过实际案例讲解如何监听多个Channel、实现多任务处理、超时控制和非阻塞通信,帮助开发者掌握Go并发编程中的多路异步事件处理技巧。
|
1月前
|
数据采集 编解码 监控
Go语言实战案例:使用channel实现生产者消费者模型
本文是「Go语言100个实战案例 · 网络与并发篇」第4篇,通过实战案例详解使用 Channel 实现生产者-消费者模型,涵盖并发控制、任务调度及Go语言并发哲学,助你掌握优雅的并发编程技巧。
|
1月前
|
数据采集 消息中间件 编解码
Go语言实战案例:使用 Goroutine 并发打印
本文通过简单案例讲解 Go 语言核心并发模型 Goroutine,涵盖协程启动、输出控制、主程序退出机制,并结合 sync.WaitGroup 实现并发任务同步,帮助理解 Go 并发设计思想与实际应用。
|
1月前
|
数据采集 JSON Go
Go语言实战案例:实现HTTP客户端请求并解析响应
本文是 Go 网络与并发实战系列的第 2 篇,详细介绍如何使用 Go 构建 HTTP 客户端,涵盖请求发送、响应解析、错误处理、Header 与 Body 提取等流程,并通过实战代码演示如何并发请求多个 URL,适合希望掌握 Go 网络编程基础的开发者。
|
2月前
|
JSON 前端开发 Go
Go语言实战:创建一个简单的 HTTP 服务器
本篇是《Go语言101实战》系列之一,讲解如何使用Go构建基础HTTP服务器。涵盖Go语言并发优势、HTTP服务搭建、路由处理、日志记录及测试方法,助你掌握高性能Web服务开发核心技能。
|
2月前
|
存储 算法 数据可视化
Go语言实战:图的邻接表表示法实现详解
本文是《Go语言100个实战案例》系列之一,讲解图的邻接表表示法及其在Go语言中的实现。适用于稀疏图,节省空间,适合初学者与进阶开发者学习图结构在工程中的应用。
|
2月前
|
机器学习/深度学习 存储 算法
Go语言实战案例-广度优先遍历BFS
广度优先遍历(BFS)是一种层级展开的搜索策略,常用于树与图的遍历、最短路径查找、二维数组中的感染扩散等问题。它借助队列实现,优先访问当前层所有节点,再进入下一层,适用于寻找最短路径、层序遍历、岛屿问题等场景。
|
2月前
|
算法 Go C++
Go语言实战案例-深度优先遍历DFS
深度优先遍历(DFS)是一种用于遍历图和树结构的重要算法,其核心思想是“一条路走到底”,即沿着每个分支尽可能深入,直到无法继续再回溯。在树中,DFS包括前序、中序和后序三种遍历方式;在图中,DFS可用于寻找路径、计算连通分量、拓扑排序等。该算法通常通过递归或栈实现,适用于解决岛屿数量、迷宫路径、括号生成等经典问题。本文还对比了DFS与BFS的区别,并介绍了其在不同场景下的应用与实现方法。

热门文章

最新文章