up:: SpringBoot电商项目用户模块枚举类和枚举数据类型
说明:
(1) 本篇博客合理性说明:【首先,项目的接口,无论处理成功与否,都会返回一些东西】→【而,接口的返回格式,是要求统一的】→【为此,既然接口的返回格式是统一的,那么我们就可以创建一个统一返回对象】→【那么,以后当我们在处理接口返回的时候,就可以使用这个统一返回对象】→【这样做,既规范,效率也高】;
(2) 本篇博客需要注意点:
● 【API统一返回对象】的编写,十分重要;
● 使用枚举类,来管理接口返回错误的策略,十分重要;
1.【接口的返回】要求格式统一;
其中:
(1)“status”是一个状态码,是一个数字;不同的数字,代表不同的情况;后面我们也会用不同的状态码,去代表不同的异常;
(2)“msg”是一个描述信息,可以明确的告诉前端【这次请求后端接口,是成功了还是失败了】;
(3)“data”是最重要的部分,“data”是接口返回的信息;
2.为此,我们可以创建一个【统一返回对象】:ApiRestResponse类;
ApiRestResponse类:
说明:
(1) 因为返回中的“data”类型不固定,所以【统一返回对象】类设为了一个泛型类,“data”属性的类型设置为了泛型类型;
有关自定义泛型类的内容,如有需要可以参考【自定义泛型类】及附近相关文章;
(2) 因为,大部分情况下,前端请求接口时,都是成功的;所以,这儿我们就先定义了【请求接口成功时,“status”和“msg”应该有的值】;
(3) 根据业务情况,创建构造函数;
(4) 创建方法来应对:接口处理成功,且接口没有返回数据,即“data”为null的情况;
有关自定义泛型方法的内容,如有需要可以参考【自定义泛型方法】及附近相关文章;
(5) 创建方法来应对:接口处理成功,且接口有返回数据,即“data”有值的情况;
(6) 创建方法来应对:接口处理失败时的情况;(这儿是,没有使用枚举类的情况;所以,这种方式不推荐)
(7) 但是,这种失败时,直接传入失败时的code和msg的方式,不推荐使用;因为这种自己写方式,有点麻烦,而且非常不利于维护(比如都是“密码错误”这个错误,A程序员可能写成【code=10001,msg=“密码错误”】,B程序员可能写成【code=80019,msg=“密码不正确”】);我们更希望把一些常见的错误给统一一下,放在一个地方;这样的话,我们遇到某个错误时,直接去拿就行了,而不用自己去写了;而,我们可以利用枚举类来做这个事情;
ImoocMallExceptionEnum枚举类:
因为这个枚举类的作用是,用来定义【接口处理失败时,错误码和错误信息】的,所以这个枚举类定义了“code”和“msg”两个属性;并且,这儿先定义了几个常见的错误情况的枚举;自然,这个枚举类需要有有参构造和set和get方法;
有关枚举和枚举类的内容,可以参考【SpringBoot电商项目用户模块枚举类和枚举数据类型】中的内容;
(8) 创建方法来应对:接口处理失败时的情况;(这儿是,使用了枚举类的情况;所以,推荐使用这种方式)
能够感受到,这种通过枚举类来统一管理错误信息的方式,十分规整,不易出错;程序规范性好,而且效率也高;
(9) 有的时候,在调试的时候,我们需要看看ApiRestResponse对象的内容;所以,这儿我们重写了toString()方法;