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

devtools/2024/11/14 12:21:38/

可以使用对称加密算法(如 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 代码:

import CommonCryptoclass Encryption {// 加密函数static func encrypt(_ data: Data, key: Data) -> Data? {let keyLength = kCCKeySizeAES256let 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 = kCCKeySizeAES256let 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)。


http://www.ppmy.cn/devtools/133586.html

相关文章

【bat】自动生成指定层级文件夹

&#x1f305; 一日之计在于晨&#xff0c;启航新程 ⭐ 本期特辑&#xff1a;自动生成指定层级文件夹 &#x1f3c6; 系列专题&#xff1a;BAT脚本工坊 文章目录 前言批处理脚本介绍脚本执行过程总结 前言 在日常的计算机使用过程中&#xff0c;我们经常需要创建文件夹来组织和…

WPF 应用程序中使用 Prism 框架时,有多种方式可以注册服务和依赖项

Prism 提供了更多的注册方式&#xff0c;适应不同的需求和场景。下面我会全面列出 IContainerRegistry 提供的所有常见注册方式&#xff0c;并附带相应的示例。1. 注册单例&#xff08;Singleton&#xff09; 注册单例类型服务&#xff0c;整个应用生命周期内只会创建一个实例&…

Kafka-Eagle的配置——kafka可视化界面

通过百度网盘分享的文件&#xff1a;kafka-eagle-bin-2.0.8.tar.gz 链接&#xff1a;https://pan.baidu.com/s/1H3YONkL97uXbLTPMZHrfdg?pwdsltu 提取码&#xff1a;sltu 一、界面展示 二、软件配置 1、关闭kafka集群 kf.sh stop 2、将该软件上传到/opt/modules下 cd /opt…

分布式数据库中间件mycat

MyCat MyCat是一个开源的分布式数据库系统&#xff0c;它实现了MySQL协议&#xff0c;可以作为数据库代理使用。 MyCat(中间件)的核心功能是分库分表&#xff0c;即将一个大表水平分割为多个小表&#xff0c;存储在后端的MySQL服务器或其他数据库中。 它不仅支持MySQL&#xff…

实用且免费的 IP 地域查询 API 接口推荐

实用且免费的 IP 地域查询 API 接口推荐 在日常开发中&#xff0c;IP 地域查询是一个常见需求。最近无意间发现一个实用的 IP 地域查询 API&#xff0c;目前是免费的&#xff0c;未来是否收费尚不可知&#xff0c;但在当前情况下非常值得推荐。 API 地址示例&#xff1a; ht…

flink 同步oracle11g数据表到pg库

1. 关闭防火墙和selinux systemctl stop firewalld systemctl disable firewalld systemctl status firewalldvi /etc/selinux/config 修改为disabled2.安装java8 yum list java-1.8* yum install java-1.8.0-openjdk* -yjava -version3.下载和部署postgresql 看需求安装pg库…

Django博客网站上线前准备事项

Django博客网站上线前准备事项 1. 功能完善与测试 确保博客网站具备以下基础功能&#xff0c;并且经过充分测试&#xff1a; 用户认证&#xff1a;注册、登录、登出、密码重置。文章管理&#xff1a;文章的创建、编辑、发布、删除。分类与标签&#xff1a;文章分类和标签的管…

《青牛科技 GC6125:驱动芯片中的璀璨之星,点亮 IPcamera 和云台控制(替代 BU24025/ROHM)》

一、GC6125 在 IPcamera 和云台控制中的卓越表现 驱动能力&#xff1a;为监控注入强劲动力 GC6125 作为一款专为 IPcamera 和云台控制而设计的驱动芯片&#xff0c;拥有令人惊叹的驱动能力。在云台电机的驱动方面&#xff0c;它就像一位技艺精湛的驭手&#xff0c;能精准地掌控…