我正在制作JSON验证功能,并且正在尝试实现它。但是,当我尝试将结构作为参数导入到另一个包中的验证函数时,结构出现问题。
之所以将它放在另一个程序包中,是因为我将在不同的路由文件中调用通用验证函数,因此我实际上在该程序包中没有任何结构,必须将它们导入并在路由文件中定义。
type UsersJSON struct {
Users struct {
Put []UserJSON `json:"PUT"`
} `json:"users"`
}
type UserJSON struct {
display_name string `json:"display_name"`
username string `json:"username"`
email string `json:"email"`
password string `json:"password"`
}
func MyFunc(w http.ResponseWriter, r *http.Request) {
errors, _ := schema.Validate(data, r, UsersJSON)
}
func Validate(schemaHelper interface{}) (interface{}, error) {
file, err := os.Open("config/schema/schema.json")
if err != nil {
return nil, err
}
defer file.Close()
byteValue, _ := ioutil.ReadAll(file)
var helpers schemaHelper // this is the error
json.Unmarshal(byteValue, &helpers)
fmt.Printf("%v", helpers)
}
我的JSON模式如下:
{
"users": {
"PUT": {
}
}
}
我想使这种方法有效,因为它使自动验证变得更加容易和快捷。
这无法编译,并显示错误schemaHelper is not a type
有什么办法可以解决这个问题吗?
答案 0 :(得分:2)
您正在尝试声明类型为helpers
的变量schemaHelper
,但是(至少在所示的代码中)您尚未定义任何类型的变量schemaHelper
。您有一个名为schemaHelper
的变量。您不能将类型用作变量,也不能将变量用作类型。您必须通过传递Validate
的 instance 来调用UsersJSON
,然后可以将其直接解组成JSON。看来您可能正在寻找的是这样的东西:
func MyFunc(w http.ResponseWriter, r *http.Request) {
var unmarshaled UsersJSON
errors, _ := schema.Validate(&unmarshaled)
}
func Validate(schemaHelper interface{}) (error) {
file, err := os.Open("config/schema/schema.json")
if err != nil {
return nil, err
}
defer file.Close()
byteValue, _ := ioutil.ReadAll(file)
return json.Unmarshal(byteValue, schemaHelper)
}
这会将JSON解组到变量schemaHelper
(无论类型如何)中,以供调用者按其认为合适的方式使用。请注意,这是一个粗略的最佳猜测,因为在您的问题中,对Validate
的调用传递了3个参数,但是给定的函数定义仅接受1个参数。
但是,我认为这不会像您认为的那样按照您的问题进行“验证”。它仅验证JSON在语法上是否有效,而不与您传入的struct
有任何关系-它可能具有结构中未定义的字段,可能是缺少已定义的字段,并且不会返回任何错误。
最后,类型UsersJSON
没有导出的字段(所有字段均以小写字母开头,使其成为未导出/私有的),因此无论如何都不会将其编组。 encoding/json
只能解组到导出的字段。
答案 1 :(得分:0)
您收到此错误,因为schemaHelper
不是类型。正如您在函数interface{}
中声明的那样,它实际上是类型Validate
的函数变量。