用 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)。

相关推荐
CaracalTiger1 小时前
什么是Clawdbot?Clawdbot下载、安装、配置教程(最新版Moltbot)
python·编辑器·aigc·idea·ai编程·intellij idea·agi
小鹿软件办公1 小时前
苹果因通信问题撤回面向旧款 iPhone 和 iPad 的系统更新
ios·iphone
WJX_KOI5 小时前
Open Notebook 一个开源的结合AI的记笔记软件
python
chipsense6 小时前
电流传感器型号从数据库查询并排序输出到网页的方法
数据库·php·传感器·霍尔电流传感器
0思必得06 小时前
[Web自动化] 反爬虫
前端·爬虫·python·selenium·自动化
徐徐同学6 小时前
cpolar为IT-Tools 解锁公网访问,远程开发再也不卡壳
java·开发语言·分布式
2301_822382767 小时前
Python上下文管理器(with语句)的原理与实践
jvm·数据库·python
m0_748229997 小时前
Laravel8.X核心功能全解析
开发语言·数据库·php
喵手7 小时前
Python爬虫实战:从零搭建字体库爬虫 - requests+lxml 实战采集字体网字体信息数据(附 CSV 导出)!
爬虫·python·爬虫实战·零基础python爬虫教学·csv导出·采集字体库数据·字体库字体信息采集
Mr.朱鹏7 小时前
Nginx路由转发案例实战
java·运维·spring boot·nginx·spring·intellij-idea·jetty