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()
}
相关文章
|
20天前
|
Go
go创建web服务
go创建web服务
22 4
|
2天前
|
前端开发 API 开发者
Python Web开发者必看!AJAX、Fetch API实战技巧,让前后端交互如丝般顺滑!
【7月更文挑战第13天】在Web开发中,AJAX和Fetch API是实现页面无刷新数据交换的关键。在Flask博客系统中,通过创建获取评论的GET路由,我们可以展示使用AJAX和Fetch API的前端实现。AJAX通过XMLHttpRequest发送请求,处理响应并在成功时更新DOM。Fetch API则使用Promise简化异步操作,代码更现代。这两个工具都能实现不刷新页面查看评论,Fetch API的语法更简洁,错误处理更直观。掌握这些技巧能提升Python Web项目的用户体验和开发效率。
15 7
|
22天前
|
前端开发 JavaScript API
探索现代Web开发中的动态数据交互——前端与后端整合实战
本文探讨了现代Web开发中前端与后端整合的关键技术点,通过实际案例演示了如何利用JavaScript和Node.js实现动态数据交互,全面解析从数据请求到响应的全过程。
|
19天前
|
中间件 开发者 C++
Django中间件探索:揭秘中间件在Web应用中的守护角色与实战应用
Django中间件探索:揭秘中间件在Web应用中的守护角色与实战应用
|
23天前
|
存储 Apache 文件存储
在Apache环境下为Web网站增设访问控制:实战指南
在Apache服务器上保护网站资源涉及启用访问控制模块(`mod_authz_core`和`mod_auth_basic`),在`.htaccess`或`httpd.conf`中设定权限,如限制对特定目录的访问。创建`.htpasswd`文件存储用户名和密码,并使用`htpasswd`工具管理用户。完成配置后重启Apache服务,访问受限目录时需提供有效的用户名和密码。对于高安全性需求,可考虑更复杂的认证方法。【6月更文挑战第20天】
75 4
|
23天前
|
安全 Ubuntu 应用服务中间件
NGINX环境下实现Web网站访问控制的实战指南
在NGINX中设置基于IP的访问控制可提升网站安全性。步骤包括安装NGINX、备份配置文件、编辑`/etc/nginx/sites-available/default`,添加`allow`和`deny`指令限制特定IP访问,如`allow 192.168.1.100; deny all;`,然后测试配置并重启服务。成功后,仅允许的IP能访问网站,否则会收到403错误。这为Web安全提供基础保障,还可扩展实现更多高级控制策略。【6月更文挑战第20天】
86 3
|
26天前
|
消息中间件 存储 监控
go语言并发实战——日志收集系统(六) 编写日志收集系统客户端
go语言并发实战——日志收集系统(六) 编写日志收集系统客户端
|
7天前
|
移动开发 前端开发 JavaScript
Web表单(Form)开发实战指南
【7月更文挑战第8天】表单(Form)是Web应用程序中不可或缺的组成部分,用于收集用户输入的数据。本指南将详细介绍HTML表单的基本结构、数据提交方式、表单验证以及如何使用JavaScript和CSS增强表单的交互性和美观性。
44 0
|
1月前
|
前端开发 JavaScript 开发工具
Web网页前端教程免费:引领您踏入编程的奇幻世界
Web网页前端教程免费:引领您踏入编程的奇幻世界
19 3
|
1月前
|
JSON 安全 关系型数据库
Web实战丨基于django+hitcount的网页计数器
Web实战丨基于django+hitcount的网页计数器
29 5