三度网教程:是一个免费提供流行视频软件教程、在线学习分享的学习平台!

Linux为OpenSSL添加自定义加密算法的技巧

时间:2024-1-19作者:未知来源:三度网教程人气:


Linux,全称GNU/Linux,是一种免费使用和自由传播的类UNIX操作系统,其内核由林纳斯·本纳第克特·托瓦兹于1991年10月5日首次发布,它主要受到Minix和Unix思想的启发,是一个基于POSIX的多用户、多任务、支持多线程和多CPU的操作系统。

  Linux系统OpenSSL是一套密码库系统,所以Linux系统使用OpenSSL的过程中,就一定会涉及给OpenSSL添加加密算法,本文就来介绍一下Linux为OpenSSL添加自定义加密算法的技巧。

  一、简介

  本文以添加自定义算法EVP_ssf33为例,介绍在OpenSSL中添加自定义加密算法的方法

  二、步骤

  1、修改crypto/object/objects.txt,注册算法OID,如下:

  rsadsi 3 255: SSF33: ssf33

  2、进入目录:crypto/object/,执行如下命令,生成算法的声明

  perl objects.pl objects.txt obj_mac.num obj_mac.h

  3、在crypto/evp/下添加e_ssf33.c,内容如下

  #include 《stdio.h》

  #include “cryptlib.h”

  #ifndef OPENSSL_NO_RC4

  #include 《openssl/evp.h》

  #include 《openssl/objects.h》

  #include 《openssl/rc4.h》

  /* FIXME: surely this is available elsewhere? */

  #define EVP_SSF33_KEY_SIZE 16

  typedef struct

  {

  RC4_KEY ks; /* working key */

  } EVP_SSF33_KEY;

  #define data(ctx) ((EVP_SSF33_KEY *)(ctx)-》cipher_data)

  static int ssf33_init_key(EVP_CIPHER_CTX *ctx, const unsigned char *key, const unsigned char *iv,int enc);

  static int ssf33_cipher(EVP_CIPHER_CTX *ctx, unsigned char *out, const unsigned char *in, unsigned int inl);

  static const EVP_CIPHER ssf33_evp_cipher=

  {

  NID_ssf33,

  1,

  EVP_SSF33_KEY_SIZE,

  0,

  EVP_CIPH_VARIABLE_LENGTH,

  ssf33_init_key,

  ssf33_cipher,

  NULL,

  sizeof(EVP_SSF33_KEY),

  NULL,

  NULL,

  NULL,

  NULL

  };

  const EVP_CIPHER *EVP_ssf33(void)

  {

  return(&ssf33_evp_cipher);

  }

  static int ssf33_init_key(EVP_CIPHER_CTX *ctx, const unsigned char *key, const unsigned char *iv, int enc)

  {

  RC4_set_key(&data(ctx)-》ks,EVP_CIPHER_CTX_key_length(ctx), key);

  return 1;

  }

  static int ssf33_cipher(EVP_CIPHER_CTX *ctx, unsigned char *out, const unsigned char *in, unsigned int inl)

  {

  RC4(&data(ctx)-》ks,inl,in,out);

  return 1;

  }

  #endif

Linux是一套免费使用和自由传播的类Unix操作系统

关键词:  Linux为OpenSSL添加自定义加密算法的技巧





Copyright © 2012-2018 三度网教程(http://www.3du8.cn) .All Rights Reserved 网站地图 友情链接

免责声明:本站资源均来自互联网收集 如有侵犯到您利益的地方请及时联系管理删除,敬请见谅!

QQ:1006262270   邮箱:kfyvi376850063@126.com   手机版