| @ -0,0 +1,62 @@ | |||
| package siterpc | |||
| import ( | |||
| "encoding/json" | |||
| "strconv" | |||
| "time" | |||
| "git.tetele.net/tgo/crypter" | |||
| "github.com/golang/protobuf/proto" | |||
| ) | |||
| /** | |||
| * 由配置key取对应value | |||
| * 请求及回均加密验签 | |||
| * 2021/01/20 | |||
| * GZ | |||
| */ | |||
| func GetAllSite(url ...string) ([]map[string]string, error) { | |||
| conn, err := rpc_server_conn(url...) | |||
| if err != nil { | |||
| return nil, err | |||
| } | |||
| defer conn.Close() | |||
| now_int64 := time.Now().Unix() | |||
| encryData := crypter.DesEn("get_from_cache", DES_KEY) | |||
| now := strconv.FormatInt(now_int64, 10) | |||
| sign := Sign(encryData, now) | |||
| req := &Request{proto.String(encryData), proto.String(now), proto.String(sign), nil} | |||
| res := &Response{} | |||
| err = conn.GetAllSite(req, res) | |||
| if err != nil { | |||
| return nil, err | |||
| } | |||
| res_data, err := GetOrgData(res) | |||
| if err != nil { | |||
| return []map[string]string{}, err | |||
| } | |||
| var res_arr []map[string]string | |||
| err = json.Unmarshal([]byte(res_data), &res_arr) | |||
| if err != nil { | |||
| return []map[string]string{}, err | |||
| } | |||
| return res_arr, nil | |||
| } | |||
| @ -0,0 +1,13 @@ | |||
| package siterpc | |||
| import ( | |||
| "testing" | |||
| ) | |||
| func Test_GetAllSite(t *testing.T) { | |||
| res, err := GetAllSite() | |||
| t.Log(res) | |||
| t.Log(err) | |||
| } | |||
| @ -1,3 +1,17 @@ | |||
| package siterpc | |||
| var DES_KEY = "confdata" | |||
| func rpc_server_conn(url ...string) (*SiteServiceClient, error) { | |||
| var wx_rpc_url string = "127.0.0.1:7971" | |||
| if len(url) > 0 && url[0] != "" { | |||
| wx_rpc_url = url[0] | |||
| } | |||
| conn, _, err := DialSiteService("tcp", wx_rpc_url) | |||
| if err != nil { | |||
| return nil, err | |||
| } | |||
| return conn, nil | |||
| } | |||
| @ -0,0 +1,10 @@ | |||
| module git.tetel.net/tgo/siterpc | |||
| go 1.14 | |||
| require ( | |||
| git.tetele.net/tgo/crypter v0.2.2 // indirect | |||
| github.com/chai2010/protorpc v1.0.0 // indirect | |||
| github.com/golang/protobuf v1.5.2 // indirect | |||
| golang.org/x/crypto v0.0.0-20210616213533-5ff15b29337e // indirect | |||
| ) | |||
| @ -0,0 +1,24 @@ | |||
| git.tetele.net/tgo/crypter v0.2.2 h1:YMQJh2Gj5Po4ZfelJUmXBKi01UbmtiSy3bmqRfnYQMo= | |||
| git.tetele.net/tgo/crypter v0.2.2/go.mod h1:vfvRLZA8+lHNgNXneOcgvVhDyuv25ZRb+C6xHOmXNx0= | |||
| github.com/chai2010/protorpc v1.0.0 h1:aJ45G9sl1utSKo35EqnBSTs5jqTpdJDJAuZMMYPAtFo= | |||
| github.com/chai2010/protorpc v1.0.0/go.mod h1:woR3WwjaQDqFjlzdVsFEKiK5Ur12QL8mYxVPjfr5z54= | |||
| github.com/golang/protobuf v1.0.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= | |||
| github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk= | |||
| github.com/golang/protobuf v1.5.2 h1:ROPKBNFfQgOUMifHyP+KYbvpjbdoFNs+aK7DXlji0Tw= | |||
| github.com/golang/protobuf v1.5.2/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY= | |||
| github.com/golang/snappy v0.0.0-20170215233205-553a64147049 h1:K9KHZbXKpGydfDN0aZrsoHpLJlZsBrGMFWbgLDGnPZk= | |||
| github.com/golang/snappy v0.0.0-20170215233205-553a64147049/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q= | |||
| github.com/google/go-cmp v0.5.5 h1:Khx7svrCpmxxtHBq5j2mp/xVjsi8hQMfNLvJFAlrGgU= | |||
| github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= | |||
| golang.org/x/crypto v0.0.0-20210616213533-5ff15b29337e h1:gsTQYXdTw2Gq7RBsWvlQ91b+aEQ6bXFUngBGuR8sPpI= | |||
| golang.org/x/crypto v0.0.0-20210616213533-5ff15b29337e/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= | |||
| golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= | |||
| golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | |||
| golang.org/x/sys v0.0.0-20210615035016-665e8c7367d1/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | |||
| golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= | |||
| golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= | |||
| golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= | |||
| golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= | |||
| google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw= | |||
| google.golang.org/protobuf v1.26.0 h1:bxAC2xTBsZGibn2RTntX0oH50xLsqy1OxA9tTL3p/lk= | |||
| google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc= | |||
| @ -0,0 +1,77 @@ | |||
| package siterpc | |||
| import ( | |||
| "crypto/md5" | |||
| "encoding/hex" | |||
| "errors" | |||
| "strconv" | |||
| "strings" | |||
| "time" | |||
| "git.tetele.net/tgo/crypter" | |||
| ) | |||
| /** | |||
| * 签名 | |||
| */ | |||
| func Sign(data string, salt string) string { | |||
| var build strings.Builder | |||
| build.WriteString(data) | |||
| build.WriteString(salt) | |||
| build.WriteString("site55sign33") | |||
| data_str := build.String() | |||
| h := md5.New() | |||
| h.Write([]byte(data_str)) // 需要加密的字符串 | |||
| return hex.EncodeToString(h.Sum(nil)) // 输出加密结果 | |||
| } | |||
| /** | |||
| * 验证签名 | |||
| */ | |||
| func CheckSign(sign_str, data, salt string) bool { | |||
| sign := Sign(data, salt) | |||
| if strings.Compare(sign_str, sign) > -1 { | |||
| return true | |||
| } | |||
| return false | |||
| } | |||
| /** | |||
| * 解密 | |||
| */ | |||
| func GetOrgData(res *Response) (string, error) { | |||
| res_data := res.GetData() | |||
| if res_data == "" { | |||
| return "", errors.New("未收到收据") | |||
| } | |||
| time_int64, err := strconv.ParseInt(res.GetTime(), 10, 64) | |||
| if err != nil { | |||
| return "", err | |||
| } | |||
| now_int64 := time.Now().Unix() | |||
| if now_int64-time_int64 > 10 || time_int64-now_int64 > 10 { | |||
| //时间误差前后10秒,返回 | |||
| return "", errors.New("返回时间错误") | |||
| } | |||
| check_sign := CheckSign(res.GetSign(), res_data, res.GetTime()) | |||
| if !check_sign { | |||
| return "", errors.New("返回数据签名错误") | |||
| } | |||
| //解密 | |||
| res_data_de := crypter.DesDe(res_data, DES_KEY) | |||
| return res_data_de, nil | |||
| } | |||