//gcc aes_128.c -lssl -lcrypto
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <openssl/evp.h>
#include <openssl/bio.h>
#include <openssl/buffer.h>
#include <openssl/aes.h>
int openssl_base64_encode(const unsigned char* in, int inlen, char* out, int* outlen)
{
BIO* b64 = BIO_new(BIO_f_base64());
BIO* bmem = BIO_new(BIO_s_mem());
if (!b64 || !bmem) {
fprintf(stderr, "fail to BIO_new\n");
return -1;
}
b64 = BIO_push(b64, bmem);
BIO_set_flags(b64, BIO_FLAGS_BASE64_NO_NL); // ignore newlines, write everything in one line
*outlen = BIO_write(b64, in, inlen);
if (*outlen <= 0 || *outlen != inlen) {
fprintf(stderr, "
aes_128加密使用+base64编码(linux c语言)
最新推荐文章于 2023-07-20 10:56:23 发布
该代码示例展示了如何使用OpenSSL库进行AES-128加密以及Base64编码和解码。在主函数中,定义了一个16字节的秘钥和字符串数据,进行了100000次的加密、Base64编码、解码以及解密操作,验证了整个流程的正确性。
开发板推荐:天空星STM32F407VET6开发板
超高性价比 STM32主控 | 超高主频 | 一板兼容百芯 | 比赛神器 | 沉金彩色丝印
开发板推荐:天空星STM32F407VET6开发板
超高性价比 STM32主控 | 超高主频 | 一板兼容百芯 | 比赛神器 | 沉金彩色丝印

&spm=1001.2101.3001.5002&articleId=120531802&d=1&t=3&u=c520da1b3e314e718d6df53e6911898f)
3113

被折叠的 条评论
为什么被折叠?



