go进行http,get或postJson请求

1,http封装get,postJson类

go 复制代码
package httpUtil

import (
	"bytes"
	logxx "go-gift-panel/src/log"
	"io"
	"io/ioutil"
	"net/http"
)

func PostJson(url string, jsonData []byte) string {
	logxx.Log.Info("请求的url=", url, " 请求的JSON Data:", string(jsonData))         // 输出 JSON 格式的数据
	resp, err := http.Post(url, "application/json", bytes.NewBuffer(jsonData)) // 发起 POST 请求
	if err != nil {
		logxx.Log.Error("ERROR postJson请求异常 http.Post err:", err)
		return "e"
	}
	defer func(Body io.ReadCloser) {
		err := Body.Close()
		if err != nil {
			logxx.Log.Error("ERROR postJson请求异常 Body.Close err:", err)
		}
	}(resp.Body)
	body, err := ioutil.ReadAll(resp.Body) // 读取响应内容
	if err != nil {
		logxx.Log.Error("ERROR postJson读取body异常 ioutil.ReadAll err:", err)
		return "e"
	}
	logxx.Log.Info("请求返回内容 Response Body:", string(body), " Response Status:", resp.Status) // 输出响应内容
	return string(body)
}

func Get(url string) {
	logxx.Log.Info("请求的url=", url) // 输出
	resp, err := http.Get(url)     // 发起 GET 请求
	if err != nil {
		logxx.Log.Error("ERROR Get请求异常 http.Post err:", err)
		return
	}
	defer func(Body io.ReadCloser) {
		err := Body.Close()
		if err != nil {
			logxx.Log.Error("ERROR Get请求异常 Body.Close err:", err)
		}
	}(resp.Body)
	body, err := ioutil.ReadAll(resp.Body) // 读取响应内容
	if err != nil {
		logxx.Log.Error("ERROR Get读取body异常:", err)
		return
	}
	logxx.Log.Info("请求返回内容 Response Body:", string(body), " Response Status:", resp.Status) // 输出响应内容
}

2,日志logxx类

go 复制代码
package logxx

import (
	"github.com/sirupsen/logrus"
	"gopkg.in/natefinch/lumberjack.v2"
	"io"
	"os"
)

var Log = logrus.New()

// var file *os.File

func Init() {

	logFile := &lumberjack.Logger{
		Filename:   "/data/giftpanel/logs/giftpanel_.log",
		MaxSize:    100,   // megabytes 单个文件大小100MB
		MaxBackups: 100,   //保留100个文件
		MaxAge:     60,    //days	保留60天
		Compress:   false, // 是否压缩 便于查询不压缩
		LocalTime:  true,  //true使用本地时区
	}
	// 设置日志级别
	Log.SetLevel(logrus.InfoLevel)

	// 设置输出文件名和代码行号
	Log.SetReportCaller(true)
	// 设置日志格式为JSON格式
	Log.SetFormatter(&logrus.JSONFormatter{
		TimestampFormat: "2006-01-02 15:04:05.000", // 设置时间格式,包括毫秒
	})

	Log.SetOutput(logFile)
	// 设置同时输出到控制台和文件
	Log.SetOutput(io.MultiWriter(os.Stdout, logFile))
}
相关推荐
follycat2 小时前
[极客大挑战 2019]HTTP 1
网络·网络协议·http·网络安全
tyler_download3 小时前
golang 实现比特币内核:处理椭圆曲线中的天文数字
golang·blockchain·bitcoin
earthzhang20213 小时前
《深入浅出HTTPS》读书笔记(5):随机数
网络协议·http·https
xiaoxiongip6663 小时前
HTTP 和 HTTPS
网络·爬虫·网络协议·tcp/ip·http·https·ip
CXDNW3 小时前
【网络面试篇】HTTP(2)(笔记)——http、https、http1.1、http2.0
网络·笔记·http·面试·https·http2.0
疯狂的程需猿4 小时前
一个百度、必应搜索引擎图片获取下载的工具包
golang·图搜索
城南vision5 小时前
计算机网络——HTTP篇
网络协议·计算机网络·http
明月看潮生5 小时前
青少年编程与数学 02-003 Go语言网络编程 09课题、Cookie
青少年编程·golang·网络编程·编程与数学
明月看潮生6 小时前
青少年编程与数学 02-003 Go语言网络编程 15课题、Go语言URL编程
开发语言·网络·青少年编程·golang·编程与数学
明月看潮生6 小时前
青少年编程与数学 02-003 Go语言网络编程 14课题、Go语言Udp编程
青少年编程·golang·网络编程·编程与数学