博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
iOS RSA 加密解密及签名验证
阅读量:7028 次
发布时间:2019-06-28

本文共 1752 字,大约阅读时间需要 5 分钟。

1.首先要下载openssl。这个不用说,直接官网下载或者用brew install openssl下载。

2.终端生成私钥密钥。

2.1生成私钥

openssl genrsa -out rsa_private_key.pem 1024

2.2生成密钥

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

2.3将RSA私钥转换为pkcs8 格式

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

 

私钥及密钥地址在根目录文件 rsa_private_key.pem  rsa_public_key.pem

问价可通过右键文件编辑器打开查看

也可以通过终端命令cat rsa_private_key.pem 及 cat rsa_pubilic_key.pem 查看私钥密钥字符串

3.导入openssl ,导入HBRSAHandler 文件夹。

小技巧:拖进去后:librarySearchpath:会自动设置,然后拷贝路径到headSearchpath,后边添加/include。

4.使用:

两种方式导入密钥然后调用响相应的方法即可。

   

NSString* private_key_string = @"MIICdQIBA.......";   NSString* public_key_string = @"MIGfMA0GC.......";     NSString *publicKeyFilePath = [[NSBundle mainBundle] pathForResource:@"rsa_public_key.pem" ofType:nil];   NSString *privateKeyFilePath = [[NSBundle mainBundle] pathForResource:@"rsa_private_key.pem" ofType:nil];   HBRSAHandler* handler = [HBRSAHandler new];  //两种方式导入  // [handler importKeyWithType:KeyTypePublic andPath:publicKeyFilePath];  //[handler importKeyWithType:KeyTypePrivate andPath:privateKeyFilePath];  [handler importKeyWithType:KeyTypePrivate andkeyString:private_key_string];  [handler importKeyWithType:KeyTypePublic andkeyString:public_key_string];   NSString* sig = [handler signString:@"签名字符串"];   NSString* sigMd5 = [handler signMD5String:@"签名字符串"];   NSLog(@"%@%@",sig,sigMd5);   BOOL isMatch = [handler verifyString:@"签名字符串" withSign:sig];   BOOL isMatchMd5 = [handler verifyMD5String:@"签名字符串       NSLog(@"%d%d",isMatch,isMatchMd5);   NSString* enString = [handler encryptWithPublicKey:@"加密字符串"];   NSString* deString = [handler decryptWithPrivatecKey:enString];   NSLog(@"%@",deString);

5.结果验证(注:公钥加密,每次加密的结果会不一样,但是私钥签名的结果每次都一样)

转载地址:http://kzgxl.baihongyu.com/

你可能感兴趣的文章
88.NODE.JS加密模块CRYPTO常用方法介绍
查看>>
java.net.ProtocolException: Exceeded stated content-length of: '13824' bytes
查看>>
asp.net 连接 oracle10g 数据库
查看>>
C 入门 第十一节
查看>>
HTML简单的注册页面搭建
查看>>
【06】Vue 之 组件化开发
查看>>
Docker 安装
查看>>
多数据库数据导入
查看>>
[AVR]高压并行编程---基础知识
查看>>
inl文件介绍
查看>>
前端坑--表单篇
查看>>
P2P原理基础
查看>>
完成登录功能,用session记住用户名
查看>>
DBCP和C3P0使用--未完善
查看>>
JS常用方法(获取Class、获取元素样式、事件监听、cookie、ajax等)
查看>>
BZOJ 1084 最大子矩阵
查看>>
2018杭电多校第三场1007(凸包,极角排序)
查看>>
django中orm的简单操作
查看>>
Mybatis知识(1)
查看>>
[CentOS] 7 不执行文件 /etc/rc.d/rc.local
查看>>