openssl解加密,数字签证
2016-06-28 21:02
423 查看
每当心情不好的时候吧,就想来写写博客。
也有一段时间没更新博客了,忙于浮躁是不想写博客的最大的问题。
最近一直在写绘五线谱底层接口,还是想把这个东西弄出来记录下的。
看时间吧,如果有空就做个专题。
服务端最近开始抽了一样给之前的接口做安全功能,索性填坑的过程中也发一篇博客以此慰藉自己。
opensll加密:
首先得要这个opensll库,平台不带自己下。
链接我贴到网盘。
链接:http://pan.baidu.com/s/1gfdPyxl 密码:za7r
.a文件直接拖到工程目录下,
opensll里面的.c文件放入class里面就好了。
这里最重要的还是设置。
找到Build Setting里面的 User Header 加入$(PROJECT_DIR)/../Classes
Library Search Paths 加入$(SRCROOT)/../Classes
Header Search Paths 加入$(inherited) 在加入$(SRCROOT)/../Classes
这是针对于目录放的, 如果这样做还是找不到头文件 那就要自己考虑层级关系了,找到openssl的根目录就好
好的,那么库已经弄好了,那就可以根据不同语言在Git上找库了
这里我拿的是oc的一套库,主要是太懒了,同事有现成的,我就直接拿过来做了个和C++桥接的类就去用了
记得桥接类必须是在.mm里面#import,别问我为什么。
类库也在网盘中
//
// ObjectHelper.hpp
// Intelligent_piano
//
// Created by 易宥佑 on 16/6/27.
//
//
#ifndef ObjectHelper_h
#define ObjectHelper_h
class ObjectHelper
{
public:
static ObjectHelper* getInstance();
static ObjectHelper* m_getToolclass;
//加密
std::string encryptString(std::string str ,std::string publickey);
//解密
std::string decryptString(std::string str, std::string publickey);
//获取时间戳
std::string GetCalculateTime();
//加密MD5
std::string md5StringForString(std::string str);
//公钥
std::string pubkey;
//时间戳
std::string m_time;
void str_replace(std::string & str, const std::string & strsrc, const std::string &strdst);
private:
};
#endif /* ObjectHelper_h */
这里有几个注意的地方,一个是url的编码, 我是用的一个很取巧的方法做的,具体可以参考html编码格式 譬如“+”变成“%2b”
整个流程是加密传数据+数字签名(时间戳+MD5)
获取数据,解密。
当然这需要和服务端沟通好
也有一段时间没更新博客了,忙于浮躁是不想写博客的最大的问题。
最近一直在写绘五线谱底层接口,还是想把这个东西弄出来记录下的。
看时间吧,如果有空就做个专题。
服务端最近开始抽了一样给之前的接口做安全功能,索性填坑的过程中也发一篇博客以此慰藉自己。
opensll加密:
首先得要这个opensll库,平台不带自己下。
链接我贴到网盘。
链接:http://pan.baidu.com/s/1gfdPyxl 密码:za7r
.a文件直接拖到工程目录下,
opensll里面的.c文件放入class里面就好了。
这里最重要的还是设置。
找到Build Setting里面的 User Header 加入$(PROJECT_DIR)/../Classes
Library Search Paths 加入$(SRCROOT)/../Classes
Header Search Paths 加入$(inherited) 在加入$(SRCROOT)/../Classes
这是针对于目录放的, 如果这样做还是找不到头文件 那就要自己考虑层级关系了,找到openssl的根目录就好
好的,那么库已经弄好了,那就可以根据不同语言在Git上找库了
这里我拿的是oc的一套库,主要是太懒了,同事有现成的,我就直接拿过来做了个和C++桥接的类就去用了
记得桥接类必须是在.mm里面#import,别问我为什么。
类库也在网盘中
//
// ObjectHelper.hpp
// Intelligent_piano
//
// Created by 易宥佑 on 16/6/27.
//
//
#ifndef ObjectHelper_h
#define ObjectHelper_h
class ObjectHelper
{
public:
static ObjectHelper* getInstance();
static ObjectHelper* m_getToolclass;
//加密
std::string encryptString(std::string str ,std::string publickey);
//解密
std::string decryptString(std::string str, std::string publickey);
//获取时间戳
std::string GetCalculateTime();
//加密MD5
std::string md5StringForString(std::string str);
//公钥
std::string pubkey;
//时间戳
std::string m_time;
void str_replace(std::string & str, const std::string & strsrc, const std::string &strdst);
private:
};
#endif /* ObjectHelper_h */
// // ObjectHelper.cpp // Intelligent_piano // // Created by 易宥佑 on 16/6/27. // // #include "ObjectHelper.h" #import "RSA.h" #import "sign.h" ObjectHelper* ObjectHelper::m_getToolclass = nullptr; ObjectHelper* ObjectHelper::getInstance() { if (!m_getToolclass) { m_getToolclass = new ObjectHelper(); } return m_getToolclass; } std::string ObjectHelper::encryptString(std::string str, std::string publickey) { NSString *stroc = [NSString stringWithCString:str.c_str() encoding:[NSString defaultCStringEncoding]]; NSString *pubkeyoc = [NSString stringWithCString:publickey.c_str() encoding:[NSString defaultCStringEncoding]]; NSString *ans = [RSA encryptString:stroc publicKey:pubkeyoc]; std::string strC= [ans UTF8String]; str_replace(strC , "+","%2b"); str_replace(strC, "/", "%2f"); return strC; } std::string ObjectHelper::decryptString(std::string str, std::string publickey) { NSString *stroc = [NSString stringWithCString:str.c_str() encoding:[NSString defaultCStringEncoding]]; NSString *pubkeyoc = [NSString stringWithCString:publickey.c_str() encoding:[NSString defaultCStringEncoding]]; NSString *ans = [RSA decryptString:stroc publicKey:pubkeyoc]; std::string strC= [ans UTF8String]; return strC; } std::string ObjectHelper::GetCalculateTime() { NSString* time =[sign CalculateTime]; m_time = [time UTF8String]; return m_time; } std::string ObjectHelper::md5StringForString(std::string str) { //先第一个元素加 xxxx数字签名 str.insert(1, "xxxx"); NSString* md5 =[NSString stringWithCString:str.c_str() encoding:[NSString defaultCStringEncoding]]; NSString* nmd5 =[sign md5StringForString:md5]; return [nmd5 UTF8String]; } void ObjectHelper::str_replace(std::string & str, const std::string & strsrc, const std::string &strdst) { std::string::size_type pos = 0;//位置 std::string::size_type srclen = strsrc.size();//要替换的字符串大小 std::string::size_type dstlen = strdst.size();//目标字符串大小 while((pos = str.find(strsrc,pos)) != std::string::npos) { str.replace(pos,srclen,strdst); pos += dstlen; } }
这里有几个注意的地方,一个是url的编码, 我是用的一个很取巧的方法做的,具体可以参考html编码格式 譬如“+”变成“%2b”
整个流程是加密传数据+数字签名(时间戳+MD5)
获取数据,解密。
当然这需要和服务端沟通好
相关文章推荐
- 使用OpenSSL生成证书
- 修改Tomcat Connector运行模式,优化Tomcat运行性能
- Apache Tomcat Native Library
- Linux-ulimit命令
- 为 Tomcat 安装 apr
- Linux系统安装 OpenSSL两种方法
- org/apache/hadoop/hbase/CompatibilityFactory(scan)没有找到类的解决办法
- 一、Hadoop 2.x 分布式安装部署
- hadoop 的编译
- 开发中经常tomcat启动报错
- GitBash+GitLab+Eclipse使用攻略非常详细版
- 42.docker简介
- 数据系统架构——Lambda architecture(Lambda架构)
- linux学习1:Linux的启动过程
- Linux开放端口
- crontab 使用日期时间命名重定向文件
- 正确使用StopCoroutine
- 单用户模式强制修改Linux系统的密码
- Linux笔记
- Kaldi学习手记(三): Kaldi 的I/O机制