文档章节

自定义注解实现日志脱敏

 滑稽阿狸
发布于 2016/11/24 23:37
字数 946
阅读 79
收藏 0
点赞 0
评论 0

第一步:定义注解

/**
 * 说明:自定义注解
 * @author T-xul3
 * @date  2016年9月9日 下午2:44:49
 */
@Target(value={ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface SensitiveInfo {
    
    public SensitiveUtils.sensitiveType Type();
    
}

第二步:使用注解

/**
 * 说明:脱敏工具类
 * @author T-xul3
 * @date  2016年9月8日 下午5:44:17
 */
public  class SensitiveUtils {
    
    /**
     * 说明:脱敏枚举类
     * @author T-xul3
     * @date  2016年9月8日 下午5:44:39
     */
    public enum sensitiveType {
        
        name,idCardNum,mobilePhone,bankCard,cnapsCode,fixedPhone,defaultType;

    }
    
    /**
     * 说明:    用户名:只显示第一个,其他隐藏为星号<例子:李**>
     * @param ss
     * @return
     * 2016年9月8日 下午5:40:29
     */
    public static String name(String ss){
        if(StringUtils.isBlank(ss)){
            return "";
        }
        int length=StringUtils.length(ss);
        String newStr=StringUtils.left(ss, 1);
        return StringUtils.rightPad(newStr, length, "*");
        //return ss.replaceAll("(.)", "*");
    }
    
    /**
     * 说明:    默认全部字符串转换为* <例子:1234 ----》 **** >
     * @param strDefault 
     * @return
     * @author T-xul3
     * @date  2016年9月9日 下午2:36:55
     */
    public static String defaultType(String strDefault){
        return strDefault.replaceAll("(.)", "*");
        
    }
    /**
     * 说明:     身份证号码:显示最后四位,其他隐藏。共计18位或者15位。<例子:*************5762>
     * @param id
     * @return
     * 2016年9月8日 下午5:39:27
     */
    public static String idCardNum(String id) {
        if (StringUtils.isBlank(id)) {
                return "";
          }
         String num = StringUtils.right(id, 4);
         return StringUtils.leftPad(num, StringUtils.length(id), "*");
        }
    
    /**
     * 说明:    [手机号码] 前三位,后四位,其他隐藏<例子:138******1234>
     * @param num 手机号码
     * @return
     * @author T-xul3
     * @date  2016年9月8日 下午5:47:06
     */
    public static String mobilePhone(String num) {
        if (StringUtils.isBlank(num)) {
            return "";
        }
return StringUtils.left(num,3).concat(StringUtils.removeStart(StringUtils.leftPad(StringUtils.right(num,4), StringUtils.length(num), "*"), "***"));
    }
    
    /**
     * 说明:    参数类型是Integer(长度值小于11位)
     * [固定电话] 后四位,其他隐藏<例子:****1234>
     * @param num
     * @return
     * @author T-xul3
     * @date  2016年9月9日 上午10:35:23
     */
    public static String fixedPhone(String num) {
        if (StringUtils.isBlank(num)) {
            return "";
        }
        int length=StringUtils.length(num);
        //从右边截取制定长度的字符串
        String right = StringUtils.right(num, 4);
        //如果参数1长度小于参数2,那么全部用*号替换
        return StringUtils.leftPad(right, length, "*");
    }

    /**
     * 说明:    [银行卡号] 前六位,后四位,其他用星号隐藏每位1个星号<例子:6222600**********1234>
     * @param cardNum 银行卡号
     * @return
     * @author T-xul3
     * @date  2016年9月8日 下午5:48:26
     */
    public static String bankCard(String cardNum) {
        if (StringUtils.isBlank(cardNum)) {
            return "";
        }
        return StringUtils.left(cardNum, 6).concat(StringUtils.removeStart(StringUtils.leftPad(StringUtils.right(cardNum, 4), StringUtils.length(cardNum), "*"), "******"));
    }
    
    /**
     * 说明:     [公司开户银行联号] 公司开户银行联行号,显示前两位,其他用星号隐藏,每位1个星号<例子:12********>
     * @param code 公司开户银行联号
     * @return
     * @author T-xul3
     * @date  2016年9月8日 下午5:50:10
     */
    public static String cnapsCode(String code) {
        if (StringUtils.isBlank(code)) {
            return "";
        }
        return StringUtils.rightPad(StringUtils.left(code, 2), StringUtils.length(code), "*");
    }

    
    /**
     * 说明:    获取脱敏对象
     * @param object 
     * @return
     * @throws SecurityException 
     * @throws NoSuchFieldException 
     * @throws IllegalAccessException 
     * @throws IllegalArgumentException 
     * @throws Exception
     * 2016年9月8日 下午5:41:16
     */
    public static String getJavaBean(Object object) throws IllegalArgumentException, IllegalAccessException, NoSuchFieldException, SecurityException  {
        
        Class<? extends Object> clazz = object.getClass();
        Field[] fields = clazz.getDeclaredFields();
        String str="";
            for (Field field : fields) {
                field.setAccessible(true);
                //获取字段上的注解
                SensitiveInfo annotation = field.getAnnotation(SensitiveInfo.class);
                //获取字段的属性名称
                String fieldName=field.getName();
                //获取字段的值并转换为String类型
                String value = fieldType(object, field, fieldName);
                //判断是否存在注解
                if(null!=annotation){
                //获取注解的具体类型
                sensitiveType Type = annotation.Type();
                //匹配注解类型
                switch(Type){
                    case name:{
                        //替换为*号,重新输出
                        String valueStr = SensitiveUtils.name(value);
                        str+=fieldName+":"+valueStr+",";
                        break;
                    }
                    case idCardNum:{
                        //替换为*号,重新输出
                        String valueStr = SensitiveUtils.idCardNum(value);
                        str+=fieldName+":"+valueStr+",";
                        break;
                    }
                    case mobilePhone:{
                        //替换为*号,重新输出
                        String valueStr = SensitiveUtils.mobilePhone(value);
                        str+=fieldName+":"+valueStr+",";
                        break;
                    }
                    case fixedPhone:{
                        //替换为*号,重新输出
                        String valueStr = SensitiveUtils.fixedPhone(value);
                        str+=fieldName+":"+valueStr+",";
                        break;
                    }
                    default:{
                        String valueStr = SensitiveUtils.defaultType(value);
                        str+=fieldName+":"+valueStr+",";
                        break;
                    }
                }
            };
            if(null==annotation){
                str+=fieldName+":"+value+",";
            }
        }
        return str;
    }

    private static String fieldType(Object object, Field field, String fieldName)
            throws NoSuchFieldException, IllegalAccessException {
        //获取字段的类型
        Class<?> fieldClazz = field.getType();
        String value="";
        //通过属性名获取私有属性字段的属性值
        Field f1 = object.getClass().getDeclaredField(fieldName);
        f1.setAccessible(true);
        //判断字段具体类型,最终将字段值全部转换为String类型。
        if(fieldClazz.equals(String.class)){
            value = (String) f1.get(object);
        }
        if(fieldClazz.equals(Integer.class)){
            Integer valueInteger = (Integer) f1.get(object);
            value=valueInteger.toString();
        }
        if(fieldClazz.equals(Long.class)){
            Long valueLong = (Long) f1.get(object);
            value=valueLong.toString();
        }
        if(fieldClazz.equals(int.class)){
            int valueLong = (int) f1.get(object);
            value=String.valueOf(valueLong);
        }
        return value;
    }
}    

 

第三步:测试

SensitiveUtils.getBean(Object) 
SensitiveUtils.注解类型(字段)

© 著作权归作者所有

共有 人打赏支持
粉丝 1
博文 8
码字总数 3930
作品 0
上海
数据脱敏——什么是数据脱敏

  数据脱敏(Data Masking),又称数据漂白、数据去隐私化或数据变形。      百度百科对数据脱敏的定义为:指对某些敏感信息通过脱敏规则进行数据的变形,实现敏感隐私数据的可靠保护。在...

zancun ⋅ 03/08 ⋅ 0

【Java进阶】利用APT优雅的实现统一日志格式

统一日志格式的几种方式 无论是搭建日志平台还是进行大数据分析,统一日志格式都是一个重要的前提条件。假设要统一成下面的日志格式, 日志格式:[{系统}|{模块}]{描述}[param1=value1$param...

English0523 ⋅ 01/12 ⋅ 0

Spring自定义注解简单使用四步走

在实际开发中,很多时刻我们会有记录请求日志,定时任务日志等需求,在每个方法中都编写相同的代码去记录日志显然是不合理的。 Spring已经为我们提供了面向切面编程的思想,不妨简单的使用下...

红尾巴的猪 ⋅ 2017/11/08 ⋅ 0

springAOP自定义注解方式实现日志管理

今天继续实现AOP,到这里我个人认为是最灵活,可扩展的方式了,就拿日志管理来说,用SPRing AOP 自定义注解形式实现日志管理。废话不多说,直接开始!!! 关于配置我还是的再说一遍。 在app...

嘻哈开发者 ⋅ 2016/04/11 ⋅ 0

青橘子的服务端 - 拦截器+注解实现登陆验证

思路 拦截器拦截所有配置好的路径,取出注解对象判断是否需要进行登陆判断。 其实也可以用AOP来实现。 代码 测试Controller 注解类 配置类 拦截器 参考资料 SpringBoot使用自定义注解实现权限...

花有信 ⋅ 2017/11/27 ⋅ 0

log4j2自定义Appender(输出到文件/RPC服务中)

声明:原创文章,转载请注明出处。http://www.jianshu.com/u/e02df63eaa87 1、背景 虽然log4j很强大,可以将日志输出到文件、DB、ES等。但是有时候确难免完全适合自己,此时我们就需要自定义...

唐影若凡 ⋅ 2017/06/30 ⋅ 0

利用自定义注解在SpringMVC中实现自定义权限检查

先描述一下应用场景,基于Spring MVC的WEB程序,需要对每个Action进行权限判断,当前用户有权限则允许执行Action,无权限要出错提示。权限有很多种,比如用户管理权限、日志审计权限、系统配...

BoyTNT ⋅ 2016/11/07 ⋅ 0

Spring+SpringMVC+Mybatis 利用AOP自定义注解实现可配置日志快照记录

目的: 需要对一些事物的操作进行日志记录,如果在service内进行记录,大量的代码重复,并且维护比较麻烦。所以采用AOP的方式对service进行拦截。使用自定义注解的目的则是判断是否需要记录日...

凯文加内特 ⋅ 2015/05/12 ⋅ 2

springboot + shiro 权限注解、请求乱码解决、统一异常处理

springboot + shiro 权限注解、请求乱码解决、统一异常处理 前篇 后台权限管理系统 相关: spring boot + mybatis + layui + shiro后台权限管理系统 springboot + shiro之登录人数限制、登录...

wyait ⋅ 06/06 ⋅ 0

spring 自定义注解,实现日志

采用自定义注解实现 用户操作日志记录 简介及说明: 记录登陆用户的操作日志,目前只针对(运营管理平台)itas系统 目前采用spring的切面技术来实现记录日志的功能,切面点在controller层,主要...

hotsmile ⋅ 2016/08/31 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

Gitee 生成并部署SSH key

1.如何生成ssh公钥 你可以按如下命令来生成 sshkey: ssh-keygen -t rsa -C "xxxxx@xxxxx.com" # Generating public/private rsa key pair...# 三次回车即可生成 ssh key 查看你的 ...

晨猫 ⋅ 38分钟前 ⋅ 0

zblog2.3版本的asp系统是否可以超越卢松松博客的流量[图]

最近访问zblog官网,发现zlbog-asp2.3版本已经进入测试阶段了,虽然正式版还没有发布,想必也不久了。那么作为aps纵横江湖十多年的今天,blog2.2版本应该已经成熟了,为什么还要发布这个2.3...

原创小博客 ⋅ 今天 ⋅ 0

聊聊spring cloud的HystrixCircuitBreakerConfiguration

序 本文主要研究一下spring cloud的HystrixCircuitBreakerConfiguration HystrixCircuitBreakerConfiguration spring-cloud-netflix-core-2.0.0.RELEASE-sources.jar!/org/springframework/......

go4it ⋅ 今天 ⋅ 0

二分查找

二分查找,也称折半查找、二分搜索,是一种在有序数组中查找某一特定元素的搜索算法。搜素过程从数组的中间元素开始,如果中间元素正好是要查找的元素,则搜素过程结束;如果某一特定元素大于...

人觉非常君 ⋅ 今天 ⋅ 0

VS中使用X64汇编

需要注意的是,在X86项目中,可以使用__asm{}来嵌入汇编代码,但是在X64项目中,再也不能使用__asm{}来编写嵌入式汇编程序了,必须使用专门的.asm汇编文件来编写相应的汇编代码,然后在其它地...

simpower ⋅ 今天 ⋅ 0

ThreadPoolExecutor

ThreadPoolExecutor public ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, ......

4rnold ⋅ 昨天 ⋅ 0

Java正无穷大、负无穷大以及NaN

问题来源:用Java代码写了一个计算公式,包含除法和对数和取反,在页面上出现了-infinity,不知道这是什么问题,网上找答案才明白意思是负的无穷大。 思考:为什么会出现这种情况呢?这是哪里...

young_chen ⋅ 昨天 ⋅ 0

前台对中文编码,后台解码

前台:encodeURI(sbzt) 后台:String param = URLDecoder.decode(sbzt,"UTF-8");

west_coast ⋅ 昨天 ⋅ 0

实验楼—MySQL基础课程-挑战3实验报告

按照文档要求创建数据库 sudo sercice mysql startwget http://labfile.oss.aliyuncs.com/courses/9/createdb2.sqlvim /home/shiyanlou/createdb2.sql#查看下数据库代码 代码创建了grade......

zhangjin7 ⋅ 昨天 ⋅ 0

一起读书《深入浅出nodejs》-node模块机制

node 模块机制 前言 说到node,就不免得提到JavaScript。JavaScript自诞生以来,经历了工具类库、组件库、前端框架、前端应用的变迁。通过无数开发人员的努力,JavaScript不断被类聚和抽象,...

小草先森 ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部