印度包网
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.
 
 
 

352 lines
7.0 KiB

package base
import (
"crypto/sha512"
"encoding/json"
"fmt"
"net/url"
"reflect"
"sort"
"strings"
"github.com/gin-gonic/gin"
"github.com/liangdas/mqant/log"
)
func GetSignStr(send interface{}, pass ...string) string {
m := StructToMapJson(send)
str := []string{}
for i := range m {
if i == "sign" {
continue
}
shouldPass := false
for _, v := range pass {
if v == i {
shouldPass = true
break
}
}
if shouldPass {
continue
}
str = append(str, i)
}
sort.Strings(str)
signStr := ""
for i, v := range str {
signStr += fmt.Sprintf("%v=%v", v, m[v])
if i != len(str)-1 {
signStr += "&"
}
}
log.Debug("signStr:%s", signStr)
return signStr
}
// 包含空字段
func GetSignStrEmpty(send interface{}, pass ...string) string {
m := StructToMapJsonEmpty(send)
str := []string{}
for i := range m {
if i == "sign" {
continue
}
shouldPass := false
for _, v := range pass {
if v == i {
shouldPass = true
break
}
}
if shouldPass {
continue
}
switch m[i].(type) {
case string:
if m[i].(string) == "" {
continue
}
}
str = append(str, i)
}
sort.Strings(str)
signStr := ""
for i, v := range str {
signStr += fmt.Sprintf("%v=%v", v, m[v])
if i != len(str)-1 {
signStr += "&"
}
}
log.Debug("signStr:%s", signStr)
return signStr
}
// 连接参数时不加&符号,且不加key值,直接value拼接
func GetSignStr2(send interface{}, pass ...string) string {
m := StructToMapJson(send)
str := []string{}
for i := range m {
if i == "sign" {
continue
}
shouldPass := false
for _, v := range pass {
if v == i {
shouldPass = true
break
}
}
if shouldPass {
continue
}
str = append(str, i)
}
sort.Strings(str)
signStr := ""
for _, v := range str {
signStr += fmt.Sprintf("%v", m[v])
}
log.Debug("signStr:%s", signStr)
return signStr
}
func StructToMapJson(obj interface{}) map[string]interface{} {
t := reflect.TypeOf(obj)
v := reflect.ValueOf(obj)
if t.Kind() == reflect.Ptr {
t = t.Elem()
v = v.Elem()
}
var result = make(map[string]interface{})
for i := 0; i < t.NumField(); i++ {
if v.Field(i).Kind() == reflect.Ptr && v.Field(i).IsNil() {
continue
}
tagName := t.Field(i).Tag.Get("json")
if tagName != "" && tagName != "-" && !v.Field(i).IsZero() {
data := v.Field(i).Interface()
if v.Field(i).Kind() == reflect.Struct {
data = GetSignStr(data)
}
name := strings.Split(tagName, ",")
result[name[0]] = data
}
}
return result
}
func StructToMapJsonEmpty(obj interface{}) map[string]interface{} {
t := reflect.TypeOf(obj)
v := reflect.ValueOf(obj)
if t.Kind() == reflect.Ptr {
t = t.Elem()
v = v.Elem()
}
var result = make(map[string]interface{})
for i := 0; i < t.NumField(); i++ {
if v.Field(i).Kind() == reflect.Ptr && v.Field(i).IsNil() {
continue
}
tagName := t.Field(i).Tag.Get("json")
if tagName != "" && tagName != "-" {
data := v.Field(i).Interface()
if v.Field(i).Kind() == reflect.Struct {
data = GetSignStr(data)
}
name := strings.Split(tagName, ",")
result[name[0]] = data
}
}
return result
}
// 根据body里的字段直接拼接出签名字符串(去除null)
func GetSignStrNull(str string, pass ...string) string {
m := map[string]json.RawMessage{}
sortStrs := []string{}
json.Unmarshal([]byte(str), &m)
for i := range m {
sortStrs = append(sortStrs, i)
}
signStr := ""
sort.Strings(sortStrs)
for _, v := range sortStrs {
shouldPass := false
for _, s := range pass {
if v == s {
shouldPass = true
break
}
}
if shouldPass {
continue
}
if len(m[v]) > 1 && m[v][0] == 34 {
m[v] = m[v][1 : len(m[v])-1]
}
if len(m[v]) == 0 || string(m[v]) == "null" {
continue
}
signStr += fmt.Sprintf("%v=%v", v, string(m[v]))
signStr += "&"
}
signStr = signStr[:len(signStr)-1]
log.Debug("signStr:%v", signStr)
return signStr
}
func SHA512(data string) string {
hash := sha512.Sum512([]byte(data))
return fmt.Sprintf("%x", hash)
}
func GetSignStrGet(vals url.Values, pass ...string) string {
sortStrs := []string{}
for k := range vals {
sortStrs = append(sortStrs, k)
}
signStr := ""
sort.Strings(sortStrs)
for _, v := range sortStrs {
shouldPass := false
for _, s := range pass {
if v == s {
shouldPass = true
break
}
}
if shouldPass {
continue
}
if len(vals.Get(v)) == 0 {
continue
}
signStr += fmt.Sprintf("%v=%v", v, vals.Get(v))
signStr += "&"
}
signStr = signStr[:len(signStr)-1]
log.Debug("signStr:%v", signStr)
return signStr
}
func GetSignStrFormURLEncode(c *gin.Context, model interface{}, pass ...string) string {
sortStrs := []string{}
for k := range c.Request.URL.Query() {
sortStrs = append(sortStrs, k)
}
// ref := reflect.ValueOf(model)
reft := reflect.TypeOf(model)
if reft.Kind() == reflect.Ptr {
// ref = ref.Elem()
reft = reft.Elem()
}
signStr := ""
sort.Strings(sortStrs)
for _, v := range sortStrs {
shouldPass := false
for _, s := range pass {
if v == s {
shouldPass = true
break
}
}
if shouldPass {
continue
}
param := c.Query(v)
if len(param) == 0 {
continue
}
first := v[0]
tmpName := strings.ToUpper(string(first)) + v[1:]
field, ok := reft.FieldByName(tmpName)
if ok && field.Tag.Get("encode") == "1" { // 需要urlencode
param, _ = url.QueryUnescape(param)
}
signStr += fmt.Sprintf("%v=%v", v, param)
signStr += "&"
}
fmt.Println(signStr)
signStr = signStr[:len(signStr)-1]
log.Debug("signStr:%v", signStr)
return signStr
}
// 根据body里的字段直接拼接出签名字符串
func GetSignStrURLEncode(str string, pass ...string) string {
sortStrs := []string{}
all, err := url.ParseQuery(str)
if err != nil {
log.Error("err:%e", err)
return ""
}
for k := range all {
sortStrs = append(sortStrs, k)
}
signStr := ""
sort.Strings(sortStrs)
for _, v := range sortStrs {
shouldPass := false
for _, s := range pass {
if v == s {
shouldPass = true
break
}
}
if shouldPass {
continue
}
tmp := all.Get(v)
if len(tmp) > 1 && tmp[0] == 34 {
tmp = tmp[1 : len(tmp)-1]
}
if len(tmp) == 0 {
continue
}
signStr += fmt.Sprintf("%v=%v", v, string(tmp))
signStr += "&"
}
signStr = signStr[:len(signStr)-1]
log.Debug("signStr:%v", signStr)
return signStr
}
// 根据body里的字段直接拼接出签名字符串(去除null包含空值)
func GetSignWithStrEmpty(str string, pass ...string) string {
m := map[string]json.RawMessage{}
sortStrs := []string{}
json.Unmarshal([]byte(str), &m)
for i := range m {
sortStrs = append(sortStrs, i)
}
signStr := ""
sort.Strings(sortStrs)
for _, v := range sortStrs {
shouldPass := false
for _, s := range pass {
if v == s {
shouldPass = true
break
}
}
if shouldPass {
continue
}
if len(m[v]) > 1 && m[v][0] == 34 {
m[v] = m[v][1 : len(m[v])-1]
}
// if string(m[v]) == "null" {
// continue
// }
signStr += fmt.Sprintf("%v=%v", v, string(m[v]))
signStr += "&"
}
signStr = signStr[:len(signStr)-1]
log.Debug("signStr:%v", signStr)
return signStr
}