rabbitmq rpc 消息格式及调用封装
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

65 lines
1.1 KiB

  1. package rabbitmqrpc
  2. import (
  3. "encoding/json"
  4. "log"
  5. "strconv"
  6. "time"
  7. "git.tetele.net/tgo/crypter"
  8. "github.com/golang/protobuf/proto"
  9. )
  10. func Send(exchange, key string, data interface{}, url ...string) (*MsgSend, error) {
  11. conn, err := rpc_server_conn(url...)
  12. if err != nil {
  13. return nil, err
  14. }
  15. defer conn.Close()
  16. arg_data, err := json.Marshal(data)
  17. if err != nil {
  18. log.Println("json marshal error:", err)
  19. }
  20. arg := MsgBody{}
  21. arg.Exchange = exchange
  22. arg.Key = key
  23. arg.Data = string(arg_data)
  24. data_json, err := json.Marshal(arg)
  25. if err != nil {
  26. return nil, err
  27. }
  28. now_int64 := time.Now().Unix()
  29. encryData := crypter.DesEn(string(data_json), DES_KEY)
  30. now := strconv.FormatInt(now_int64, 10)
  31. sign := Sign(encryData, now)
  32. req := &Request{proto.String(encryData), proto.String(now), proto.String(sign), nil}
  33. res := &Response{}
  34. err = conn.Send(req, res)
  35. if err != nil {
  36. return nil, err
  37. }
  38. res_data, err := GetOrgData(res)
  39. var res_arr MsgSend
  40. err = json.Unmarshal([]byte(res_data), &res_arr)
  41. if err != nil {
  42. return nil, err
  43. }
  44. return &res_arr, nil
  45. }