知识点

阿里云OSS

Alibaba Cloud OSS

Web端直传

数据校验

前端校验

前端使用的是ElementUI,可以直接使用其提供的表单验证,可以参考ElementUI-表单验证官方文档

后端校验

SpringBoot数据校验可以使用javax.validation.constraints包下的规则,其实现了JSR303规范

可以参考CSDN博文Java数据校验:JSR-303

  1. 基础使用:在实体类上打上相应注解,并在Controller中使用@Valid注解即可使用。

  2. 分组:为校验规则分组,注解字段为groups,需要传入注解类型的Class,以应对复杂的校验场景。

  3. 自定义校验器:可以自定义校验规则,案例代码参考自定义校验

全局异常处理

使用@ControllerAdvice注解与@ExceptionHandler,案例代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
import cn.insectmk.common.exception.BizCodeEnum;
import cn.insectmk.common.utils.R;
import lombok.extern.slf4j.Slf4j;
import org.springframework.validation.BindingResult;
import org.springframework.web.bind.MethodArgumentNotValidException;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.RestControllerAdvice;
import java.util.HashMap;
import java.util.Map;

@RestControllerAdvice
@Slf4j
public class GulimallExceptionControllerAdvice {
/**
* 数据校验错误处理
* @param e
* @return
*/
@ExceptionHandler(value = MethodArgumentNotValidException.class)
public R handleValidException(MethodArgumentNotValidException e) {
log.error("数据校验出现问题{},异常类型{}", e.getMessage(), e.getClass());

Map<String, String> errors = new HashMap<>();
BindingResult bindingResult = e.getBindingResult();
bindingResult.getFieldErrors().forEach(fieldError -> {
errors.put(fieldError.getField(), fieldError.getDefaultMessage());
});

return R.error(BizCodeEnum.VALID_EXCEPTION.getCode(), BizCodeEnum.VALID_EXCEPTION.getMsg()).put("data", errors);
}

/**
* 处理全局未知异常
* @param e
* @return
*/
@ExceptionHandler(value = Throwable.class)
public R handleException(Throwable e) {
log.error("系统出现未知问题{},异常类型{}", e.getMessage(), e.getClass());
return R.error(BizCodeEnum.UNKNOWN_EXCEPTION.getCode(), BizCodeEnum.UNKNOWN_EXCEPTION.getMsg());
}
}

Vue2子组件向父组件传递数据

可以参考Vue子组件向父组件传值(this.$emit()方法)「建议收藏」

  1. 子组件使用this.$emit('event-name', arg1, arg2,...)触发事件。
  2. 父组件在子组件引用标签上使用@event-name="callback(arg1, arg2, ...)"来接收子组件传递的数据。

Object划分

持久对象

PO(persistant object) 持久对象

PO 就是对应数据库中某个表中的一条记录,多个记录可以用PO 的集合。PO 中应该不包含任何对数据库的操作。

领域对象

DO(Domain Object)领域对象

就是从现实世界中抽象出来的有形或无形的业务实体。

数据传输对象

TO(Transfer Object) 数据传输对象

不同的应用程序之间传输的对象

数据传输对象

DTO(Data Transfer Object)数据传输对象

这个概念来源于J2EE 的设计模式,原来的目的是为了EJB 的分布式应用提供粗粒度的数据实体,以减少分布式调用的次数,从而提高分布式调用的性能和降低网络负载。

但在这里,泛指用于展示层与服务层之间的数据传输对象。

值对象

VO(value object) 值对象

通常用于业务层之间的数据传递,和PO 一样也是仅仅包含数据而已。但应是抽象出的业务对象, 可以和表对应, 也可以不, 这根据业务的需要。用new 关键字创建,由GC 回收的。View object:视图对象;接受页面传递来的数据,封装对象将业务处理完成的对象,封装成页面要用的数据

业务对象

BO(business object) 业务对象

从业务模型的角度看, 见UML 元件领域模型中的领域对象。封装业务逻辑的java 对象, 通过调用DAO 方法, 结合PO,VO 进行业务操作。

business object: 业务对象主要作用是把业务逻辑封装为一个对象。这个对象可以包括一个或多个其它的对象。

比如一个简历,有教育经历、工作经历、社会关系等等。我们可以把教育经历对应一个PO ,工作经历对应一个PO ,社会关系对应一个PO 。

建立一个对应简历的BO 对象处理简历,每个BO 包含这些PO 。这样处理业务逻辑时,我们就可以针对BO 去处理。

简单无规则java 对象

POJO(plain ordinary java object) 简单无规则java 对象

传统意义的java 对象。就是说在一些Object/Relation Mapping 工具中,能够做到维护数据库表记录的persisent object 完全是一个符合Java Bean 规范的纯Java 对象,没有增加别的属性和方法。

我的理解就是最基本的java Bean ,只有属性字段及setter 和getter方法!。

POJO 是DO/DTO/BO/VO 的统称。

数据访问对象

DAO(data access object) 数据访问对象

是一个sun 的一个标准j2ee 设计模式, 这个模式中有个接口就是DAO ,它负持久层的操作。为业务层提供接口。

此对象用于访问数据库。通常和PO 结合使用, DAO 中包含了各种数据库的操作方法。通过它的方法, 结合PO 对数据库进行相关的操作。

夹在业务逻辑与数据库资源中间。配合VO, 提供数据库的CRUD 操作。

SpringMVC分工

  1. Controller处理请求,接收和校验数据
  2. Service接收Controller传来的数据,进行业务处理
  3. Controler接受Service处理完的数据,封装页面指定的VO对象