亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用Java實現(xiàn)價格加密與優(yōu)化功能

 更新時間:2025年01月20日 08:31:22   作者:碼農(nóng)阿豪@新空間代碼工作室  
在現(xiàn)代軟件開發(fā)中,數(shù)據(jù)加密是一個非常重要的環(huán)節(jié),尤其是在處理敏感信息(如價格、用戶數(shù)據(jù)等)時,本文將詳細介紹如何使用?Java?實現(xiàn)價格加密,并對代碼進行優(yōu)化,需要的朋友可以參考下

引言

在現(xiàn)代軟件開發(fā)中,數(shù)據(jù)加密是一個非常重要的環(huán)節(jié),尤其是在處理敏感信息(如價格、用戶數(shù)據(jù)等)時。本文將詳細介紹如何使用 Java 實現(xiàn)價格加密,并對代碼進行優(yōu)化,以提高其健壯性、可維護性和性能。

1. 背景

在廣告交易系統(tǒng)中,價格信息通常需要加密以確保其安全性。Google 的 DoubleClick Ad Exchange 提供了一種加密方案,使用 HMAC-SHA1 算法對價格進行加密。本文將基于這一方案,實現(xiàn)一個價格加密工具,并逐步優(yōu)化代碼。

2. 實現(xiàn)價格加密

2.1 加密原理

DoubleClick 的加密方案使用兩個密鑰:

  • 加密密鑰(Encryption Key):用于加密價格數(shù)據(jù)。
  • 完整性密鑰(Integrity Key):用于生成簽名,確保數(shù)據(jù)的完整性。

加密后的數(shù)據(jù)格式如下:

initVector:16 || E(payload:?) || I(signature:4)

其中:

  • initVector 是初始化向量,包含時間戳和服務(wù)器 ID。
  • E(payload) 是加密后的價格數(shù)據(jù)。
  • I(signature) 是完整性簽名。

2.2 基礎(chǔ)實現(xiàn)

以下是基礎(chǔ)的價格加密實現(xiàn):

import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import java.util.Base64;

public class PriceEncryptor {

    private static final String HMAC_ALGORITHM = "HmacSHA1";

    /**
     * 加密價格
     *
     * @param winPrice 價格字符串
     * @param enKey    加密密鑰(Base64 編碼)
     * @param ivKey    完整性密鑰(Base64 編碼)
     * @return 加密后的價格字符串(Base64 編碼)
     * @throws IllegalArgumentException 如果參數(shù)無效
     * @throws RuntimeException         如果加密失敗
     */
    public static String priceEncrypt(String winPrice, String enKey, String ivKey) {
        // 參數(shù)校驗
        Objects.requireNonNull(winPrice, "價格不能為空");
        Objects.requireNonNull(enKey, "加密密鑰不能為空");
        Objects.requireNonNull(ivKey, "完整性密鑰不能為空");

        if (winPrice.trim().isEmpty()) {
            throw new IllegalArgumentException("價格不能為空字符串");
        }

        try {
            // 將價格轉(zhuǎn)換為 double
            double priceValue = Double.parseDouble(winPrice);

            // 解析密鑰
            SecretKey encryptionKey = decodeBase64ToSecretKey(enKey, HMAC_ALGORITHM);
            SecretKey integrityKey = decodeBase64ToSecretKey(ivKey, HMAC_ALGORITHM);

            // 創(chuàng)建加密工具
            DoubleClickCrypto.Keys keys = new DoubleClickCrypto.Keys(encryptionKey, integrityKey);
            DoubleClickCrypto.Price crypto = new DoubleClickCrypto.Price(keys);

            // 加密價格
            return crypto.encodePriceValue(priceValue, null);
        } catch (NumberFormatException e) {
            throw new IllegalArgumentException("價格格式無效: " + winPrice, e);
        } catch (Exception e) {
            throw new RuntimeException("加密失敗", e);
        }
    }

    /**
     * 將 Base64 編碼的密鑰轉(zhuǎn)換為 SecretKey
     *
     * @param base64Key Base64 編碼的密鑰
     * @param algorithm 密鑰算法
     * @return SecretKey
     * @throws IllegalArgumentException 如果密鑰無效
     */
    private static SecretKey decodeBase64ToSecretKey(String base64Key, String algorithm) {
        try {
            byte[] keyBytes = Base64.getDecoder().decode(base64Key);
            return new SecretKeySpec(keyBytes, algorithm);
        } catch (IllegalArgumentException e) {
            throw new IllegalArgumentException("無效的 Base64 密鑰: " + base64Key, e);
        }
    }

    public static void main(String[] args) {
        try {
            String bidPrice = priceEncrypt("88", "your_base64_encoded_enKey", "your_base64_encoded_ivKey");
            System.out.println("加密后價格:" + bidPrice);
        } catch (Exception e) {
            System.err.println("加密失敗: " + e.getMessage());
            e.printStackTrace();
        }
    }
}

2.3 代碼說明

  1. 參數(shù)校驗

    • 使用 Objects.requireNonNull 檢查 winPrice、enKey 和 ivKey 是否為 null。
    • 檢查 winPrice 是否為空字符串。
  2. 異常處理

    • 捕獲 NumberFormatException,提供清晰的錯誤信息。
    • 捕獲其他異常,統(tǒng)一拋出 RuntimeException
  3. 密鑰解析

    • 將 Base64 編碼的密鑰轉(zhuǎn)換為 SecretKey。
  4. 加密邏輯

    • 使用 DoubleClickCrypto.Price 對價格進行加密。

3. 優(yōu)化代碼

3.1 參數(shù)校驗

在加密方法中,參數(shù)校驗是必不可少的。我們使用 Objects.requireNonNull 來確保參數(shù)不為 null,并檢查價格字符串是否為空。

Objects.requireNonNull(winPrice, "價格不能為空");
Objects.requireNonNull(enKey, "加密密鑰不能為空");
Objects.requireNonNull(ivKey, "完整性密鑰不能為空");

if (winPrice.trim().isEmpty()) {
    throw new IllegalArgumentException("價格不能為空字符串");
}

3.2 異常處理

為了提供更好的錯誤信息,我們捕獲 NumberFormatException 并拋出 IllegalArgumentException。其他異常則統(tǒng)一拋出 RuntimeException

try {
    double priceValue = Double.parseDouble(winPrice);
    // ...
} catch (NumberFormatException e) {
    throw new IllegalArgumentException("價格格式無效: " + winPrice, e);
} catch (Exception e) {
    throw new RuntimeException("加密失敗", e);
}

3.3 代碼復(fù)用

將密鑰解析邏輯封裝到 decodeBase64ToSecretKey 方法中,避免重復(fù)代碼。

private static SecretKey decodeBase64ToSecretKey(String base64Key, String algorithm) {
    try {
        byte[] keyBytes = Base64.getDecoder().decode(base64Key);
        return new SecretKeySpec(keyBytes, algorithm);
    } catch (IllegalArgumentException e) {
        throw new IllegalArgumentException("無效的 Base64 密鑰: " + base64Key, e);
    }
}

3.4 性能優(yōu)化

如果 priceEncrypt 方法會被頻繁調(diào)用,可以考慮將 DoubleClickCrypto.Keys 和 DoubleClickCrypto.Price 的實例緩存起來,避免重復(fù)創(chuàng)建。

private static final Map<String, DoubleClickCrypto.Price> CRYPTO_CACHE = new ConcurrentHashMap<>();

private static DoubleClickCrypto.Price getCrypto(String enKey, String ivKey) {
    String cacheKey = enKey + "|" + ivKey;
    return CRYPTO_CACHE.computeIfAbsent(cacheKey, k -> {
        SecretKey encryptionKey = decodeBase64ToSecretKey(enKey, HMAC_ALGORITHM);
        SecretKey integrityKey = decodeBase64ToSecretKey(ivKey, HMAC_ALGORITHM);
        DoubleClickCrypto.Keys keys = new DoubleClickCrypto.Keys(encryptionKey, integrityKey);
        return new DoubleClickCrypto.Price(keys);
    });
}

然后在 priceEncrypt 方法中使用 getCrypto 獲取 DoubleClickCrypto.Price 實例。

DoubleClickCrypto.Price crypto = getCrypto(enKey, ivKey);
return crypto.encodePriceValue(priceValue, null);

4. 總結(jié)

通過以上步驟,我們實現(xiàn)了一個健壯、高效的價格加密工具。優(yōu)化后的代碼具有以下優(yōu)點:

  • 健壯性:通過參數(shù)校驗和異常處理,確保代碼在異常情況下也能正常運行。
  • 可維護性:通過代碼復(fù)用和模塊化設(shè)計,提高了代碼的可讀性和可維護性。
  • 性能:通過緩存加密工具實例,減少了重復(fù)創(chuàng)建對象的開銷。

到此這篇關(guān)于使用Java實現(xiàn)價格加密與優(yōu)化功能的文章就介紹到這了,更多相關(guān)Java價格加密與優(yōu)化內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java集合總結(jié)

    Java集合總結(jié)

    今天小編就為大家分享一篇關(guān)于Java集合總結(jié),小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • SpringBoot yaml語法與數(shù)據(jù)讀取操作詳解

    SpringBoot yaml語法與數(shù)據(jù)讀取操作詳解

    YAML 是 “YAML Ain’t Markup Language”(YAML 不是一種標(biāo)記語言)的遞歸縮寫。在開發(fā)的這種語言時,YAML 的意思其實是:“Yet Another Markup Language”(仍是一種標(biāo)記語言),本文給大家介紹的非常詳細,需要的朋友可以參考下
    2022-07-07
  • mybatis-sqlserver批量新增返回id方式

    mybatis-sqlserver批量新增返回id方式

    這篇文章主要介紹了mybatis-sqlserver批量新增返回id方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • Java實例域初始化方法及順序

    Java實例域初始化方法及順序

    這篇文章主要介紹了Java實例域初始化方法及順序,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-05-05
  • 挑戰(zhàn)4道Java試題

    挑戰(zhàn)4道Java試題

    這篇文章主要為大家分享了4道Java基礎(chǔ)題,幫助大家鞏固基礎(chǔ)知識,夯實java基礎(chǔ)技能,感興趣的朋友快點挑戰(zhàn)
    2015-12-12
  • java如何實現(xiàn)樹形查詢

    java如何實現(xiàn)樹形查詢

    這篇文章主要介紹了java實現(xiàn)樹形查詢方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • Java運行時數(shù)據(jù)區(qū)域(內(nèi)存劃分)的深入講解

    Java運行時數(shù)據(jù)區(qū)域(內(nèi)存劃分)的深入講解

    聽說Java運行時環(huán)境的內(nèi)存劃分是挺進BAT的必經(jīng)之路,這篇文章主要給大家介紹了關(guān)于Java運行時數(shù)據(jù)區(qū)域(內(nèi)存劃分)的相關(guān)資料,需要的朋友可以參考下
    2021-06-06
  • 使用MyBatis攔截器實現(xiàn)SQL的完整打印

    使用MyBatis攔截器實現(xiàn)SQL的完整打印

    當(dāng)我們使用Mybatis結(jié)合Mybatis-plus進行開發(fā)時,為了查看執(zhí)行sql的信息通常我們可以通過屬性配置的方式打印出執(zhí)行的sql語句,但這樣的打印出了sql語句常帶有占位符信息,不利于排錯,所以本文介紹了構(gòu)建MyBatis攔截器,實現(xiàn)SQL的完整打印,需要的朋友可以參考下
    2024-07-07
  • 用Rational Rose逆向工程(java)生成類圖(教程和錯誤解決)

    用Rational Rose逆向工程(java)生成類圖(教程和錯誤解決)

    Rational Rose有個很方便的功能,將項目中的JAVA代碼自動轉(zhuǎn)換成UML類圖
    2013-02-02
  • SpringBoot接口防重復(fù)提交的三種解決方案

    SpringBoot接口防重復(fù)提交的三種解決方案

    在Web開發(fā)中,防止用戶重復(fù)提交表單是一個常見的需求,用戶可能會因為網(wǎng)絡(luò)延遲、誤操作等原因多次點擊提交按鈕,導(dǎo)致后臺接收到多個相同的請求,本文將介紹幾種在Spring Boot中實現(xiàn)接口防重復(fù)提交的方法,需要的朋友可以參考下
    2024-11-11

最新評論