Springboot加入拦截器(待完善)

Easter79
• 阅读 643

1、在sdk中加入拦截器主类

package com.self.activity.sdk.aop;

import java.io.IOException;
import java.sql.SQLException;
import java.util.List;

import org.aspectj.lang.ProceedingJoinPoint;
import org.springframework.util.StringUtils;
import org.springframework.validation.BeanPropertyBindingResult;
import org.springframework.validation.FieldError;

import com.self.activity.sdk.bean.Result;
import com.self.activity.sdk.config.CodeProperties;
import com.self.activity.sdk.exception.BusinessException;

public class BaseValidateHandler {
    public Object validate(ProceedingJoinPoint joinPoint) {
        try {
            Object[] args = joinPoint.getArgs();
            // 输入参数对象通用校验
            for (Object arg : args) {
                if (!(arg instanceof BeanPropertyBindingResult)) 
                    continue;

                BeanPropertyBindingResult result = (BeanPropertyBindingResult) arg;
                if (!result.hasFieldErrors()) 
                    continue;

                List fieldErrors = result.getFieldErrors();
                for (FieldError error : fieldErrors) {
                    String codePattern = error.getDefaultMessage();
                    String fieldName = error.getField();

                    String code = this.fetchMsgCode(codePattern);
                    String displayMsg = this.getDisplayMessage(codePattern, fieldName);

                    return new Result(code, displayMsg);
                }

            }
            // 具体业务处理
            return joinPoint.proceed();
        } catch (BusinessException ex) {
            // 业务异常
            return new Result(ex.getCode(), ex.getMessage(), null, ex.getCause());
        } catch (ArrayIndexOutOfBoundsException e) {
            // 数组下标越界!
            return new Result("10102", e);
        } catch (ArithmeticException e) {
            // 数学运算异常!
            return new Result("10103", e);
        } catch (NullPointerException e) {
            // 空指针异常!
            return new Result("10104", e);
        } catch (ClassNotFoundException e) {
            // 找不到类异常
            return new Result("10105", e);
        } catch (IOException e) {
            // IO异常
            return new Result("10106", e);
        } catch (IllegalArgumentException e) {
            // 方法的参数错误
            return new Result("10107", e);
        } catch (ClassCastException e) {
            // 类型强制转换错误!
            return new Result("10108", e);
        } catch (SecurityException e) {
            // 违背安全原则异常!
            return new Result("10109", e);
        } catch (SQLException e) {
            // 操作数据库异常!
            return new Result("10110", e);
        } catch (NoSuchMethodException e) {
            // 方法未找到异常!
            return new Result("10111", e);
        } catch (InternalError e) {
            // Java虚拟机发生了内部错误!
            return new Result("10112", e);
        } catch (Throwable e) {
            // 未知的错误
            return new Result("2", e);
        }
    }

    protected String getDisplayMessage(String codePattern, String fieldName) {
        String code = fetchMsgCode(codePattern);
        String[] params = fetchMsgParams(codePattern, fieldName);
        return CodeProperties.getInstance().getValue(code, params);
    }

    private String fetchMsgCode(String codePattern) {
        if (StringUtils.isEmpty(codePattern)) {
            return null;
        }

        String[] fields = codePattern.split(",");
        return fields[0];
    }

    private String[] fetchMsgParams(String codePattern, String fieldName) {
        if (StringUtils.isEmpty(codePattern)) {
            return new String[] {};
        }

        String[] configParams = codePattern.split(",");
        String[] params = new String[configParams.length];
        params[0] = fieldName;

        if (configParams.length > 1) {
            System.arraycopy(configParams, 1, params, 1, configParams.length - 1);
        }

        return params;
    }
}

2、在拦截器中书写内容

package com.self.activity.handler;

import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;

import com.self.activity.sdk.aop.BaseValidateHandler;

@Aspect
@Component
@Order(0)
public class ValidateHandler extends BaseValidateHandler {

    @Pointcut("execution(* com.self.activity.controller.*Controller.*(..))")
    public void validateMethod(){}
    
    @Around("validateMethod()")
    public Object validate(ProceedingJoinPoint joinPoint){
        return super.validate(joinPoint);
    }
}  

aop是面向切面变成,是与oop面向对象编程相对的。

AOP、OOP在字面上虽然非常类似,但却是面向不同领域的两种设计思想。OOP(面向对象编程)针对业务处理过程的实体及其属性和行为进行抽象封装,以获得更加清晰高效的逻辑单元划分。 而AOP则是针对业务处理过程中的切面进行提取,它所面对的是处理过程中的某个步骤或阶段,以获得逻辑过程中各部分之间低耦合性的隔离效果。这两种设计思想在目标上有着本质的差异。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Android So动态加载 优雅实现与原理分析
背景:漫品Android客户端集成适配转换功能(基于目标识别(So库35M)和人脸识别库(5M)),导致apk体积50M左右,为优化客户端体验,决定实现So文件动态加载.!(https://oscimg.oschina.net/oscnet/00d1ff90e4b34869664fef59e3ec3fdd20b.png)点击上方“蓝字”关注我
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
35岁是技术人的天花板吗?
35岁是技术人的天花板吗?我非常不认同“35岁现象”,人类没有那么脆弱,人类的智力不会说是35岁之后就停止发展,更不是说35岁之后就没有机会了。马云35岁还在教书,任正非35岁还在工厂上班。为什么技术人员到35岁就应该退役了呢?所以35岁根本就不是一个问题,我今年已经37岁了,我发现我才刚刚找到自己的节奏,刚刚上路。
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这
Easter79
Easter79
Lv1
今生可爱与温柔,每一样都不能少。
文章
2.8k
粉丝
6
获赞
1.2k