欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring aop+反射實(shí)現(xiàn)電話號加密

 更新時(shí)間:2021年06月05日 09:32:27   作者:來了我的小老弟  
線上項(xiàng)目涉及大量查詢接口中,存在電話號明文展示不合規(guī)的問題。如果對每個(gè)接口返回結(jié)果中電話號相關(guān)字段修改相關(guān)代碼邏輯,則工作量較大花費(fèi)時(shí)間多。因此設(shè)計(jì)電話號加密注解,減少工作量。

加密算法

為什么需要加密呢?就好比戰(zhàn)爭時(shí)期特工在進(jìn)行傳輸情報(bào)的時(shí)候,如果將情報(bào)明文直接通過某種媒介傳輸給同盟人員,那么一旦情報(bào)被地方截取,就會(huì)釀成大禍。如果將明文通過某種加密算法加密成雜亂無章的密文,即使被敵方截獲,沒有對應(yīng)的解密算法,也很難識別出其中的明文。安全傳輸領(lǐng)域,加密算法是一種很常用的手段,它可以保證數(shù)據(jù)不被竊取和泄漏,還可以保證數(shù)據(jù)的完整性,不被篡改。

常見的加密算法有對稱加密,非對稱加密,單向加密(簽名)等分類。其中對稱加密算法,加密密鑰和解密密鑰是同一個(gè),因此發(fā)送發(fā)和接收方都需要維護(hù)一個(gè)相同的密鑰,如果密鑰要修改,雙方都需要同時(shí)修改。非對稱加密算法中,發(fā)送發(fā)用公鑰進(jìn)行加密,接收方用私鑰進(jìn)行解密。單向加密算法是對傳輸?shù)臄?shù)據(jù)生成一個(gè)簽名,通過這個(gè)簽名來驗(yàn)證數(shù)據(jù)在傳輸過程中是否被篡改過,一般是不可逆的。

AES

  • AES 加密算法是一種對稱加密算,加密密鑰和解密密鑰是同一個(gè)。它采用對稱分組密碼體制,最少支持長度為128位的加密。涉及到分組加密,padding填充,初始向量IV,密鑰,四種加密模式。
  • 分組加密就是將原文分割成一段段的分別進(jìn)行加密,每段分組長度為128位16個(gè)字節(jié),如果最后一組長度不足128位,則采用padding填充模式將其補(bǔ)齊到128位。然后對每組進(jìn)行加密,最后組成最終密文。
  • padding填充是為了解決分組后的長度不足128位的場景。填充模式也有多種不同模式,比如PKCS5, PKCS7和NOPADDING。其中PKSC5是指分組后缺少幾個(gè)字節(jié),就在后面填充幾個(gè)字節(jié)的幾,比如缺少2個(gè)字節(jié),就在后面填充2個(gè)字節(jié)的2。PKCS7是指缺少幾個(gè)字節(jié),就在后面填充幾個(gè)字節(jié)的0,比如缺少5個(gè)字節(jié),就填充5個(gè)字節(jié)的0。NOPADDING模式就是不需要填充。如果最后面剛好是16個(gè)字節(jié)的16,那么解密方不知道是填充數(shù)據(jù)還是真實(shí)數(shù)據(jù),因此會(huì)在后面再補(bǔ)16個(gè)字節(jié)的16來區(qū)分。
  • 初始向量IV是為了保證數(shù)據(jù)的安全性,如果我們對同一段內(nèi)容進(jìn)行加密后,所生成的密文應(yīng)該是相同的,那么這樣就很容易通過密文分析出哪些段是相同的。比如原文分組后成為ABCADE,加密后的密文是GHIGJK,那么很容易看出那兩段內(nèi)容是相同的。第一個(gè)分組在初始加密向量的基礎(chǔ)上進(jìn)行加密,以后的每一個(gè)分組都在前一個(gè)分組加密的結(jié)果為基礎(chǔ)進(jìn)行加密,從而保證了即使相同的原文段,也不會(huì)生成相同的密文段。
  • 密鑰是加密和解密公用的一個(gè),它一般是128位16個(gè)字節(jié)長度的隨機(jī)字符串,分組后的原文都用同一個(gè)密鑰進(jìn)行加密。
  • 加密模式包含ECB,CBC, CFB, OFB等四種模式。ECB分別對每個(gè)分組進(jìn)行加密,相同的明文會(huì)被加密成相同的密文。CBC模式會(huì)使用上一段的加密結(jié)果作為加密向量,相同的原文不會(huì)被加密成相同的密文。

MD5

MD5算法是一種不可逆的簽名算法,對相同的輸入通過MD5散列函數(shù)處理后,會(huì)輸出相同的信息。因此MD5可以驗(yàn)證傳輸?shù)臄?shù)據(jù)是否有被篡改,但是如果竊密者對明文進(jìn)行了修改后,再使用MD5算法進(jìn)行散列,接收方將無法判斷明文已經(jīng)被修改了。一般數(shù)據(jù)庫存儲用戶密碼會(huì)將密碼使用MD5進(jìn)行處理。

HMAC-MD5

HMAC-MD5由一個(gè)H函數(shù)和一個(gè)密鑰組成,一般我們采用的散列函數(shù)為Md5或者SHA-1。HMAC-MD5算法就是采用密鑰加密+Md5信息摘要的方式形成新的密文。

AOP

眾所周知,AOP(面向切面編程)是Spring一個(gè)重要特性,它將核心關(guān)注點(diǎn)和業(yè)務(wù)邏輯進(jìn)行解耦,將業(yè)務(wù)無關(guān)的邏輯提取出來作為公共模塊進(jìn)行處理。它有切點(diǎn),切面,連接點(diǎn),通知的概念。切點(diǎn)就是我們可以織入切面的點(diǎn),切面就是我們要織入的橫切邏輯,通知包含前置通知,后置通知,返回通知,異常通知,環(huán)繞通知等。

1. 引入依賴

<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <version>1.16.18</version>
</dependency>
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-context</artifactId>
    <version>5.2.8.RELEASE</version>
</dependency>
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-aop</artifactId>
    <version>5.2.8.RELEASE</version>
</dependency>
<dependency>
    <groupId>org.aspectj</groupId>
    <artifactId>aspectjweaver</artifactId>
    <version>1.9.5</version>
</dependency>

2. 業(yè)主信息類、業(yè)主信息服務(wù)類

@Data
@AllArgsConstructor
public class CustomerInfo {

    private String name;

    private String phoneNum;
}

@Service
public class CustomerInfoService {

    @PhoneEncryptionForList(fields = "phoneNum", clazz = CustomerInfo.class)
    public List<CustomerInfo> listCustomerInfo() {
        return Arrays.asList(
                new CustomerInfo("小王", "15112368569"),
                new CustomerInfo("小李", "13652298565"),
                new CustomerInfo("小武", "18965653698"),
                new CustomerInfo("小天", "13192558569")
        );
    }
}

3. 電話號加密注解,電話號加密切面類

@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface PhoneEncryptionForList {

    /**
     * 加密字段
     *
     * @return
     */
    String[] fields();

    /**
     * 加密對象類型
     *
     * @return
     */
    Class<?> clazz();
}

@Aspect
@Component
public class PhoneEncryptionForListAspect {

    private static final int PHONE_SIZE = 11;

    @AfterReturning(value = "@annotation(com.zzq.spring.phone.encryption.PhoneEncryptionForList)", returning = "result")
    public void doEncrypt(JoinPoint joinPoint, Object result) {
        if (result == null || !(result instanceof List)) {
            System.out.println("result class type is not list, annotation is invalid");
            return;
        }

        List list = (List) result;
        if (CollectionUtils.isEmpty(list)) {
            return;
        }

        // 獲取注解的屬性值
        Method method = ((MethodSignature) joinPoint.getSignature()).getMethod();
        PhoneEncryptionForList annotation = method.getAnnotation(PhoneEncryptionForList.class);
        String[] fields = annotation.fields();
        Class<?> clazz = annotation.clazz();

        for (String field : fields) {
            try {
                // 反射獲取實(shí)體類加密字段相應(yīng)的 set 和 get 方法
                char[] chars = field.toCharArray();
                chars[0] = (char) (chars[0] - 32);
                String setMethodName = "set" + new String(chars);
                String getMethodName = "get" + new String(chars);
                Method getMethod = clazz.getDeclaredMethod(getMethodName);
                Method setMethod = clazz.getDeclaredMethod(setMethodName, String.class);

                for (Object obj : list) {
                    doEncryptPhone(getMethod, setMethod, obj);
                }
            } catch (Exception e) {
                System.out.println(field + " encrypt exception, " + e.getMessage());
                continue;
            }
        }
    }

    private static void doEncryptPhone(Method getMethod, Method setMethod, Object obj) throws Exception {
        // 反射調(diào)用 get 方法
        String originalPhone = (String)getMethod.invoke(obj);
        if (!StringUtils.hasText(originalPhone) || originalPhone.length() != PHONE_SIZE) {
            System.out.println("phone field value is blank or formal error");
            return;
        }

        String encryptedPhone = originalPhone.replaceAll("(\\d{3})\\d{4}(\\d{4})","$1****$2");
        // 反射調(diào)用 set 方法
        setMethod.invoke(obj, encryptedPhone);
    }
}

4. 測試類

@Configuration
@EnableAspectJAutoProxy
@ComponentScan("com.zzq.spring.phone.encryption")
public class TestApplication {

    public static void main(String[] args) {
        AnnotationConfigApplicationContext ctx = new AnnotationConfigApplicationContext(TestApplication.class);

        CustomerInfoService customerInfoService = ctx.getBean(CustomerInfoService.class);
        List<CustomerInfo> afterPhoneEncryptCustomerInfos = customerInfoService.listCustomerInfo();

        afterPhoneEncryptCustomerInfos.forEach(customerInfos -> {
            System.out.println(customerInfos);
        });
    }
}

5. 結(jié)果和總結(jié)

該加密注解只簡單實(shí)現(xiàn)了電話號加密,注解中還可以新增一些屬性擴(kuò)展注解功能,比如增加加密字段格式加密規(guī)則的正則表達(dá)式的屬性值,這樣加密的字段類型(手機(jī)號、身份證等)和方式(中間多少位加密、首位加密)就可以根據(jù)具體需求處理。

以上就是Spring aop+反射實(shí)現(xiàn)電話號加密的詳細(xì)內(nèi)容,更多關(guān)于Spring aop電話號加密的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 打造一款代碼命名工具的詳細(xì)教程

    打造一款代碼命名工具的詳細(xì)教程

    這篇文章主要介紹了來,我們一起打造一款代碼命名工具,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09
  • Java Spring IOC圖文詳解

    Java Spring IOC圖文詳解

    IoC是一種讓服務(wù)消費(fèi)者不直接依賴于服務(wù)提供者的組件設(shè)計(jì)方式,是一種減少類與類之間依賴的設(shè)計(jì)原則。下面通過本文給大家分享spring中ioc的概念,感興趣的朋友一起看看吧
    2021-09-09
  • SpringBoot對數(shù)據(jù)訪問層進(jìn)行單元測試的方法詳解

    SpringBoot對數(shù)據(jù)訪問層進(jìn)行單元測試的方法詳解

    我們公司作為一個(gè)面向銀行、金融機(jī)構(gòu)的TO B類企業(yè),頻繁遇到各個(gè)甲方爸爸提出的國產(chǎn)化數(shù)據(jù)庫的改造需求,包括OceanBase, TiDB,geldenDB等等,本文就介紹一種快高效、可復(fù)用的解決方案——對數(shù)據(jù)訪問層做單元測試,需要的朋友可以參考下
    2023-08-08
  • java實(shí)現(xiàn)頁面多查詢條件必選的統(tǒng)一處理思路

    java實(shí)現(xiàn)頁面多查詢條件必選的統(tǒng)一處理思路

    這篇文章主要為大家介紹了java實(shí)現(xiàn)頁面多查詢條件必選的統(tǒng)一處理思路詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • springboot jar包外置配置文件的解決方法

    springboot jar包外置配置文件的解決方法

    這篇文章主要給大家介紹了關(guān)于spring boot jar包外置配置文件的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • Java實(shí)現(xiàn)分布式系統(tǒng)限流

    Java實(shí)現(xiàn)分布式系統(tǒng)限流

    這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)分布式系統(tǒng)限流,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • Java實(shí)現(xiàn)將png格式圖片轉(zhuǎn)換成jpg格式圖片的方法【測試可用】

    Java實(shí)現(xiàn)將png格式圖片轉(zhuǎn)換成jpg格式圖片的方法【測試可用】

    這篇文章主要介紹了Java實(shí)現(xiàn)將png格式圖片轉(zhuǎn)換成jpg格式圖片的方法,涉及java文件讀寫及圖形創(chuàng)建等相關(guān)操作技巧,需要的朋友可以參考下
    2018-03-03
  • Spring MVC數(shù)據(jù)綁定概述及原理詳解

    Spring MVC數(shù)據(jù)綁定概述及原理詳解

    這篇文章主要介紹了Spring MVC數(shù)據(jù)綁定概述及原理詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • Java數(shù)據(jù)結(jié)構(gòu)之AC自動(dòng)機(jī)算法的實(shí)現(xiàn)

    Java數(shù)據(jù)結(jié)構(gòu)之AC自動(dòng)機(jī)算法的實(shí)現(xiàn)

    AC自動(dòng)機(jī)算法常被認(rèn)為是Trie樹+KMP算法的結(jié)合體,它是一個(gè)多模式匹配算法,在模式匹配領(lǐng)域被廣泛應(yīng)用。本文將詳細(xì)為大家介紹AC自動(dòng)機(jī)的原理與實(shí)現(xiàn)方法,感興趣的可以了解一下
    2022-12-12
  • 淺析java中asList的使用詳解

    淺析java中asList的使用詳解

    Java中的asList方法是數(shù)組工具類 Arrays中的一個(gè)靜態(tài)方法,asList()方法把數(shù)組轉(zhuǎn)換成集合時(shí),不能使用其修改集合相關(guān)的方法,本文通過示例代碼給大家介紹java asList使用,感興趣的朋友一起看看吧
    2021-10-10

最新評論