iOS RSA 加密解密

作者: 雪_晟 | 来源:发表于2019-01-08 18:19 被阅读34次

    前言

    后台给的公钥,私钥,不管是公钥加密私钥解密还是私钥加密公钥解密都是可以的,但是Mac 通过openssl生成的公钥私钥还有一点点问题。(最大的问题还是获取私钥的不对)。
    感谢文章:iOS之RSA加密解密与后台之间的双向加密详解
    本文只是简单说明Mac 通过openssl 生成公钥私钥,获取私钥,公钥的时机以及注意点。

    生成公钥私钥。

    1. cd 到一个文件夹,比如RSA
      cd /Users/xxxx/Desktop/RSA

    2.执行Mac自带的openssl命令。
    openssl

    3.生成私钥
    genrsa -out rsa_private_key.pem 1024

    4.将私钥转成PKCS8的格式(必须转)格式转好后立刻复制.切记后面使用的私钥加密解密就是执行命令行之后终端打印的私钥,而不是执行命令行之后重新生成的私钥,(网上一些命令行是错误的,一定要注意)。

    pkcs8 -topk8 -inform PEM -in rsa_private_key.pem -outform PEM -nocrypt

    WX20190108-180638@2x.png

    复制上图的私钥保存。

    5.生成公钥。

    rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem

    测试RSA加密解密。

    GitHub RSA 一个工具类 Objective-C-RSA,然后下载,后面加密解密使用。

    通过文本编辑打开刚才的RSA文件里的rsa_public_key.pem,拿到公钥。

    私钥使用第4步转PKCS8格式后保存的私钥。

    测试结果:

    NSString *publicKey = @"MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC0OiXHaees9Aj5h31YYGw5nfCUdS6MK0T5UrJAfIdwkUbadDOXclDVK+ftBMe+DVAn7xSORPi1cjiBBjU+lo/hmNGoDWQGgxr/LAkaJz3/A1Sv+S1d3deTc6SFN+toDQbpsx3jYOUrJM1B8olUI1a9f+DgzkF/sIKJ7V4Wh7XtlQIDAQAB";
        //私钥
        NSString *privateKey = @"MIICdgIBADANBgkqhkiG9w0BAQEFAASCAmAwggJcAgEAAoGBALQ6Jcdp56z0CPmHfVhgbDmd8JR1LowrRPlSskB8h3CRRtp0M5dyUNUr5+0Ex74NUCfvFI5E+LVyOIEGNT6Wj+GY0agNZAaDGv8sCRonPf8DVK/5LV3d15NzpIU362gNBumzHeNg5SskzUHyiVQjVr1/4ODOQX+wgontXhaHte2VAgMBAAECgYAljox63sXpk70fCq4DMay74P7WYQj/KrEn56S/rXOn8I48TcTGhYr0sT6WdM2O/EU83SSCdTsCzLebo4iK72Mx/VI1alKWSfyncfXi51gZePpgVaudTG9kcI8sszRG+P7zfPptr4HxZ7X2LveJy5myImqQomESEUvDVHdZCtIIgQJBANxT7Bev+LA+jH9gSV4Uc14B5YYabpLso39t/uhTaOdVNxV2eV2UAF1PGg2R3IMwlzHcjRkDDpBiWuXaxbTKCaECQQDRaCUb7J1mPDBrEIi1Aupho16b3Sy82vzZ9WGLgMl+eMKbSy0rAdJA10CtNKL2Gq7EGNoN4CpDPPulJTmm6Cd1AkAajH5BaHHmAtN5McgFbx9rr3zRyPOT/rHA1CdIJWzZmzoU+v6q2P+mPrbb9byFjmBZoMLbxbOGkGN1mQQDweihAkEAkAJ9Mr0AaeSOr7KJMWK16Tu+vpXWRHKdXQ9Ba/y/lThbLQ0AHQl9nJXrprICOBmVgspMeypkJiV0Mdht03joWQJAaF8kDoCNkpp++6aqVbqFBYysiW83AiHgL0JA5dhQ2XzIFYZIpLOsM+Je4yw9ppQ76DqePg6pqRKjR6m9Gatn+A==";
        //测试要加密的数据
        NSString *sourceStr = @"iOS端RSA加密";
        //公钥加密
        NSString *encryptStr = [RSA encryptString:sourceStr publicKey:publicKey];
        //私钥解密
        NSString *decrypeStr = [RSA decryptString:encryptStr privateKey:privateKey];
        
        NSLog(@"公钥加密私钥解密后的数据 %@",decrypeStr);
        
        //私钥加密
        NSString *encryptStr1 = [RSA encryptString:sourceStr privateKey:privateKey];
        //公钥解密
        NSString *decrypeStr1 = [RSA decryptString:encryptStr1 publicKey:publicKey];
        NSLog(@"私钥加密公钥解密后的数据 %@",decrypeStr1);
    

    结果:

    2019-01-08 18:17:48.834840+0800 RSAUtil[53592:4032334] 原始数据:iOS端RSA加密 公钥加密私钥解密后的数据 iOS端RSA加密
    2019-01-08 18:17:48.843686+0800 RSAUtil[53592:4032334] 原始数据:iOS端RSA加密 私钥加密公钥解密后的数据 iOS端RSA加密
    

    可以看到公钥加密私钥解密后的数据是正常的,私钥加密公钥解密后的数据是正常的。

    需要注意的是:RSA 文件中已经对结果做了base64加密解密

    end RSA 的加密简单介绍到这里。

    相关文章

      网友评论

        本文标题:iOS RSA 加密解密

        本文链接:https://www.haomeiwen.com/subject/lnubrqtx.html