package weixinrpc import ( "encoding/json" "strconv" "time" "git.tetele.net/tgo/crypter" "github.com/golang/protobuf/proto" ) func GetAccessToken(dbname, site_id string, appid, secret string, url ...string) (*AccessTokenRes, error) { conn, err := rpc_server_conn(url...) if err != nil { return nil, err } defer conn.Close() data := AccessTokenReq{} data.SiteId = site_id data.Dbname = dbname data.Appid = appid data.Secret = secret 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.GetAccessToken(req, res) if err != nil { return nil, err } return HandleAccessToken(res) } /** * 处理返回结果 */ func HandleAccessToken(res *Response) (*AccessTokenRes, error) { //解密 res_data_de, err := GetOrgData(res) if err != nil { return nil, err } var res_arr AccessTokenRes err = json.Unmarshal([]byte(res_data_de), &res_arr) if err != nil { return nil, err } return &res_arr, nil }