model层不允许使用 json,构体格式 dto层又重复造轮子,问题一个表的中结字段可能20个左右,那么赋值语句难受死了。构体格式
其次就是问题json直接解析,model层的中结time.Time,完蛋格式不对,构体格式返回的问题数据不对。
比如
{ "user_name": "xiaoli",中结 "create_time": "2020-06-05T13:53:06.293614+08:00" }这种情况,无法解决,构体格式就需要必须重写一个dto。问题
那么如何解决这个问题呢,中结本人思考了一段时间,构体格式最终使用Map来解决。问题
那么反射会遇到,各种奇葩的书写方式,有些人什么都出传入指针,有些人各种interface{ } 隐藏转换,反正就是太过于差异化。
所以就是需要解决,如何准确的拿到Value对象,下面是我写的一个工具类
func GetRealValue(value reflect.Value) reflect.Value { kind := value.Kind() if kind == reflect.Ptr { return GetRealValue(value.Elem()) } if kind == reflect.Interface { // eg:var s2 interface{ } // s2 = User{ } // fmt.Println(reflect.ValueOf(&s2).Elem().Kind())// interface // 所以这里需要将它转换 if value.CanInterface() { return GetRealValue(reflect.ValueOf(value.Interface())) } return GetRealValue(value.Elem()) } return value }解决这个问题,开干
2、下划线命名法下划线如何解决,结构体的字段属于驼峰命名法,网站模板怎么解决呢?
写了一个简单的工具类
问题:
如果是ID,连续大写,输出i_d 因为数组到切片需要拷贝一次,所以可以利用unsafe解决,因为字符串底层就是切片,但是不安全 func CamelCase(s string) string { if s == "" { return "" } t := make([]byte, 0, 32) i := 0 for ; i < len(s); i++ { c := s[i] if isASCIIDigit(c) { t = append(t, c) continue } if isASCIIUpper(c) { c ^= } t = append(t, c) for i+1 < len(s) && isASCIIUpper(s[i+1]) { i++ t = append(t, _, s[i]+32) } } //return *(*string)(unsafe.Pointer(&t)) return string(t) } func isASCIIUpper(c byte) bool { return A <= c && c <= Z } func isASCIIDigit(c byte) bool { return 0 <= c && c <= 9 }输出结果:
完美,美中不足是需要使用likedMap,由于Golang源码包没有,所以,注定乱序
{ "create_time":"2020-06-05 14:05:31","user_name":"xiaoli"} 站群服务器