Introduction

If you execute the previous example code several times, you will find that the returned results are unordered, and the order of the fields and rules is completely random. Even if we use other methods like FirstItem, FirstString() to obtain validation results, they are the same, and the returned validation results are not fixed. This is because the rules we pass are of the map type, and the map type in golang does not have order, so the validation results are random, and the same validation method may return different result values each time it is executed.

Sequential Validation

Let’s improve the above example: If the validation result does not satisfy the required rule, it returns the corresponding error message; otherwise, it returns the subsequent validation error message. In other words, the returned error messages should be consistent with the sequence defined in the rules. As follows:

  1. package main
  2. import (
  3. "fmt"
  4. "github.com/gogf/gf/v2/frame/g"
  5. "github.com/gogf/gf/v2/os/gctx"
  6. )
  7. func main() {
  8. var (
  9. ctx = gctx.New()
  10. params = map[string]interface{}{
  11. "passport": "",
  12. "password": "123456",
  13. "password2": "1234567",
  14. }
  15. rules = []string{
  16. "passport@required|length:6,16#账号不能为空|账号长度应当在{min}到{max}之间",
  17. "password@required|length:6,16|same:password2#密码不能为空|密码长度应当在{min}到{max}之间|两次密码输入不相等",
  18. "password2@required|length:6,16#",
  19. }
  20. )
  21. err := g.Validator().Rules(rules).Data(params).Run(ctx)
  22. if err != nil {
  23. fmt.Println(err.Map())
  24. fmt.Println(err.FirstItem())
  25. fmt.Println(err.FirstError())
  26. }
  27. }

After execution, the terminal output:

  1. map[length:账号长度应当在616之间 required:账号不能为空]
  2. passport map[length:账号长度应当在616之间 required:账号不能为空]
  3. 账号不能为空

As you can see, if we want the validation results to maintain order, we just need to change the type of the rules parameter to []string and set them according to a certain rule. Furthermore, the msgs parameter can be defined directly in the rules parameter or passed separately (using a third parameter). For detailed rules on writing validation rules in rules, please refer to the chapter Struct Validation - Example.