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

ops/2024/11/14 13:25:46/

可以使用对称加密算法(如 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/ops/133290.html

相关文章

Unity学习笔记(2):场景绘制

文章目录 前言开发环境场景资源导入Unity2d 瓦片功能更改游戏视图缩放比例 叠层Tilemap如何分层 总结 前言 我也算是跨行学Unity。我希望学了这个东西能有用吧。对以后的工作的要求&#xff0c;时薪高。唉&#xff0c;先学着好了。不知道以后的行情是如何&#xff0c;但是上位…

探索LINQ在C#中的应用:从基本查询到数据联接

LINQ&#xff08;语言集成查询&#xff09;是微软为.NET框架开发的一种强大功能&#xff0c;于2007年作为C# 3.0和Visual Basic .NET 9.0的一部分引入。LINQ的诞生旨在提供一种一致且直观的方式来查询和操作数据&#xff0c;无论数据来源是内存中的集合、数据库还是XML文档。 …

【测试框架篇】单元测试框架pytest(1):环境安装和配置

一、pytest简介 Pytest是Python的一种单元测试框架&#xff0c;与Python自带的unittest测试框架类似&#xff0c;但是比 unittest框架使用起来更简洁&#xff0c;效率更高。 二、pytest特点 Pytest是一个非常成熟的Python测试框架,主要特点有以下几点&#xff1a; 非常容易…

DAY59||并查集理论基础 |寻找存在的路径

并查集理论基础 并查集主要有两个功能&#xff1a; 将两个元素添加到一个集合中。判断两个元素在不在同一个集合 代码模板 int n 1005; // n根据题目中节点数量而定&#xff0c;一般比节点数量大一点就好 vector<int> father vector<int> (n, 0); // C里的一…

C++开发基础之使用librabbitmq库实现RabbitMQ消息队列通信

1. 前言 RabbitMQ是一个流行的开源消息队列系统&#xff0c;支持多种消息协议&#xff0c;广泛用于构建分布式系统和微服务架构。可以在不同应用程序之间实现异步消息传递。在本文中&#xff0c;我们将熟悉如何使用C与RabbitMQ进行消息通信。 2. 准备工作 在 Windows 平台上…

docker构建jdk11

# 建立一个新的镜像文件&#xff0c;配置模板&#xff1a;新建立的镜像是以centos为基础模板 # 因为jdk必须运行在操作系统之上 FROM centos:7.9.2009# 作者名 MAINTAINER yuanhang# 创建一个新目录来存储jdk文件 RUN mkdir /usr/local/java#将jdk压缩文件复制到镜像中&#…

LinkedList和单双链表。

java中提供了双向链表的动态数据结构 --- LinkedList&#xff0c;它同时也实现了List接口&#xff0c;可以当作普通的列表来使用。也可以自定义实现链表。 单向链表&#xff1a;一个节点本节点数据下个节点地址 给定两个有序链表的头指针head1和head2&#xff0c;打印两个链表…

《人工智能网络安全现状(2024)》深度解读:机遇、挑战与应对策略

在当今数字化浪潮汹涌澎湃的时代&#xff0c;人工智能&#xff08;AI&#xff09;与网络安全已然深度交融&#xff0c;二者相互作用所塑造的发展态势正深刻重塑着我们的信息安全格局。《人工智能网络安全现状&#xff08;2024&#xff09;》这份报告恰似一盏明灯&#xff0c;为…