util.go 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. package util
  2. import (
  3. "crypto/rand"
  4. "encoding/hex"
  5. "io/ioutil"
  6. "os"
  7. "path/filepath"
  8. "reflect"
  9. "runtime"
  10. "strconv"
  11. "strings"
  12. )
  13. // 提供一些常用方法
  14. // 计算结构体大小
  15. func SizeOfStruct(data interface{}) int {
  16. return sizeof(reflect.ValueOf(data))
  17. }
  18. func sizeof(v reflect.Value) int {
  19. var sum int
  20. switch v.Kind() {
  21. case reflect.Map:
  22. sum = 0
  23. keys := v.MapKeys()
  24. for i := 0; i < len(keys); i++ {
  25. mapkey := keys[i]
  26. s := sizeof(mapkey)
  27. if s < 0 {
  28. return -1
  29. }
  30. sum += s
  31. s = sizeof(v.MapIndex(mapkey))
  32. if s < 0 {
  33. return -1
  34. }
  35. sum += s
  36. }
  37. case reflect.Slice, reflect.Array:
  38. sum = 0
  39. for i, n := 0, v.Len(); i < n; i++ {
  40. s := sizeof(v.Index(i))
  41. if s < 0 {
  42. return -1
  43. }
  44. sum += s
  45. }
  46. case reflect.String:
  47. sum = 0
  48. for i, n := 0, v.Len(); i < n; i++ {
  49. s := sizeof(v.Index(i))
  50. if s < 0 {
  51. return -1
  52. }
  53. sum += s
  54. }
  55. case reflect.Struct:
  56. sum = 0
  57. for i, n := 0, v.NumField(); i < n; i++ {
  58. s := sizeof(v.Field(i))
  59. if s < 0 {
  60. return -1
  61. }
  62. sum += s
  63. }
  64. case reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64,
  65. reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64,
  66. reflect.Float32, reflect.Float64, reflect.Complex64, reflect.Complex128,
  67. reflect.Int:
  68. sum = int(v.Type().Size())
  69. default:
  70. return 0
  71. }
  72. return sum
  73. }
  74. // 读文件
  75. func ReadFile(filename string) ([]byte, error) {
  76. fp, err := os.Open(filename)
  77. if err != nil {
  78. return nil, err
  79. }
  80. defer fp.Close()
  81. buf, err := ioutil.ReadAll(fp)
  82. if err != nil {
  83. return nil, err
  84. }
  85. return buf, nil
  86. }
  87. // 处理PDU uuid 转成字节数组
  88. func PDUUuidFromBytes(uuid string) []byte {
  89. s := strings.ReplaceAll(uuid, "-", "")
  90. b, _ := hex.DecodeString(s)
  91. r := []byte{b[3], b[2], b[1], b[0], b[5], b[4], b[7], b[6], b[8], b[9], b[10], b[11], b[12], b[13], b[14], b[15]}
  92. return r
  93. }
  94. func Random(n int) []byte {
  95. const alpha = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"
  96. var bytes = make([]byte, n)
  97. rand.Read(bytes)
  98. for i, b := range bytes {
  99. bytes[i] = alpha[b%byte(len(alpha))]
  100. }
  101. return bytes
  102. }
  103. func BytesFromHex(hexstr string) []byte {
  104. data := make([]byte, len(hexstr)/2)
  105. for i := 0; i < len(hexstr)/2; i++ {
  106. var s = hexstr[i*2 : i*2+2]
  107. num, _ := strconv.ParseInt(s, 16, 0)
  108. data[i] = byte(num)
  109. }
  110. // log.Printf("%v", data)
  111. return data
  112. }
  113. func FileExist(filePath string) bool {
  114. _, err := os.Stat(filePath)
  115. if err == nil {
  116. // path/to/whatever exists
  117. return true
  118. } else if os.IsNotExist(err) {
  119. // path/to/whatever does *not* exist
  120. // logx.Infof("not exist, path: %v, err: %v", filePath, err)
  121. return false
  122. } else {
  123. // logx.Infof("path: %v, err: %v", filePath, err)
  124. // Schrodinger: file may or may not exist. See err for details.
  125. // Therefore, do *NOT* use !os.IsNotExist(err) to test for file existence
  126. }
  127. return false
  128. }
  129. func PWDR() string {
  130. _, KSrcPath, _, _ := runtime.Caller(1)
  131. return filepath.Dir(KSrcPath)
  132. }