知识点

阿里云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对象