1、新建Spring Boot 项目,引入web依赖
<dependencies>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.1.1</version>
</dependency>
<dependency>
<groupId>com.github.lenve</groupId>
<artifactId>encrypt-spring-boot-starter</artifactId>
<version>0.0.3</version>
</dependency>
</dependencies>
<repositories>
<repository>
<id>jitpack.io</id>
<url>https://jitpack.io</url>
</repository>
</repositories>
2、创建实体类用来传输数据
public class User {
private Long id;
private String name;
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "User{" +
"id=" + id +
", name='" + name + '\'' +
'}';
}
}
3、创建Controller进行测试
@RestController
public class HelloController {
@GetMapping("/user")
@Encrypt
public RespBean getUser() {
User user = new User();
user.setId((long) 99);
user.setName("java");
User user1 = (User) RespBean.ok("ok", user).getObj();
System.out.println(user1);
System.out.println(RespBean.ok("ok", user).getObj());
System.out.println(RespBean.ok("ok", user).getMsg());
return RespBean.ok("ok", user);
}
@PostMapping("/user")
@Decrypt
public RespBean addUser(@RequestBody User user) {
System.out.println("user = " + user);
return RespBean.ok("ok", user);
}
}
第一个接口使用了 @Encrypt 注解,所以会对该接口的数据进行加密(如果不使用该注解就不加密),第二个接口使用了 @Decrypt 所以会对上传的参数进行解密,注意 @Decrypt 注解既可以放在方法上也可以放在参数上。
接下来启动项目进行测试。
首先测试 get 请求接口:
控制台输出内容如下:
接下来测试post请求:
经过测试,可以看到被加密的数据已经被还原了