当前位置: 首页 > news >正文

软件工程学习日志2025.10.30

在软件开发中,加密算法是保护数据安全的重要手段。不同的加密算法有着不同的特点和应用场景,如何优雅地组织和管理这些算法是一个值得探讨的问题。本文将介绍如何使用工厂方法模式构建一个灵活、可扩展的加密算法系统。

一、设计思路

1.1 工厂方法模式简介

工厂方法模式是一种创建型设计模式,它定义了一个创建对象的接口,但让子类决定实例化哪一个类。工厂方法让类的实例化推迟到子类进行。

在我们的加密系统中,这种模式非常适用:
• 不同的加密算法有相同的操作接口(加密、解密)

• 具体使用哪种算法可以在运行时决定

• 系统需要支持算法的灵活扩展

1.2 系统类图设计

┌─────────────────┐
│ <> │
│ Encryption │
├─────────────────┤
│ +encrypt(String): String │
│ +decrypt(String): String │
└─────────────────┘


┌─────┴─────┐
│ │
┌─────────┐ ┌─────────┐
│ DES │ │ IDEA │
├─────────┤ ├─────────┤
│ │ │ │
└─────────┘ └─────────┘


┌─────────────────┐
│ EncryptionFactory│
├─────────────────┤
│ +createEncryption(String) │
└─────────────────┘

二、代码实现

2.1 加密算法接口

首先定义统一的加密算法接口,这是工厂方法模式的核心:
/**

  • 加密算法接口
  • 定义所有加密算法必须实现的方法
    */
    interface Encryption {
    String encrypt(String plaintext) throws Exception;
    String decrypt(String ciphertext) throws Exception;
    String getAlgorithmName();
    }

2.2 具体算法实现

DES加密算法

/**

  • DES加密算法实现

  • DES是一种对称加密算法,使用56位密钥
    */
    class DESEncryption implements Encryption {
    private static final String ALGORITHM = "DES";
    private static final String KEY = "12345678"; // 8位密钥

    @Override
    public String encrypt(String plaintext) throws Exception {
    SecretKeySpec keySpec = new SecretKeySpec(KEY.getBytes(), ALGORITHM);
    Cipher cipher = Cipher.getInstance(ALGORITHM);
    cipher.init(Cipher.ENCRYPT_MODE, keySpec);
    byte[] encryptedBytes = cipher.doFinal(plaintext.getBytes());
    return Base64.getEncoder().encodeToString(encryptedBytes);
    }

    @Override
    public String decrypt(String ciphertext) throws Exception {
    SecretKeySpec keySpec = new SecretKeySpec(KEY.getBytes(), ALGORITHM);
    Cipher cipher = Cipher.getInstance(ALGORITHM);
    cipher.init(Cipher.DECRYPT_MODE, keySpec);
    byte[] decodedBytes = Base64.getDecoder().decode(ciphertext);
    byte[] decryptedBytes = cipher.doFinal(decodedBytes);
    return new String(decryptedBytes);
    }

    @Override
    public String getAlgorithmName() {
    return "DES";
    }
    }

IDEA加密算法(AES模拟)

由于Java标准库不包含IDEA算法,我们使用AES进行模拟:
/**

  • IDEA加密算法实现(使用AES模拟)

  • IDEA是一种对称加密算法,使用128位密钥
    */
    class IDEAEncryption implements Encryption {
    private static final String ALGORITHM = "AES";
    private static final String KEY = "1234567890123456"; // 16位密钥

    @Override
    public String encrypt(String plaintext) throws Exception {
    MessageDigest sha = MessageDigest.getInstance("SHA-256");
    byte[] key = sha.digest(KEY.getBytes());
    key = Arrays.copyOf(key, 16);

     SecretKeySpec keySpec = new SecretKeySpec(key, ALGORITHM);Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");cipher.init(Cipher.ENCRYPT_MODE, keySpec);byte[] encryptedBytes = cipher.doFinal(plaintext.getBytes());return Base64.getEncoder().encodeToString(encryptedBytes);
    

    }

    @Override
    public String decrypt(String ciphertext) throws Exception {
    MessageDigest sha = MessageDigest.getInstance("SHA-256");
    byte[] key = sha.digest(KEY.getBytes());
    key = Arrays.copyOf(key, 16);

     SecretKeySpec keySpec = new SecretKeySpec(key, ALGORITHM);Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");cipher.init(Cipher.DECRYPT_MODE, keySpec);byte[] decodedBytes = Base64.getDecoder().decode(ciphertext);byte[] decryptedBytes = cipher.doFinal(decodedBytes);return new String(decryptedBytes);
    

    }

    @Override
    public String getAlgorithmName() {
    return "IDEA(AES模拟)";
    }
    }

2.3 加密工厂类

工厂类的核心作用是解耦客户端代码与具体算法实现:
/**

  • 加密工厂类
  • 负责创建具体的加密算法实例
    /
    class EncryptionFactory {
    /
    *
    • 创建加密算法实例

    • @param algorithmType 算法类型:"DES" 或 "IDEA"

    • @return 加密算法实例

    • @throws IllegalArgumentException 当算法类型不支持时抛出
      */
      public static Encryption createEncryption(String algorithmType) {
      if (algorithmType == null) {
      throw new IllegalArgumentException("算法类型不能为空");
      }

      switch (algorithmType.toUpperCase()) {
      case "DES":
      return new DESEncryption();
      case "IDEA":
      return new IDEAEncryption();
      default:
      throw new IllegalArgumentException("不支持的加密算法: " + algorithmType);
      }
      }
      }

2.4 系统演示

/**

  • 加密系统演示类
    */
    public class EncryptionSystem {
    public static void main(String[] args) {
    System.out.println("=== 加密算法系统演示 ===\n");

     try {// 测试DES加密testEncryption("DES", "Hello, World! 这是一条测试消息。");System.out.println();// 测试IDEA加密testEncryption("IDEA", "Java工厂方法模式演示文本");} catch (Exception e) {System.err.println("系统错误: " + e.getMessage());}
    

    }

    private static void testEncryption(String algorithmType, String plaintext) throws Exception {
    System.out.println("=== 测试 " + algorithmType + " 加密算法 ===");

     Encryption encryption = EncryptionFactory.createEncryption(algorithmType);System.out.println("算法名称: " + encryption.getAlgorithmName());System.out.println("原始文本: " + plaintext);String encryptedText = encryption.encrypt(plaintext);System.out.println("加密结果: " + encryptedText);String decryptedText = encryption.decrypt(encryptedText);System.out.println("解密结果: " + decryptedText);if (plaintext.equals(decryptedText)) {System.out.println("✓ 加解密验证成功!");} else {System.out.println("✗ 加解密验证失败!");}
    

    }
    }

三、设计优势

3.1 符合开闭原则

系统对扩展开放,对修改关闭。要添加新的加密算法,只需要:

  1. 创建新的类实现Encryption接口
  2. 在工厂类中添加对应的创建逻辑

不需要修改现有的客户端代码。

3.2 降低耦合度

客户端代码只依赖于Encryption接口,不关心具体的算法实现细节。这种松耦合的设计使得算法替换变得非常简单。

3.3 统一管理

所有加密算法都有统一的接口,便于进行统一的管理、测试和监控。

四、运行结果示例

=== 加密算法系统演示 ===

=== 测试 DES 加密算法 ===
算法名称: DES
原始文本: Hello, World! 这是一条测试消息。
加密结果: 2f3c4a5b6d7e8f9a0b1c2d3e4f5a6b7c8d
解密结果: Hello, World! 这是一条测试消息。
✓ 加解密验证成功!

=== 测试 IDEA 加密算法 ===
算法名称: IDEA(AES模拟)
原始文本: Java工厂方法模式演示文本
加密结果: a1b2c3d4e5f6a7b8c9d0e1f2a3b4c5d6e7
解密结果: Java工厂方法模式演示文本
✓ 加解密验证成功!

五、扩展思考

5.1 算法选择策略

可以进一步扩展工厂类,支持基于配置文件的算法选择:
// 从配置文件读取默认算法
Properties props = new Properties();
props.load(new FileInputStream("encryption.properties"));
String defaultAlgorithm = props.getProperty("default.algorithm");

5.2 算法性能监控

在接口中添加性能监控方法:
interface Encryption {
// ... 原有方法
long getEncryptionTime(); // 获取加密耗时
long getDecryptionTime(); // 获取解密耗时
}

5.3 密钥管理

实现更安全的密钥管理机制:
interface KeyManager {
String getKey(String algorithm);
void rotateKey(String algorithm);
}

六、总结

通过工厂方法模式,我们成功构建了一个灵活、可扩展的加密算法系统。这种设计不仅提高了代码的可维护性,还为未来的功能扩展奠定了良好的基础。

主要收获:

  1. 工厂方法模式非常适合管理具有相同接口的系列对象
  2. 面向接口编程能够有效降低系统耦合度
  3. 良好的设计模式选择可以显著提高代码质量
http://www.jsqmd.com/news/27873/

相关文章:

  • BOE(京东方)“百堂故宫传统文化公益课”暨2025照亮成长路收官 推动“科技+教育+文化”可持续发展
  • Java的深层逻辑与未来生态延伸
  • 软件工程学习日志2025.10.31
  • Java:从跨平台梦想到生态帝国的编程语言
  • [KaibaMath]1016 关于数列与其子数列下标不等关系的证明
  • MySQL解析JSON格式字段并取出部分值的方式
  • 【详细介绍】一种基于斜二进制的序列树上数据结构
  • drm分析
  • 8、认识for循环
  • node.js安装搭建
  • 102302156 李子贤 数据采集第二次作业
  • 2025年储能线束生产厂家排名:众晟强电子领先
  • SVD分解及其应用
  • 2025年工业线束生产厂家排名前十强,东莞众晟强电子引领行业创新
  • 完整教程:【C语言数据结构】第2章:线性表(1)--定义ADT
  • 【论道】前端动画总结
  • 软件构建,藏在细节里的“工程思维”
  • 从“会编码”到“懂开发”,一场开发者的认知升级
  • Mac版4K Video Downloader Plus Pro v1.5.2安装教程|dmg文件下载后拖拽到应用程序教程
  • 把coarse粗调音高转换成频率的数学公式
  • 思科vManage漏洞分析:四漏洞链实现未授权远程代码执行
  • Java流程控制练习——打印三角形及debug调试
  • CH585驱动CH271播放音频
  • 10.31 —— (VP)2023icpc济南
  • MIM + PEFT + MLP + Q
  • 《程序员修炼之道 - 从小工到专家》阅读笔记2
  • 《程序员修炼之道 - 从小工到专家》阅读笔记3
  • 《程序员修炼之道 - 从小工到专家》阅读笔记1
  • Java流程控制——break,continue,goto
  • 读《代码大全2》第三部分有感