package model import ( "cu-helper/cus-eng-con-sys/cryptokit" "reflect" ) /* /zjgd/frm/acceptanceComfirmController/backFlow */ /* 用途:撤回交付 */ type BackFlow struct { DeliveryId string `map:"deliveryId"` ParentProcInsId string `map:"parentProcInsId"` Ranstr string `map:"ranstr"` Timestamp string `map:"timestamp"` } func NewBackFlow(deliveryId, parenProcInsId string) *BackFlow { backFlow := new(BackFlow) backFlow.DeliveryId = deliveryId backFlow.ParentProcInsId = parenProcInsId backFlow.Ranstr = cryptokit.RandomStr(true, 10, 32) backFlow.Timestamp = cryptokit.GetTimeStamp() return backFlow } func (th *BackFlow) GenReqParam() map[string]string { th.encrypt() return th.structToMap() } func (th *BackFlow) structToMap() map[string]string { result := make(map[string]string) t := reflect.TypeOf(*th) v := reflect.ValueOf(*th) for i := 0; i < t.NumField(); i++ { field := t.Field(i) value := v.Field(i) // Use the tag value as the key in the map, if it exists; otherwise, use the field name. tag := field.Tag.Get("map") if tag == "" { tag = field.Name } result[tag] = value.String() } return result } func (th *BackFlow) encrypt() { v := reflect.ValueOf(th).Elem() for i := 0; i < v.NumField(); i++ { field := v.Field(i) if field.CanSet() { field.SetString(cryptokit.Encrypt(field.String())) } } }