用 PHP或Python加密字符串,用iOS解密

可以使用对称加密算法(如 AES)来加密和解密字符串。对称加密适合这种跨平台加密解密的需求,因为可以使用相同的密钥和算法在不同的编程语言和系统之间进行加密和解密。

下面展示如何使用 PythonPHP 进行加密,然后用 iOS (Swift) 来解密。我们将使用 AES-256 加密,这种加密方式具有广泛的跨平台支持,并且安全性高。

1、问题背景

一位用户需要用 PHP 或 Python 加密字符串,并在 iOS 应用中对其进行解密。加密结果要求为 base64 编码,并在应用中进行解码并显示。用户了解到 PHP 中存在密钥填充问题,因此不介意使用 Python 或 Perl 来进行加密。

2、解决方案

PHP 代码:

php 复制代码
<?php

// 定义加密函数
function encrypt($data, $key) {
  // 将密钥转换为 16 位或 24 位或 32 位
  $key = substr(md5($key), 0, 16);

  // 使用 OpenSSL AES 加密数据
  return base64_encode(openssl_encrypt($data, 'AES-256-ECB', $key));
}

// 定义解密函数
function decrypt($data, $key) {
  // 将密钥转换为 16 位或 24 位或 32 位
  $key = substr(md5($key), 0, 16);

  // 使用 OpenSSL AES 解密数据
  return openssl_decrypt(base64_decode($data), 'AES-256-ECB', $key);
}

// 测试加密和解密
$data = 'Hello, world!';
$key = 'secret';

$encrypted_data = encrypt($data, $key);
$decrypted_data = decrypt($encrypted_data, $key);

echo "Encrypted Data: " . $encrypted_data . "\n";
echo "Decrypted Data: " . $decrypted_data . "\n";

?>

iOS 代码:

swift 复制代码
import CommonCrypto

class Encryption {
    // 加密函数
    static func encrypt(_ data: Data, key: Data) -> Data? {
        let keyLength = kCCKeySizeAES256
        let ivSize = kCCBlockSizeAES128

        // 分配内存用于保存加密结果
        var encryptedData = Data(repeating: 0, count: data.count + ivSize)

        // 加密数据
        guard let status: CCCryptorStatus = CCCrypt(CCOperation(kCCEncrypt),
                                                  CCAlgorithm(kCCAlgorithmAES),
                                                  CCOptions(kCCOptionECBMode),
                                                  key,
                                                  keyLength,
                                                  nil,
                                                  data,
                                                  data.count,
                                                  &encryptedData,
                                                  encryptedData.count,
                                                  nil) == kCCSuccess else {
            print("Encryption failed: \(status)")
            return nil
        }

        // 截取实际加密数据
        encryptedData = encryptedData[ivSize...]
        return encryptedData
    }

    // 解密函数
    static func decrypt(_ data: Data, key: Data) -> Data? {
        let keyLength = kCCKeySizeAES256
        let ivSize = kCCBlockSizeAES128

        // 分配内存用于保存解密结果
        var decryptedData = Data(repeating: 0, count: data.count)

        // 解密数据
        guard let status: CCCryptorStatus = CCCrypt(CCOperation(kCCDecrypt),
                                                  CCAlgorithm(kCCAlgorithmAES),
                                                  CCOptions(kCCOptionECBMode),
                                                  key,
                                                  keyLength,
                                                  nil,
                                                  data,
                                                  data.count,
                                                  &decryptedData,
                                                  decryptedData.count,
                                                  nil) == kCCSuccess else {
            print("Decryption failed: \(status)")
            return nil
        }

        // 返回解密结果
        return decryptedData
    }
}

// 测试加密和解密
let data = "Hello, world!".data(using: .utf8)!
let key = "secret".data(using: .utf8)!

// 加密数据
let encryptedData = Encryption.encrypt(data, key: key)
print("Encrypted Data: \(encryptedData!)")

// 解密数据
let decryptedData = Encryption.decrypt(encryptedData!, key: key)
print("Decrypted Data: \(String(data: decryptedData!, encoding: .utf8)!)")

确保 Python、PHP 和 Swift 都使用相同的算法(AES-256-CBC)和相同的填充方式(PKCS7)。

相关推荐
源代码•宸2 小时前
分布式缓存-GO(分布式算法之一致性哈希、缓存对外服务化)
开发语言·经验分享·分布式·后端·算法·缓存·golang
我送炭你添花2 小时前
Pelco KBD300A 模拟器:03.Pelco-P 协议 8 字节完整拆解 + 与 Pelco-D 一一对应终极对照表
python·测试工具·运维开发
云和数据.ChenGuang2 小时前
PHP-FPM返回的File not found.”的本质
开发语言·php·运维工程师·运维技术
It's now2 小时前
Spring AI 基础开发流程
java·人工智能·后端·spring
cxh_陈2 小时前
线程的状态,以及和锁有什么关系
java·线程·线程的状态·线程和锁
计算机毕设VX:Fegn08952 小时前
计算机毕业设计|基于springboot + vue图书商城系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·课程设计
R.lin2 小时前
Java 8日期时间API完全指南
java·开发语言·python
毕设源码-赖学姐2 小时前
【开题答辩全过程】以 高校教学质量监控平台为例,包含答辩的问题和答案
java·eclipse
高山上有一只小老虎2 小时前
翻之矩阵中的行
java·算法
西南胶带の池上桜2 小时前
1.Pytorch模型应用(线性与非线性预测)
人工智能·pytorch·python