diff --git a/mp_userinfo.client.go b/mp_userinfo.client.go new file mode 100644 index 0000000..e09a1cd --- /dev/null +++ b/mp_userinfo.client.go @@ -0,0 +1,78 @@ +package weixinrpc + +import ( +"encoding/json" +"log" +"strconv" +"time" +"git.tetele.net/tgo/crypter" +"github.com/golang/protobuf/proto" +) + +func GetMpUserInfo(accessToken,openId string,url ...string) (*MpUserInfoRes, error) { + + conn, err := rpc_server_conn(url...) + if err != nil { + return nil, err + } + defer conn.Close() + + data := MpUserInfoReq{} + data.AccessToken = accessToken + data.Openid = openId + data.Lang = "zh_CN" + + data_json, err := json.Marshal(data) + if err != nil { + return nil, err + } + + encryData := crypter.DesEn(string(data_json), DES_KEY) + + now_int64 := time.Now().Unix() + + 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.GetMpUserInfo(req, res) + + if err != nil { + return nil, err + } + + return HandleMpUserInfo(res) + +} + +/** + * 处理返回结果 + */ +func HandleMpUserInfo(res *Response) (*MpUserInfoRes, error) { + + //解密 + res_data_de, err := GetOrgData(res) + + if err != nil { + return nil, err + } + + var res_arr MpUserInfoRes + + err = json.Unmarshal([]byte(res_data_de), &res_arr) + + if err != nil { + log.Println(err, res_data_de) + return nil, err + } + + return &res_arr, nil +}