go语言的http post推送

go语言的网络功能比较强大,使用go语言实现http 协议的推送非常简单,这里做了个简单的post推送示例。

代码

go 复制代码
package main
 
import (
    "bytes"
    "fmt"
    "io/ioutil"
	"crypto/tls"
    "net/http"
	 "flag"  
)
 
type Data struct {
    Name string `json:"name"`
}
 
func main() {
    // JSON数据
    var payloadBytes string;
	
	var  url string
	
    flag.StringVar(&payloadBytes, "c", "", "内容")
    flag.StringVar(&url, "d", "", "url")
	flag.Parse()
	
	

	//fmt.Println(payloadBytes)
	
	bytestr := []byte(payloadBytes)
	
	//在认证的时候,忽略证书校验,
	tr := &http.Transport{
        TLSClientConfig:    &tls.Config{InsecureSkipVerify: true},
    }
	
    // HTTP POST请求
    req, err := http.NewRequest("POST", url, bytes.NewBuffer(bytestr))
    if err != nil {
        panic(err)
    }
 
    // 设置Content-Type头部信息
    req.Header.Set("Content-Type", "application/json")
 
    // 创建客户端并发送请求
    client := &http.Client{Transport: tr}
    resp, err := client.Do(req)
    if err != nil {
        panic(err)
    }
    defer resp.Body.Close()
 
    // 获取响应结果
    body, _ := ioutil.ReadAll(resp.Body)
    responseString := string(body)
 
    // 输出响应结果
    fmt.Println(responseString)
}

测试运行:

bash 复制代码
go run main.go -d http://192.168.1.168/cgi-bin/file/post -c "{\"test\": 1}"
{"code": "200"}  --收到的应答消息

//服务端接收的信息:
method: POST
data: {"test": 1}

总结

以上代码里,使用flag来获取命令行传递的入参。

在认证的时候,忽略服务端证书校验,

go 复制代码
	tr := &http.Transport{
        TLSClientConfig:    &tls.Config{InsecureSkipVerify: true},
    }  

这里如果不忽略,可能会报如下错误:

bash 复制代码
x509: certificate signed by unknown authority
相关推荐
ephemerals__1 分钟前
【c++丨STL】list模拟实现(附源码)
开发语言·c++·list
码农飞飞5 分钟前
深入理解Rust的模式匹配
开发语言·后端·rust·模式匹配·解构·结构体和枚举
一个小坑货6 分钟前
Rust 的简介
开发语言·后端·rust
湫ccc14 分钟前
《Python基础》之基本数据类型
开发语言·python
Matlab精灵15 分钟前
Matlab函数中的隐马尔可夫模型
开发语言·matlab·统计学习
Microsoft Word16 分钟前
c++基础语法
开发语言·c++·算法
数据小爬虫@18 分钟前
如何利用java爬虫获得淘宝商品评论
java·开发语言·爬虫
qq_1728055926 分钟前
RUST学习教程-安装教程
开发语言·学习·rust·安装
wjs202433 分钟前
MongoDB 更新集合名
开发语言
monkey_meng37 分钟前
【遵守孤儿规则的External trait pattern】
开发语言·后端·rust