springboot-数据校验、异常处理、单元测试、打包、日志

springboot-数据校验、异常处理、单元测试、打包、日志

数据校验

在 model 增加注解 @Min(value = 18,message = "不能小于18岁")

@Entity
public class Person {

    @Id
    @GeneratedValue
    private Integer id;
    private String name;

    @Min(value = 18,message = "不能小于18岁")
    private Integer age;

    。。。setget 方法
}

在 controller 的 model 增加@Valid注解,同时可以BindingResult获取校验的信息。

@PostMapping(value = "/addPerson")
public Person addPerson(@Valid Person person, BindingResult bindingResult) {
   if (bindingResult.hasErrors()) {
       //输出错误信息:不能小于18岁
       System.out.print(bindingResult.getFieldError().getDefaultMessage());
   }
   return personRespository.save(person);
}



异常处理

定义常量枚举:ResultEnum.java

public enum ResultEnum {

    UNKNOW(-1, "未知错误"),
    OKKK(100, "小于18岁"),
    NOOO(101, "大于50岁"),;

    private Integer code;
    private String msg;

    ResultEnum(Integer code, String mag) {
        this.code = code;
        this.msg = mag;
    }

    public Integer getCode() {
        return code;
    }

    public void setCode(Integer code) {
        this.code = code;
    }

    public String getMag() {
        return msg;
    }

    public void setMag(String mag) {
        this.msg = mag;
    }
}

自定义异常类:PersonException.java

public class PersonException extends Exception {
    private Integer code;
    private String msg;

    public Integer getCode() {
        return code;
    }

    public void setCode(Integer code) {
        this.code = code;
    }

    public String getMsg() {
        return msg;
    }

    public void setMsg(String msg) {
        this.msg = msg;
    }

    public PersonException(ResultEnum resultEnum) {
        this.code = resultEnum.getCode();
        this.msg = resultEnum.getMag();
    }
}

定义返回结果类:ResultInfo.java

public class ResultInfo<T> implements Serializable {
    private int code;
    private String msg;
    private T data;

    public ResultInfo(int code, String msg) {
        this.code = code;
        this.msg = msg;
    }

    public int getCode() {
        return code;
    }

    public void setCode(int code) {
        this.code = code;
    }

    public String getMsg() {
        return msg;
    }

    public void setMsg(String msg) {
        this.msg = msg;
    }

    public T getData() {
        return data;
    }

    public void setData(T data) {
        this.data = data;
    }
}

全局异常处理类ResultExceptionHandle.java

@ControllerAdvice
public class ResultExceptionHandle {

    @ExceptionHandler(value = Exception.class)
    @ResponseBody
    public ResultInfo handleException(HttpServletRequest request, Exception e) {
        if (e instanceof PersonException) {
            PersonException personException = (PersonException) e;
            return new ResultInfo(personException.getCode(), personException.getMsg());
        }
        return new ResultInfo(-1, "未知错误");
    }
}

Controller 正常调用,全局 Exception 会自动拦截处理 HelloController.java

@RestController
public class HelloController {
    @Autowired
    private PersonRespository personRespository;

    @PostMapping(value = "/addPerson")
    public Person addPerson(@Valid Person person, BindingResult bindingResult) throws Exception {
        if (bindingResult.hasErrors()) {
            //输出错误信息
            System.out.print(bindingResult.getFieldError().getDefaultMessage());
        }
        return personService.save(person);
    }
}



单元测试

需要模拟 http 请求进行单元测试,类上要添加注解(@RunWith(SpringRunner.class)@SpringBootTest@AutoConfigureMockMvc),方法上也要添加注解(@Test),使用MockMvc进行请求模拟。

@RunWith(SpringRunner.class)
@SpringBootTest
@AutoConfigureMockMvc
public class PersonControllerTest {

    @Autowired
    private MockMvc mockMvc;

    @Test
    public void findPerson() throws Exception {
        mockMvc.perform(MockMvcRequestBuilders.get("/findPersons")).andExpect(MockMvcResultMatchers.status().isOk()).andExpect(MockMvcResultMatchers.content().string("hello"));
    }
}

打包默认会运行所有单元测试,可以通过参数跳过单元测试。



打包

如果需要打包发布应用的话,可以打包成 jar(docker用这种方式) 或者 war(老方式)
还需要在增加一个打包插件:spring-boot-maven-plugin

pom.xml

<build>
   <plugins>
       <plugin>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-maven-plugin</artifactId>
           <executions>
               <execution>
                   <goals>
                       <goal>repackage</goal>
                   </goals>
               </execution>
           </executions>
       </plugin>
   </plugins>
</build>

使用命令:

mvn package

默认在 target 目录下生成 jar 或者 war 文件,jar 可以直接使用 jdk 运行,war 需要放到 tomcatwebapp 目录下。

java -jar spring-boot-demo-1.0-SNAPSHOT.jar

日志

public static Logger logger = LoggerFactory.getLogger(HttpAspect.class);

    @Pointcut("execution(public * com.example.HelloController.*(..))")
    public void log() {

    }

    @Before("log()")
    public void logBefore() {
        logger.info("logBefore");
    }


    @After("log()")
    public void logAfter() {
        logger.info("logAfter");
    }
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot提供了很方便的数据校验功能,可以通过注解方式实现。要使用数据校验功能,首先需要在项目的pom.xml文件中添加相关的依赖。其中,我们可以使用spring-boot-starter-validation依赖来引入数据校验功能。 在代码中,我们可以使用javax.validation.constraints包中的注解来对数据进行校验。常用的注解包括@NotNull、@NotEmpty、@Size、@Min、@Max等。例如,使用@NotNull注解来标记一个字段不能为空。 首先,在需要校验的类中,添加注解@Validated,这样Spring Boot会自动校验被注解标记的字段。然后,在需要校验的字段上添加相关的校验注解,如@NotNull。最后,在Controller的方法参数上添加@Valid注解,来触发数据校验。 下面是一个示例代码,展示了如何在Spring Boot中进行数据校验。 ```java import org.springframework.validation.annotation.Validated; import javax.validation.constraints.NotNull; @RestController @Validated public class UserController { @PostMapping("/user") public String addUser(@Valid @RequestBody User user) { // 业务逻辑处理 // ... return "User added successfully"; } public class User { @NotNull private String username; // getters and setters } } ``` 在上述示例中,我们定义了一个UserController类,其中的addUser方法用于添加用户。在User类中,我们使用了@NotNull注解来标记username字段不能为空。在addUser方法的参数中,我们使用了@Valid注解来触发数据校验。 通过以上配置,当我们发送一个POST请求到"/user"的时候,Spring Boot会自动校验请求体中的数据。如果校验失败,会返回相应的错误信息。如果校验通过,会执行业务逻辑并返回成功信息。 总结一下,Spring Boot提供了简单易用的数据校验功能,可以通过注解方式实现。通过添加相应的依赖和配置,我们可以在项目中方便地使用数据校验功能,保证数据的有效性和完整性。 :https://www.jianshu.com/p/2dabf4f0b72e :https://www.baeldung.com/spring-boot-bean-validation

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值