支持gzip解析数据

This commit is contained in:
白茶清欢 2021-08-06 20:13:02 +08:00
parent 6baa3bc05e
commit 1f3456a7e1
3 changed files with 34 additions and 9 deletions

View File

@ -16,5 +16,7 @@ type Server struct {
Scheme string // 转发scheme Scheme string // 转发scheme
Host string // 服务器地址 Host string // 服务器地址
URI string // 转发接口 URI string // 转发接口
RewriteHeader map[string]string // 重写header RewriteRequestHeader map[string]string // 重写请求header
RewriteResponseHeader map[string]string // 重写响应header
RewriteResponseData map[string]string // 重写响应数据
} }

View File

@ -8,11 +8,15 @@
package proxy package proxy
import ( import (
"compress/gzip"
"fmt" "fmt"
"io" "io"
"io/ioutil"
"net" "net"
"net/http" "net/http"
"strings" "strings"
"git.zhangdeman.cn/zhangdeman/gopkg/safe"
) )
// Forward 正向代理的实现 // Forward 正向代理的实现
@ -37,7 +41,7 @@ func Forward(rw http.ResponseWriter, req *http.Request, serverConfig *Server) {
} }
// 写入重写的请求Header // 写入重写的请求Header
for k, v := range serverConfig.RewriteHeader { for k, v := range serverConfig.RewriteRequestHeader {
outReq.Header.Set(k, v) outReq.Header.Set(k, v)
} }
@ -46,6 +50,7 @@ func Forward(rw http.ResponseWriter, req *http.Request, serverConfig *Server) {
outReq.URL.Path = serverConfig.URI outReq.URL.Path = serverConfig.URI
outReq.URL.Scheme = serverConfig.Scheme outReq.URL.Scheme = serverConfig.Scheme
outReq.URL.Host = serverConfig.Host outReq.URL.Host = serverConfig.Host
// step 2 // step 2
res, err := transport.RoundTrip(outReq) res, err := transport.RoundTrip(outReq)
if err != nil { if err != nil {
@ -61,6 +66,24 @@ func Forward(rw http.ResponseWriter, req *http.Request, serverConfig *Server) {
} }
rw.WriteHeader(res.StatusCode) rw.WriteHeader(res.StatusCode)
// 重写请求header
for k, v := range serverConfig.RewriteResponseHeader {
rw.Header().Set(k, v)
}
// 重写响应数据
if !strings.Contains(strings.ToLower(res.Header.Get("Content-Type")), "application/json") || nil == serverConfig.RewriteResponseData || len(serverConfig.RewriteResponseData) == 0 {
io.Copy(rw, res.Body) io.Copy(rw, res.Body)
} else {
var responseData []byte
var gzipData io.Reader
gzipData, err = gzip.NewReader(res.Body)
responseData, err = ioutil.ReadAll(gzipData)
fmt.Println(string(responseData), err)
formatData, _ := safe.Filter(responseData, serverConfig.RewriteResponseData)
rw.Write(formatData)
}
res.Body.Close() res.Body.Close()
} }

View File

@ -18,18 +18,18 @@ import (
// Author : go_developer@163.com<白茶清欢> // Author : go_developer@163.com<白茶清欢>
// //
// Date : 6:40 下午 2021/3/10 // Date : 6:40 下午 2021/3/10
func Filter(source []byte, filter []string) ([]byte, error) { func Filter(source []byte, filter map[string]string) ([]byte, error) {
var ( var (
bt []byte bt []byte
setErr error setErr error
) )
for _, item := range filter { for result, item := range filter {
fieldList := strings.Split(item, ".") fieldList := strings.Split(item, ".")
val, _, _, err := jsonparser.Get(source, fieldList...) val, _, _, err := jsonparser.Get(source, fieldList...)
if nil != err { if nil != err {
return nil, err return nil, err
} }
if bt, setErr = jsonparser.Set(bt, val, fieldList...); nil != setErr { if bt, setErr = jsonparser.Set(bt, val, strings.Split(result, ".")...); nil != setErr {
return nil, setErr return nil, setErr
} }
} }