36-案例:百度网盘密码数据兼容处理
需求分析
需求:对百度网盘分享链接输入密码时尾部多输入的空格做兼容处理。
问题描述:
- 当我们从别人发给我们的内容中复制提取码的时候,有时候会多复制到一些空格,直接粘贴到百度的提取码输入框
- 但是百度那边记录的提取码是没有空格的
- 这个时候如果不做处理,直接对比的话,就会引发提取码不一致,导致无法访问百度盘上的内容
- 所以多输入一个空格可能会导致项目的功能无法正常使用。
- 此时我们就想能不能将输入的参数先帮用户去掉空格再操作呢?
- 答案是可以的,我们只需要在业务方法执行之前对所有的输入参数进行格式处理——trim()
- 那要对所有的参数都需要去除空格么?
- 也没有必要,一般只需要针对字符串处理即可
- 以后涉及到需要去除前后空格的业务可能会有很多,这个去空格的代码是每个业务都写么?
- 可以考虑使用AOP来统一处理
- AOP有五种通知类型,该使用哪种呢?
- 我们的需求是将原始方法的参数处理后,再使用处理后的参数参与原始方法的调用,能做这件事的就只有环绕通知(环绕通知是唯一一种能够让你在方法执行之前修改参数,然后使用修改后的参数继续执行原始方法的通知类型)
环境准备
- 创建一个Maven项目
- pom.xml添加Spring依赖
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.2.10.RELEASE</version>
</dependency>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.9.4</version>
</dependency>
- 添加ResourcesDao和ResourcesDaoImpl,ResourcesService,ResourcesServiceImpl类
public interface ResourcesDao {
//传入url和提取码
boolean readResource(String url,String password);
}
@Repository
public class ResourceDaoImpl implements ResourcesDao {
@Override
public boolean readResource(String url, String password) {
//模拟校验
return password.equals("root");
}
}
public interface ResourceService {
public boolean openURL(String url,String password);
}
@Service
public class ResourceServiceImpl implements ResourceService {
@Autowired
private ResourcesDao resourcesDao;
@Override
public boolean openURL(String url, String password) {
//向dao层传入用户输入的数据,并根据dao层的返回值判断是否打开链接
return resourcesDao.readResource(url, password);
}
}
- 创建Spring配置类
@Configuration
@ComponentScan("com.yolo")
public class SpringConfig {
}
- 编写App运行类
public class App {
public static void main(String[] args) {
AnnotationConfigApplicationContext ctx = new AnnotationConfigApplicationContext(SpringConfig.class);
ResourceService service = ctx.getBean(ResourceService.class);
boolean flag = service.openURL("https://pan.baidu.com/xx", "root");
System.out.println(flag);
}
}
现在项目的效果是,当输入密码为”root”
控制台打印为true,如果密码改为"root "
控制台打印的是false
需求是使用AOP将参数进行统一处理,不管输入的密码root前后包含多少个空格,最终控制台打印的都是true。
具体实现
- 步骤一:开启SpringAOP的注解功能
@Configuration
@ComponentScan("com.yolo")
@EnableAspectJAutoProxy
public class SpringConfig {
}
- 步骤二:编写通知类
@Component
@Aspect
public class MyAdvice {
//但凡带字符串的操作,全都把空格去掉
@Pointcut("execution(boolean com.yolo.service.*Service.*(..))")
public void pt() {
}
@Around("MyAdvice.pt()")
public Object trimStr (ProceedingJoinPoint point) throws Throwable {
//获取参数
Object[] args = point.getArgs();
for (int i = 0; i < args.length; i++) {
//判断参数是不是字符串
if (args[i].getClass().equals(String.class)) {
//是字符串的话就去掉前后空格
args[i] = args[i].toString().trim();
}
}
//此处proceed必须传入参数,因为对args进行了修改,不传入的话还是使用的未修改的参数,运行还是没去空格的结果
Object res = point.proceed(args);
return res;
}
}
- 步骤三:运行程序
不管密码root前后是否加空格,最终控制台打印的都是true
如果有相同的大量的功能需要在很多地方加的话,AOP是你的不二选择,使用AOP可以简化共性功能的开发