crypto++
CryptoPP库是一个C++书写的加密算法库,很棒。
在如今的抛却数字证书体系下,只关注公私钥对的情况下,我认为存粹的加解密算法库很有市场,虽然我以前觉得PolarSSL的加解密算法实现不错,但不影响我对CryptoPP的热情
今天,介绍一下,CryptoPP的椭圆曲线加/解密和签名/延签问题,当然是提供源码来说话了
——————————————————————————————————————————
//ecc-enc-dec.h
#ifndef ECC_ENC_DEC_H
#define ECC_ENC_DEC_H
#include <string>
void genEccEncKeys(unsigned int uiKeySize, std::string &priKey, std::string &pubKey);
void genEccSignKeys(unsigned int uiKeySize, std::string &priKey, std::string &pubKey);
std::string ecc_pri_signature(const std::string priKey, const std::string msgToSign);
std::string ecc_pub_encrypt(const std::string pubKey, const std::string msgToEncrypt);
std::string ecc_pri_decrypt(const std::string priKey, const std::string msgToDecrypt);
int ecc_pub_verify(const std::string pubKey, const std::string msgToSign, const std::string msgSigned);
#endif
//ecc-enc-dec.c
#include "ecc-enc-dec.h"
#include "eccrypto.h"
#include "osrng.h"
#include "oids.h"
#include "hex.h"
#include "filters.h"
using namespace CryptoPP;
void genEccEncKeys(unsigned int uiKeySize, std::string &priKey, std::string &pubKey)
{
AutoSeededRandomPool rnd(false, uiKeySize);
ECIES<ECP>::PrivateKey privateKey;
ECIES<ECP>::PublicKey publicKey;
privateKey.Initialize(rnd, ASN1::secp521r1());
privateKey.MakePublicKey(publicKey);
ECIES<ECP>::Encryptor encryptor(publicKey);
HexEncoder pubEncoder(new StringSink(pubKey));
encryptor.DEREncode(pubEncoder);
pubEncoder.MessageEnd();
ECIES<ECP>::Decryptor decryptor(privateKey);
HexEncoder priEncoder(new StringSink(priKey));
decryptor.DEREncode(priEncoder);
priEncoder.MessageEnd();
}
void genEccSignKeys(unsigned int uiKeySize, std::string &priKey, std::string &pubKey)
{
AutoSeededRandomPool rnd(false, uiKeySize);
ECDSA<ECP, SHA256>::PrivateKey privateKey;
ECDSA<ECP, SHA256>::PublicKey publicKey;
privateKey.Initialize(rnd, ASN1::secp521r1());
privateKey.MakePublicKey(publicKey);
StringSink priSs(priKey);
privateKey.Save(priSs);
StringSink pubSs(pubKey);
publicKey.Save(pubSs);
}
std::string ecc_pri_signature(const std::string priKey, const std::string msgToSign)
{
std::string signedText;
ECDSA<ECP, SHA256>::PrivateKey privateKey;
StringSource Ss(priKey, true);
privateKey.Load(Ss);
ECDSA<ECP, SHA256>::Signer signer(privateKey);
size_t siglen = signer.MaxSignatureLength();
signedText.resize(siglen);
RandomPool rnd;
siglen = signer.SignMessage(rnd, (byte*)msgToSign.data(), msgToSign.size(), (byte*)signedText.data());
signedText.resize(siglen);
return signedText;
}
std::string ecc_pub_encrypt(const std::string pubKey, const std::string msgToEncrypt)
{
std::string cipherText;
// if to save the key into a file, FileSource should be replace StringSource
StringSource pubString(pubKey, true, new HexDecoder);
ECIES<ECP>::Encryptor encryptor(pubString);
size_t uiCipherTextSize = encryptor.CiphertextLength(msgToEncrypt.size());
cipherText.resize(uiCipherTextSize);
RandomPool rnd;
encryptor.Encrypt(rnd, (byte*)msgToEncrypt.c_str(), msgToEncrypt.size(), (byte*)cipherText.data());
return cipherText;
}
std::string ecc_pri_decrypt(const std::string priKey, const std::string msgToDecrypt)
{
std::string decryptText;
StringSource priString(priKey, true, new HexDecoder);
ECIES<ECP>::Decryptor decryptor(priString);
size_t uiDecryptTextSize = decryptor.MaxPlaintextLength(msgToDecrypt.size());
decryptText.resize(uiDecryptTextSize);
RandomPool rnd;
decryptor.Decrypt(rnd, (byte*)msgToDecrypt.c_str(), msgToDecrypt.size(), (byte*)decryptText.data());
return decryptText;
}
int ecc_pub_verify(const std::string pubKey, const std::string msgToSign, const std::string msgSigned)
{
ECDSA<ECP, SHA256>::PublicKey publicKey;
StringSource Ss(pubKey, true);
publicKey.Load(Ss);
RandomPool rnd;
publicKey.Validate(rnd, 3);
ECDSA<ECP, SHA256>::Verifier verifier(publicKey);
bool result = verifier.VerifyMessage((byte*)msgToSign.data(), msgToSign.size(), (byte*)msgSigned.data(), msgSigned.size());
if (result)
{
return 1;
}
else
{
return 0;
}
}
//ecc-test.c
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include "ecc-enc-dec.h"
int main()
{
std::string srcText = std::string("Hello world.");
std::string enc_priKey, enc_pubKey;
genEccEncKeys(1024, enc_priKey, enc_pubKey);
std::string encryptResult = ecc_pub_encrypt(enc_pubKey, srcText);
printf("public key enc result: %s--\nlength: %d\n", encryptResult.c_str(), (int)encryptResult.size());
std::string decryptResult = ecc_pri_decrypt(enc_priKey, encryptResult);
printf("private key dec result: %s--\nlength: %d\n", decryptResult.c_str(), (int)decryptResult.size());
std::string sign_priKey, sign_pubKey;
genEccSignKeys(1024, sign_priKey, sign_pubKey);
std::string signedResult = ecc_pri_signature(sign_priKey, srcText);
printf("private key sign result: %s--\nlength: %d\n", signedResult.c_str(), (int)signedResult.size());
int bVerify = ecc_pub_verify(sign_pubKey, srcText, signedResult);
printf("public key verify result: %d\n", 0==bVerify?false:true);
return 0;
}
//result
# ./ecc-test
public key enc result:
crypto++的更多相关文章
- javax.crypto.BadPaddingException: Given final block not properly padded 解决方法
下面的 Des 加密解密代码,在加密时正常,但是在解密是抛出错误: javax.crypto.BadPaddingException: Given final block not properly p ...
- 使用crypto模块实现md5加密功能(解决中文加密前后端不一致的问题)
正常情况下使用md5加密 var crypto = require('crypto'); var md5Sign = function (data) { var md5 = crypto.create ...
- javax.crypto.BadPaddingException: Given final block not properly padded
一.报错 写了一个加密方法,在Windows上运行没有问题,在Linux上运行时提示如下错误: javax.crypto.BadPaddingException: Given final block ...
- Liunx-https-java.lang.NoClassDefFoundError: javax/crypto/SunJCE_b
错误信息: java.lang.NoClassDefFoundError: javax/crypto/SunJCE_b at javax.crypto.KeyGenerator.a(DashoA13* ...
- node crypto md5加密,并解决中文不相同的问题
在用crypto模块时碰到了加密中文不相同的问题,多谢群里面@蚂蚁指定 1:解决中文不同的问题 function md5Pay(str) { str = (new Buffer(str)).toStr ...
- Crypto++ 动态链接编译与实例测试
测试用例的来源<Crypto++入门学习笔记(DES.AES.RSA.SHA-256)> 解决在初始化加密器对象时触发异常的问题: CryptoPP::AESEncryption aesE ...
- python3 crypto winrandom import error
早就听说3的包很成熟了,自从从2.7过渡上来后还是碰到各种不适应,可以想象更早的时候问题该要多么多,特别一些必备库经典库如果没有跟进得多痛苦. [code lang="python" ...
- Crypto++入门学习笔记(DES、AES、RSA、SHA-256)(加解密)
转自http://www.cppblog.com/ArthasLee/archive/2010/12/01/135186.html 最近,基于某些原因和需要,笔者需要去了解一下Crypto++库,然后 ...
- nodejs 核心模块crypto
crypto用于加密解密 'use strict' var crypto=require('crypto'); var data={age:18} var key='dt';//定义一个钥匙 var ...
- maven install 时提示“程序包 javax.crypto不存在”
但是javax.crypto是在jdk的jre\lib目录下的 解决方案: <compilerArguments> <bootclasspath>${java.home}/li ...
随机推荐
- 如何在cocos中为节点添加监听事件
一般在监听键盘事件时,可是采用以下方式来监听键盘事件: 以及记得定义取消监听的函数(这个摧毁函数会自己调用吗?): 同时这里还有一种传统的监听方式: 但是cocos官方的文档建议我们不要使用这种方式, ...
- SOUI taobao SVN目录结构说明
- Codeforces 1109E. Sasha and a Very Easy Test 线段树
原文链接https://www.cnblogs.com/zhouzhendong/p/CF1109E.html 题意 给定一个长度为 n 的数列 a,以及一个模数 M(不一定是质数). 要求支持 q ...
- 即将上线的Imcash是何方神圣?
区块链的诞生,让数字资产来到这个时代,每个人的财产分布又多了一种十分重要的选择. 当下每个人最需要的就是一款优秀的数字资产管理平台,目前市面上各种平台层出不穷,在线管理.离线管理.全节点钱包.轻钱包. ...
- C#---ASP页面的下拉框模糊查询功能
基础方法支持: 一. DataTable 转换成 Json 换句话说如何在ASP.NET将一个DataTable序列化为 Json数组,或者如何从一个DataTable返回一个Json字符串. 使用 ...
- win10,vs2017+mpi v10.0 安装与入门 (详细)
一.安装visual studio 2017 下载 地址:https://visualstudio.microsoft.com/zh-hans/vs/ 安装 我们再选择自己想要安装的东西,确认好后点 ...
- Scrapy 框架
1. 基本使用 1.1 定义及安装 为了爬取网站数据,提取结构性数据而编写的应用框架 scrapy组件工作流程 引擎首先会将爬虫文件中的起始url获取,并且提交到调度器中.如果需要从url中下载数据, ...
- [LeetCode] Binary Tree Pruning 二叉树修剪
We are given the head node root of a binary tree, where additionally every node's value is either a ...
- centos中安装配置nginx完成之后主机无法访问
原因 VMware中安装centos7,安装配置完成nginx后,主机无法访问.虚拟机没有放行Nginx默认端口80. 解决办法 首先:开启 web 端口 firewall-cmd --permane ...
- 总结-shell脚本
执行脚本从 svn 检出项目 vi ace.sh #!/bin/bash svn export svn://127.0.0.1/ace/demo /ace/demo 设置脚本可执行 chmod +x ...