之前说过, iOS 的加密解密方法非常不方便, 不易于和 PHP 或者 Java 之间交互, 比较封闭.

为了和PHP服务器端方便地进行加密解密操作, 我封装了 RSA 类. 使用这个类, 你可以用你喜欢的工具, 如 openssl 命令行, PHP 脚本, 生成友好的公钥或者私租文本, 然后 iOS 使用这些密钥进行加密, PHP 进行解密, 或者 PHP 进行解密, 由 iOS 进行解密.

方法如下:

// return base64 encoded string
+ (NSString *)encryptString:(NSString *)str publicKey:(NSString *)pubKey;
// return raw data
+ (NSData *)encryptData:(NSData *)data publicKey:(NSString *)pubKey;
// TODO:
//+ (NSString *)encryptString:(NSString *)str privateKey:(NSString *)privKey;
//+ (NSData *)encryptData:(NSData *)data privateKey:(NSString *)privKey;

// decrypt base64 encoded string, convert result to string(not base64 encoded)
+ (NSString *)decryptString:(NSString *)str publicKey:(NSString *)pubKey;
+ (NSData *)decryptData:(NSData *)data publicKey:(NSString *)pubKey;
// TODO:
//+ (NSString *)decryptString:(NSString *)str privateKey:(NSString *)privKey;
//+ (NSData *)decryptData:(NSData *)data privateKey:(NSString *)privKey;

目前能实现:

  1. iOS 用公钥加密, PHP 用私钥解密

  2. PHP 用私钥加密, iOS 用公钥解密

  3. iOS 用私钥加密, PHP 用公钥解密(未实现)

  4. PHP 用公钥加密, iOS 用私钥解密(未实现)

后面两种场景的需求还未实现, 但很快会实现. 欢迎你来补充. 项目地址:https://github.com/ideawu/Objective-C-RSA

Related posts:

  1. iOS 正确接收 HTTP chunked 数据的方法

  2. Objective C urlencode urldecode

  3. C/C++编程的现代习惯

  4. 写自己的 http_build_query

  5. 编写JSP/PHP+MySQL留言本