378 lines
6.6 KiB
Go
378 lines
6.6 KiB
Go
package utils
|
||
|
||
import (
|
||
"bytes"
|
||
"compress/flate"
|
||
"encoding/json"
|
||
"fmt"
|
||
"goutil/logUtilPlus"
|
||
"io/ioutil"
|
||
"math/rand"
|
||
"net/http"
|
||
"runtime/debug"
|
||
"strconv"
|
||
"strings"
|
||
"time"
|
||
)
|
||
|
||
// 定义常量
|
||
var MinDateTime = time.Date(2000, 1, 1, 0, 0, 0, 0, time.Local)
|
||
var MaxDateTime = time.Date(3000, 1, 1, 0, 0, 0, 0, time.Local)
|
||
var GuidEmpty = "00000000-0000-0000-0000-000000000000"
|
||
|
||
// IsTrue
|
||
// @description: 是否为true
|
||
// parameter:
|
||
// @data: []byte格式的bool信息
|
||
// return:
|
||
// @bool: 返回布尔值
|
||
func IsTrue(data []byte) bool {
|
||
|
||
if data == nil {
|
||
return false
|
||
}
|
||
|
||
if len(data) == 0 {
|
||
return false
|
||
}
|
||
|
||
if data[0] == 0 {
|
||
return false
|
||
} else {
|
||
return true
|
||
}
|
||
}
|
||
|
||
// ConvertBooleanToBytes
|
||
// @description: bool型转换成byte数组
|
||
// parameter:
|
||
// @status: 状态
|
||
// return:
|
||
// @[]byte: 返回字节数组
|
||
func ConvertBooleanToBytes(status bool) []byte {
|
||
|
||
if status == false {
|
||
return []byte{0}
|
||
} else {
|
||
return []byte{1}
|
||
}
|
||
}
|
||
|
||
// StrSliceJoinToStr
|
||
// @description: 将[]string组装成字符串
|
||
// parameter:
|
||
// @numArray: 源int32数组
|
||
// @sep: 分割字符串
|
||
// return:
|
||
// @string: 组成的字符串
|
||
func StrSliceJoinToStr(numArray []string, sep string) string {
|
||
str := ""
|
||
if numArray == nil || len(numArray) == 0 {
|
||
return str
|
||
}
|
||
|
||
for _, n := range numArray {
|
||
str += fmt.Sprintf("%s%s", n, sep)
|
||
}
|
||
|
||
str = strings.TrimSuffix(str, sep)
|
||
|
||
return str
|
||
}
|
||
|
||
// Int32SliceJoinToStr
|
||
// @description: 将[]int32转换成字符串
|
||
// parameter:
|
||
// @source: 资源
|
||
// @sep: 分隔符
|
||
// return:
|
||
// @result: 字符串
|
||
func Int32SliceJoinToStr(source []int32, sep string) (result string) {
|
||
if source == nil || len(source) == 0 {
|
||
return ""
|
||
}
|
||
|
||
for _, s := range source {
|
||
result += fmt.Sprintf("%d%s", s, sep)
|
||
}
|
||
|
||
result = strings.TrimRight(result, sep)
|
||
|
||
return
|
||
}
|
||
|
||
// SplitToStrSlice
|
||
// @description: 将字符串切割为[]string
|
||
// parameter:
|
||
// @s: 输入字符串
|
||
// @sep: 分割字符串
|
||
// @removeEmpty: 是否去除空字符串
|
||
// return:
|
||
// @resultSlice: 字符串列表
|
||
func SplitToStrSlice(s, sep string, removeEmpty bool) (resultSlice []string) {
|
||
if len(s) == 0 {
|
||
return make([]string, 0)
|
||
}
|
||
|
||
// 先按照分隔符进行切割
|
||
strSlice := strings.Split(s, sep)
|
||
|
||
for _, value := range strSlice {
|
||
if removeEmpty {
|
||
// 去除空格
|
||
if value = strings.TrimSpace(value); value == "" {
|
||
continue
|
||
}
|
||
}
|
||
|
||
resultSlice = append(resultSlice, value)
|
||
}
|
||
|
||
return resultSlice
|
||
}
|
||
|
||
// ParseTimeString
|
||
// @description: 解析时间字符串
|
||
// parameter:
|
||
// @timeStr: 时间字符串,例:12:33:12
|
||
// return:
|
||
// @hour: 小时
|
||
// @minute: 分钟
|
||
// @second: 秒数
|
||
func ParseTimeString(timeStr string) (hour int, minute int, second int) {
|
||
timeSlice := strings.Split(timeStr, ":")
|
||
if len(timeSlice) != 3 {
|
||
return
|
||
}
|
||
|
||
hour, _ = strconv.Atoi(timeSlice[0])
|
||
minute, _ = strconv.Atoi(timeSlice[1])
|
||
second, _ = strconv.Atoi(timeSlice[2])
|
||
|
||
return
|
||
}
|
||
|
||
// Rm_duplicate_string
|
||
// @description: 去重
|
||
// parameter:
|
||
// @list: 列表
|
||
// return:
|
||
// @[]string: 去重后的数据
|
||
func Rm_duplicate_string(list []string) []string {
|
||
var x []string = []string{}
|
||
for _, i := range list {
|
||
if len(x) == 0 {
|
||
x = append(x, i)
|
||
} else {
|
||
for k, v := range x {
|
||
if i == v {
|
||
break
|
||
}
|
||
if k == len(x)-1 {
|
||
x = append(x, i)
|
||
}
|
||
}
|
||
}
|
||
}
|
||
return x
|
||
}
|
||
|
||
// Rm_duplicate_int32
|
||
// @description: 去重
|
||
// parameter:
|
||
// @list: 列表数据
|
||
// return:
|
||
// @[]int32: 去重后的结果
|
||
func Rm_duplicate_int32(list []int32) []int32 {
|
||
var x []int32 = []int32{}
|
||
for _, i := range list {
|
||
if len(x) == 0 {
|
||
x = append(x, i)
|
||
} else {
|
||
for k, v := range x {
|
||
if i == v {
|
||
break
|
||
}
|
||
if k == len(x)-1 {
|
||
x = append(x, i)
|
||
}
|
||
}
|
||
}
|
||
}
|
||
return x
|
||
}
|
||
|
||
// RandomAarrayOfInt32
|
||
// @description: int32数组乱序
|
||
// parameter:
|
||
// @arr: 数组
|
||
// return:
|
||
func RandomAarrayOfInt32(arr []int32) {
|
||
|
||
if arr == nil {
|
||
return
|
||
}
|
||
|
||
if len(arr) <= 0 {
|
||
return
|
||
}
|
||
|
||
rand.Seed(time.Now().UnixNano())
|
||
|
||
for i := len(arr) - 1; i > 0; i-- {
|
||
num := rand.Intn(i + 1)
|
||
arr[i], arr[num] = arr[num], arr[i]
|
||
}
|
||
}
|
||
|
||
// RandomAarrayOfString
|
||
// @description: string数组乱序
|
||
// parameter:
|
||
// @arr: 数组
|
||
// return:
|
||
func RandomAarrayOfString(arr []string) {
|
||
|
||
if arr == nil {
|
||
return
|
||
}
|
||
|
||
if len(arr) <= 0 {
|
||
return
|
||
}
|
||
|
||
rand.Seed(time.Now().UnixNano())
|
||
|
||
for i := len(arr) - 1; i > 0; i-- {
|
||
num := rand.Intn(i + 1)
|
||
arr[i], arr[num] = arr[num], arr[i]
|
||
}
|
||
}
|
||
|
||
// LogErrorRecover
|
||
// @description: 记录错误
|
||
// parameter:
|
||
// return:
|
||
func LogErrorRecover() {
|
||
if err := recover(); err != nil {
|
||
tmsg := fmt.Sprintf("err msg:%s stack:%s", err, debug.Stack())
|
||
logUtilPlus.ErrorLog(tmsg)
|
||
}
|
||
}
|
||
|
||
// LogReqErrorRecover
|
||
// @description: 记录错误
|
||
// parameter:
|
||
// @r:
|
||
// return:
|
||
func LogReqErrorRecover(r *http.Request) {
|
||
if err := recover(); err != nil {
|
||
b, err := json.Marshal(r)
|
||
reqStr := ""
|
||
if err == nil {
|
||
reqStr = string(b)
|
||
}
|
||
tmsg := fmt.Sprintf("RequestInfo:%s .err msg:%s stack:%s", reqStr, err, debug.Stack())
|
||
logUtilPlus.ErrorLog(tmsg)
|
||
}
|
||
}
|
||
|
||
// StringSliceIsExists
|
||
// @description: StringSliceIsExists
|
||
// parameter:
|
||
// @strList: strList
|
||
// @val: val
|
||
// return:
|
||
// @bool: 是否存在
|
||
func StringSliceIsExists(strList []string, val string) bool {
|
||
|
||
if strList == nil {
|
||
return false
|
||
}
|
||
|
||
for _, v := range strList {
|
||
if v == val {
|
||
return true
|
||
}
|
||
}
|
||
|
||
return false
|
||
}
|
||
|
||
// Int64SliceIsExists
|
||
// @description: Int64SliceIsExists
|
||
// parameter:
|
||
// @strList: strList
|
||
// @val: val
|
||
// return:
|
||
// @bool: 是否存在
|
||
func Int64SliceIsExists(strList []int64, val int64) bool {
|
||
|
||
if strList == nil {
|
||
return false
|
||
}
|
||
|
||
for _, v := range strList {
|
||
if v == val {
|
||
return true
|
||
}
|
||
}
|
||
|
||
return false
|
||
}
|
||
|
||
// SliceIsExists
|
||
// @description: SliceIsExists
|
||
// parameter:
|
||
// @n: n
|
||
// @f: f
|
||
// return:
|
||
// @bool: 是否存在
|
||
func SliceIsExists(n int, f func(int) bool) bool {
|
||
|
||
for i := 0; i < n; i++ {
|
||
if f(i) {
|
||
return true
|
||
}
|
||
}
|
||
|
||
return false
|
||
}
|
||
|
||
// FlateEncode
|
||
// @description: 压缩字符串
|
||
// parameter:
|
||
// @input: 输入字符列表
|
||
// return:
|
||
// @result: 结果字符列表
|
||
// @err: 错误信息
|
||
func FlateEncode(input []byte) (result []byte, err error) {
|
||
var buf bytes.Buffer
|
||
w, err := flate.NewWriter(&buf, flate.DefaultCompression)
|
||
if err != nil {
|
||
return nil, err
|
||
}
|
||
|
||
// 无法使用defer close使用无法拿到结果
|
||
_, err = w.Write(input)
|
||
if err != nil {
|
||
return nil, err
|
||
}
|
||
|
||
w.Close()
|
||
|
||
result = buf.Bytes()
|
||
return
|
||
}
|
||
|
||
// FlateDecode
|
||
// @description: FlateDecode
|
||
// parameter:
|
||
// @input: 输入字符列表
|
||
// return:
|
||
// @result: 结果字符列表
|
||
// @err: 错误信息
|
||
func FlateDecode(input []byte) (result []byte, err error) {
|
||
result, err = ioutil.ReadAll(flate.NewReader(bytes.NewReader(input)))
|
||
return
|
||
}
|