zoukankan      html  css  js  c++  java
  • OpenSSl 加密解密 示例(终于有编程实践了)

    OPenSSl的加密主要有三个重要的函数。看懂下面的代码就基本上知道该如何使用openssL来加密了。

    不过注意,要先将libssl.so.1.0和libcrypto.so.1.0文件复制到执行的文件夹下,linux下,该命令一般为/usr/lib,否则,程序执行时会显示找不到文件。另外,注意先在目录下建立mikejin.txt、mikejmw.txt、mikejout.txt三个文件

    #include <stdio.h>

    #include <string.h>
    #include <windows.h>
    #include <openssl/evp.h>
    #include <openssl/x509.h>
     
    //加密函数
    Encrypt_File()
    {

    unsigned char key[EVP_MAX_KEY_LENGTH];//保存密钥的数组
    unsigned char iv[EVP_MAX_KEY_LENGTH];//保存初始化向量的数组
    EVP_CIPHER_CTX ctx;//EVP加密上下文环境
    unsigned char out[1024];//保存密文的缓冲区
    int outl;
    unsigned char in[1024];//保存原文的缓冲区
    int inl;
    int rv;
    int i;
    FILE *fpIn;
    FILE *fpOut;
    //打开待加密文件
    fpIn = fopen("mikejin.txt","rb");
    if(fpIn==NULL)
    {
    return FALSE;
    }
    //打开保存密文的文件
    fpOut = fopen("mikejmw.txt","wb");
    if(fpOut==NULL)
    {
    fclose(fpIn);
    return FALSE;
    }
    //设置key和iv
    for(i=0;i<24;i++)
    {
    key[i]=i;
    }
    for(i=0;i<8;i++)
    {
    iv[i]=i;
    }
     
    //初始化ctx
    EVP_CIPHER_CTX_init(&ctx);
    //设置密码算法、key和iv
    rv = EVP_EncryptInit_ex(&ctx,EVP_des_ede3_cbc(),NULL,key,iv);
    if(rv != 1)
    {
    printf("Err ");
    return FALSE;
    }
    //循环读取原文,加密后后保存到密文文件。
    for(;;)
    {
    inl = fread(in,1,1024,fpIn);
    if(inl <= 0)//读取原文结束
    break;
    rv = EVP_EncryptUpdate(&ctx,out,&outl,in,inl);//加密
    if(rv != 1)
    {
    fclose(fpIn);
    fclose(fpOut);
    EVP_CIPHER_CTX_cleanup(&ctx);
    return FALSE;
    }
    fwrite(out,1,outl,fpOut);//保存密文到文件
    }
    //加密结束
    rv = EVP_EncryptFinal_ex(&ctx,out,&outl);
    if(rv != 1)
    {
    fclose(fpIn);
    fclose(fpOut);
    EVP_CIPHER_CTX_cleanup(&ctx);
    return FALSE;
    }
    fwrite(out,1,outl,fpOut);//保密密文到文件
    fclose(fpIn);
    fclose(fpOut);
    EVP_CIPHER_CTX_cleanup(&ctx);//清除EVP加密上下文环境
    printf("加密已完成 ");
    return TRUE;
    }
     
     
    //解密函数
    Decrypt_File()
    {
    unsigned char key[EVP_MAX_KEY_LENGTH];//保存密钥的数组
    unsigned char iv[EVP_MAX_KEY_LENGTH];//保存初始化向量的数组
    EVP_CIPHER_CTX ctx;//EVP加密上下文环境
    unsigned char out[1024+EVP_MAX_KEY_LENGTH];//保存解密后明文的缓冲区数组
    int outl;
    unsigned char in[1024];//保存密文数据的数组
    int inl;
    int rv;
    int i;
    FILE *fpIn;
    FILE *fpOut;

    //打开待解密的密文文件
    fpIn = fopen("mikejmw.txt","rb");
    if(fpIn==NULL)
    {
    return FALSE;
    }
    //打开保存明文的文件
    fpOut = fopen("mikejout.txt","wb");
    if(fpOut==NULL)
    {
    fclose(fpIn);
    return FALSE;
    }
    //设置key和iv
    for(i=0;i<24;i++)
    {
    key[i]=i;
    }
    for(i=0;i<8;i++)
    {
    iv[i]=i;
    }

    //初始化ctx
    EVP_CIPHER_CTX_init(&ctx);
    //设置解密的算法、key和iv
    rv = EVP_DecryptInit_ex(&ctx,EVP_des_ede3_cbc(),NULL,key,iv);
    if(rv != 1)
    {
    EVP_CIPHER_CTX_cleanup(&ctx);
    return FALSE;
    }
    //循环读取原文,解密后后保存到明文文件。
    for(;;)
    {
    inl = fread(in,1,1024,fpIn);
    if(inl <= 0)
    break;
    rv = EVP_DecryptUpdate(&ctx,out,&outl,in,inl);//解密
    if(rv != 1)
    {
    fclose(fpIn);
    fclose(fpOut);
    EVP_CIPHER_CTX_cleanup(&ctx);
    return FALSE;
    }
    fwrite(out,1,outl,fpOut);//保存明文到文件
    }
    //解密结束
    rv = EVP_DecryptFinal_ex(&ctx,out,&outl);
    if(rv != 1)
    {
    fclose(fpIn);
    fclose(fpOut);
    EVP_CIPHER_CTX_cleanup(&ctx);
    return FALSE;
    }
    fwrite(out,1,outl,fpOut);//保存明文到文件
    fclose(fpIn);
    fclose(fpOut);
    EVP_CIPHER_CTX_cleanup(&ctx);//清除EVP加密上下文环境 
    printf("解密已完成 ");
    return TRUE;
    }
     
     
    int main()
    {
    int i;  
    int j;
    OpenSSL_add_all_algorithms();
     
    printf("|-------请您选择的服务类型--------| ");
    printf("|                                 | ");
    printf("|    1:加密   2:解密   3:退出     | ");
    printf("|                                 | ");
    printf("|---------------------------------| ");
    printf("请输入选择:");
    scanf("%d",&i);
    for(j=0;j<50000000;j++)
          {
              if(j%660000==0)
              printf(">"); //实现缓冲的功能
          }
    system("cls");
    switch(i)
    {
    case 1: Encrypt_File(); break;
    case 2: Decrypt_File(); break;
    case 3: exit(0); break;
    default:
    printf("         输入错误,请重新输入");
    }
     
    return 0;
    }

    http://blog.csdn.net/xueyushenzhou/article/details/17486143

  • 相关阅读:
    开始准备考研了
    ubuntu安装完vbox没有无缝模式
    Terminator快捷键
    ubuntu启动慢显示waiting for network configuration
    terminal快捷键
    openstack根据软件选择实例resume
    输出数组的全排列
    给非同步的集合加锁原理。
    集合框架—ArrayList的用法
    集合框架 Map的小例子
  • 原文地址:https://www.cnblogs.com/findumars/p/5706024.html
Copyright © 2011-2022 走看看