编写目的
在我们的项目登陆模块中,往往在执行登陆代码后,其会返回一个状态码,而根据返回的状态码的不同,我们return对应的结果到前台界面。
因为状态码可能有多种情况,因而在返回的方法中我们不停的用if...else if...
根据每个if
条件的不同,返回不同的结果。这样虽然可以满足业务上的需求,但是代码不简洁,不便于开发人员后期对代码的维护。因而我觉得有必要写一个工具类,通过该类,直接在执行登陆代码后,根据其返回的状态码,直接返回对应的结果。
在这里,我使用了遍历枚举的方法来返回所需的结果,而谈到枚举,这就需要我们了解枚举有哪些特性。在这里,我将枚举的特性罗列如下:
Enum看起来很象是特殊的class,其地位与class、interface等同。 它也可以有自己的变量,可以定义自己的方法,可以实现一个或者多个接口。 当我们在声明一个enum类型时,我们应该注意到enum类型有如下的一些特征。
1、它不能有public的构造函数,这样做可以保证客户代码没有办法新建一个enum的实例。
2、所有枚举值都是public , static , final的。注意这一点只是针对于枚举值,我们可以和在普通类里面定义 变量一样定义其它任何类型的非枚举变量,这些变量可以用任何你想用的修饰符。
3、Enum默认实现了java.lang.Comparable接口。
4、Enum覆载了了toString方法,因此我们如果调用Color.Blue.toString()默认返回字符串”Blue”.
5、Enum提供了一个valueOf方法,这个方法和toString方法是相对应的。调用valueOf(“Blue”)将返回Color.Blue.因此我们在自己重写toString方法的时候就要注意到这一点,一把来说应该相对应地重写valueOf方法。
6、Enum还提供了values方法,这个方法使你能够方便的遍历所有的枚举值。
7、Enum还有一个oridinal的方法,这个方法返回枚举值在枚举类种的顺序,这个顺序根据枚举值声明的顺序而定,这里Color.Red.ordinal()返回0
源码
依赖
<!-- junit-5单元测试依赖 -->
<dependency>
<groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter-api</artifactId>
<version>5.3.2</version>
<scope>test</scope>
</dependency>
<!-- lombok插件 -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.4</version>
<scope>provided</scope>
</dependency>
<!-- 整合log4j2与slf4j -->
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-slf4j-impl</artifactId>
<version>2.10.0</version>
</dependency>
<!-- log4j2核心类 -->
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>2.10.0</version>
</dependency>
项目源码
CommonType源码:
package com.lyc.common;
import lombok.AllArgsConstructor;
import lombok.Getter;
public class CommonType {
/**
* 登陆状态
*/
@Getter
@AllArgsConstructor
public enum LoginStatus{
LOGIN_SUCCESS("登陆成功!",0),
USERNAME_NOT_NULL("用户名不能为空!",1),
USERNAME_ERROR("用户名错误!",2),
PASSWORD_NOT_NULL("密码不能为空!",3),
PASSWORD_ERROR("密码错误!",4),
AUTH_CODE_NOT_NULL("验证码不能为空!",5),
AUTH_CODE_ERROR("验证码错误!",6),
USER_IS_NULL("账号不存在!",7),
ROLES_IS_NULL("角色不存在!",8),