您的位置:首页 > 运维架构

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 */

//
//  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)

获取数据,解密。

当然这需要和服务端沟通好
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: