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
相关推荐
Zfox_3 分钟前
【Go】异常处理、泛型和文件操作
开发语言·后端·golang
zhangyanfei016 分钟前
谈谈 Golang 中的线程协程是如何管理栈内存的
开发语言·后端·golang
浪客川10 分钟前
高效日志分离器:一键筛选关键信息
开发语言·windows·c#
星竹晨L13 分钟前
C++红黑树:理论与实践相结合的平衡艺术
开发语言·数据结构·c++
itwangyang52014 分钟前
在 GitHub 上生成和配置个人访问令牌(PAT),并将其用于 R 环境中的凭证管理和包安装。
开发语言·r语言·github
宠..18 分钟前
创建文本框控件
linux·运维·服务器·开发语言·qt
Sally_xy20 分钟前
安装 Java
java·开发语言
湫兮之风21 分钟前
C++: 一文掌握std::vector::assign函数
开发语言·c++
南玖i23 分钟前
vue2/html 实现高德点聚合
开发语言·ios·swift
飞梦工作室24 分钟前
PHP 中 php://input 的全面使用指南
android·开发语言·php