青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

S.l.e!ep.¢%

像打了激速一樣,以四倍的速度運轉,開心的工作
簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
posts - 1098, comments - 335, trackbacks - 0, articles - 1
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

about des_encrypt()

Posted on 2010-01-22 10:51 S.l.e!ep.¢% 閱讀(1129) 評論(0)  編輯 收藏 引用

des_encrypt() -- SSLeay 0.9.0b -- January 1999

NAME

des_encrypt, des_encrypt2, des_ecb_encrypt, des_cbc_encrypt, des_ncbc_encrypt,
des_xcbc_encrypt, des_pcbc_encrypt, des_cfb_encrypt, des_cfb64_encrypt,
des_ofb_encrypt, des_ofb64_encrypt -- DES encryption

SYNOPSIS

#include "des.h"

void des_encrypt(data,ks,enc)
unsigned long *data;
des_key_schedule ks; int enc;

void des_encrypt2(data,ks,enc)
unsigned long *data;
des_key_schedule ks; int enc;

void des_ecb_encrypt(input,output,ks,enc)
des_cblock *input, *output;
des_key_schedule ks; int enc;

void des_cbc_encrypt(input,output,length,ks,ivec,enc)
des_cblock *input, *output, *ivec;
long length;
des_key_schedule ks;
int enc;

void des_ncbc_encrypt(input,output,length,ks,ivec,enc)
des_cblock *input, *output, *ivec;
long length;
des_key_schedule ks;
int enc;

void des_xcbc_encrypt(input,output,length,ks,ivec,inw,outw,enc)
des_cblock *input, *output, *ivec, *inw, *outw;
des_cblock *output;
long length;
des_key_schedule ks;
int enc;

void des_pcbc_encrypt(input,output,length,ks,ivec,enc)
des_cblock *input, *output, *ivec;
long length;
des_key_schedule ks;
int enc;

void des_cfb_encrypt(in,out,numbits,length,ks,ivec,enc)
unsigned char *input, *output;
int numbits, enc;
long length;
des_key_schedule ks;
des_cblock *ivec;

void des_cfb64_encrypt(in,out,length,ks,ivec,num,enc)
unsigned char *in, *out;
long length;
des_key_schedule ks;
des_cblock *ivec;
int *num, enc;

void des_ofb_encrypt(in,out,numbits,length,ks,ivec)
unsigned char *in, *out;
int numbits;
long length;
des_key_schedule ks;
des_cblock *ivec;

void des_ofb64_encrypt(in,out,length,ks,ivec,num)
unsigned char *in, *out;
long length;
des_key_schedule ks;
des_cblock *ivec;
int *num;

DESCRIPTION

In any function prototype which has arguments input and output, the same variable can be passed for both arguments.

des_encrypt() is the basic building block used by all of the other DES encryption routines. It should be used only to implement a DES mode that the library doesn't already supply.

des_encrypt operates on data which is a pointer to two DES_LONGs (at least 4 characters per element, maybe more depending on how large a long is on your machine, but in that case, the extra bytes are treated as padding). In order to make this work right, each function implementing a DES mode does conversion of the input block, essentially a string of characters, to an array of DES_LONGs before invoking des_encrypt. After the encryption the function does the reverse conversion. Here's an example (from ecb_enc.c):

void des_ecb_encrypt(input, output, ks, encrypt)
des_cblock (*input);
des_cblock (*output);
des_key_schedule ks;
int encrypt;
        {
        register DES_LONG l;
        register unsigned char *in,*out;
        DES_LONG ll[2];

        in=(unsigned char *)input;
        out=(unsigned char *)output;
        c2l(in,l); ll[0]=l;
        c2l(in,l); ll[1]=l;
        des_encrypt(ll,ks,encrypt);
        l=ll[0]; l2c(l,out);
        l=ll[1]; l2c(l,out);
        l=ll[0]=ll[1]=0;
        }

ks is a previously-initialized des_key_schedule.

enc takes either the value DES_ENCRYPT, in which case encryption is performed, or DES_DECRYPT, in which case decryption is performed.

des_encrypt2() is identical to des_encrypt except that the DES initial permutation (IP) and final permutation (FP) have been left out. Again, this function should not be used except to implement new DES modes.

It is currently used to implement the various triple-DES modes.

(IP() des_encrypt2() des_encrypt2() des_encrypt2() FP()
is the same as
des_encrypt() des_encrypt() des_encrypt()
except faster :-).)

des_ecb_encrypt() is the Electronic Code Book form of DES, the most basic form of the algorithm. The des_cblock pointed to by input is encrypted into the block pointed to by output (which may be the same as input) using the key represented by ks. enc takes either the value DES_ENCRYPT, in which case encryption is performed, or DES_DECRYPT, in which case decryption is performed.

des_cbc_encrypt() implements DES in Cipher Block Chaining mode. The des_cblocks pointed to by input are encrypted (or decrypted) to the blocks pointed to by output.

Length should contain the number of des_cblocks * 8 (i.e. the total length of the input).

If length is not a multiple of 8, the results are unpredictable.

ivec is used to hold the output cipher text before calling the function again, if you are encrypting a text in several separate calls. This output is typically used in some way to modify the algorithm so that, if you use one of the chaining or feedback modes, encryption of the same block of text does not always give the same output (but encryption of the same block of text, with the same ivec in place, will typically give the same output).

See DES encryption modes overview for a discussion of the various modes.

For more details about the modes, see FIPS Pub 81: DES Modes of Operation; this is the updated version from May of 1996.

Unfortunately, this function does not automatically update ivec; the user must do it by copying in the last 8 bytes of output cipher text into ivec before the next call to this function.

ivec must be initialized to some known (but randomly generated) state before calling this function on the first chunk of data (and when you decrypt the data, the same initialization needs to be used for the first decryption call).

For example (from destest.c),

    des_cbc_encrypt((C_Block *)cbc_data,(C_Block *)cbc_out,
         (long)strlen((char *)cbc_data)+1,ks,
         (C_Block *)cbc_iv,DES_ENCRYPT);
    des_cbc_encrypt((C_Block *)cbc_out,(C_Block *)cbc_in,
         (long)strlen((char *)cbc_data)+1,ks,
         (C_Block *)cbc_iv,DES_DECRYPT);

where cbc_iv has been initialized previously by the user.

des_ncbc_encrypt() is identical to des_cbc_encrypt except that it does the update of ivec automatically. For tha reason it should be used in preference to des_cbc_encrypt whenever possible.

des_xcbc_encrypt() is RSA's DESX mode of DES. It uses inw and outw, supplied by the user, to 'whiten' the key. These should be nice random strings like the DES key unless the user is choosing them manually.

DESX is defined as key1 xor (des ( key2 xor input ) ), where the des encryption is done with a third key key3. Here, inw is keyn, and outw is keyn.

This substantially strengthens the algorithm against exhaustive search of the key space; see DES algorithm references for more details.

des_pcbc_encrypt() is the Propagating Cipher Block Chaining mode of DES. It is used by Kerberos v4. Its parameters are the same as des_ncbc_encrypt().

des_cfb_encrypt() is the Cipher Feedback mode of DES. This implementation 'feeds back' in numbit blocks. The input in) and the output out is in multiples of numbits bits, and numbit should be a multiple of 8 bits. length is the number of bytes in in.

If numbits is not a multiple of 8 bits, the extra bits in the bytes will be considered padding. For example, if numbits is 12, for each 2 input bytes, the 4 high bits of the second byte will be ignored. So to encode 72 bits when using numbits of 12 takes 12 bytes. To encode 72 bits when using numbits of 9 will take 16 bytes. To encode 80 bits when using numbits of 16 will take 10 bytes, and so on. This padding factor applies to both in and out.

ivec is used to keep intermediate results for subsequent calls, and as input to the function the first time it is called on a text.

It should be initialized to a known (but randomly generated) state before this function is called on the first part of a piece of data.

ks is a key schedule that has been previously set by des_set_key.

enc takes either the value DES_ENCRYPT, in which case encryption is performed, or DES_DECRYPT, in which case decryption is performed.

des_cfb64_encrypt() implements the Cipher Feedback Mode of DES, with 64 bit feedback. The arguments are the same as for des_cfb_encrypt except that there is no numbits argument, because there is no padding factor, and there is an additional num argument which is updated by the function along with ivec after each call.

The num argument is updated to show how many bytes of the ivec have been used; one step in the algorithm includes the xor of a byte of the plaintext with a byte of the (encrypted) ivec, so that all 8 bytes of the ivec are used in turn for an input block of 8 bytes. As each byte of the ivec is used, a new byte is created by the algorithm and stuffed into the ivec in place of the used byte. The following byte would be used next, and so on. num can be thought of as a pointer into the ivec to show which byte to start xor-ing with, the next time the function is called.

des_ofb_encrypt() is a implementation of the Output Feedback mode of DES. Its parameters are the same as those of des_cfb_encrypt() except that there is no < b>argument; encryption and decryption use the same arguments. in and out must be multiples of numbits long, numbits should be a multiple of 8 bits, and if it is not, the same padding factor comes into play.

Note that there is no enc parameter; this algorithm functions the same for encryption and decryption.

des_ofb64_encrypt() implements the Output Feedback Mode of DES, with 64 bit feedback. The arguments are the same as for des_cfb64_encrypt.


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲品质自拍| 午夜日韩在线观看| 欧美激情在线有限公司| 亚洲片在线观看| 亚洲欧洲精品一区二区三区波多野1战4| 久久亚洲综合色| 日韩亚洲精品视频| 99国产精品视频免费观看一公开| 欧美日韩免费观看一区二区三区 | 91久久国产综合久久蜜月精品| 欧美成人午夜视频| 欧美日产在线观看| 亚洲欧美一区二区原创| 欧美一二区视频| 亚洲国产精品精华液2区45 | 亚洲亚洲精品在线观看 | 欧美高清免费| 欧美日韩精品一区二区三区| 亚洲综合日韩在线| 久久精品国产亚洲精品| 亚洲精品国产精品久久清纯直播| 99视频有精品| 国产综合色在线视频区| 亚洲人成亚洲人成在线观看图片| 欧美吻胸吃奶大尺度电影| 久久福利精品| 欧美日韩精品免费在线观看视频| 久久亚洲私人国产精品va| 亚洲精品一二区| 午夜欧美不卡精品aaaaa| 亚洲国产综合在线看不卡| av不卡在线看| 亚洲黄网站在线观看| 亚洲欧美另类综合偷拍| 亚洲国产中文字幕在线观看| 亚洲一区在线播放| 亚洲人成网站在线播| 亚洲欧美一区二区精品久久久 | 欧美成人午夜剧场免费观看| 亚洲综合激情| 欧美激情91| 久久狠狠亚洲综合| 欧美日韩一区在线| 欧美91福利在线观看| 国产精品日韩久久久| 亚洲国产裸拍裸体视频在线观看乱了 | 另类国产ts人妖高潮视频| 欧美日韩天天操| 亚洲国产99| 影音先锋日韩有码| 亚洲欧美影院| 亚洲女同同性videoxma| 欧美激情一区二区三区成人| 久久综合一区二区三区| 国产日韩av一区二区| 亚洲亚洲精品在线观看| 亚洲影视中文字幕| 欧美日韩精品免费观看| 亚洲欧洲一区| a4yy欧美一区二区三区| 欧美成人在线免费视频| 欧美激情免费观看| 亚洲高清视频在线观看| 久久青青草综合| 欧美成人中文字幕| 亚洲国产精品t66y| 免费在线看成人av| 亚洲国产美女| 日韩视频在线一区二区| 欧美大片在线观看一区| 亚洲人www| 亚洲视频一区在线| 国产精品福利网| 亚洲在线视频网站| 久久久综合香蕉尹人综合网| 激情视频一区| 欧美大片一区二区三区| 亚洲激情视频网站| 亚洲色在线视频| 国产女人精品视频| 久久久欧美精品| 亚洲国产精品免费| 亚洲视频免费| 国产日韩免费| 久久免费少妇高潮久久精品99| 欧美电影美腿模特1979在线看 | 国产精品日韩一区| 欧美在线免费观看视频| 欧美成人免费全部观看天天性色| 亚洲国产日韩在线| 欧美日韩一区综合| 午夜免费日韩视频| 欧美福利影院| 亚洲免费一在线| 好吊日精品视频| 欧美激情免费在线| 亚洲欧美日韩一区在线观看| 免费观看久久久4p| 亚洲午夜激情| 在线播放国产一区中文字幕剧情欧美| 欧美国产精品| 欧美亚洲自偷自偷| 亚洲人www| 久久久久久色| 亚洲一区二区三区视频播放| 国语自产精品视频在线看| 欧美精品一区二区三| 欧美一区二区三区另类| 亚洲三级视频| 久久一区二区三区四区| 亚洲视频在线一区| 亚洲国产精品视频一区| 国产精品视频第一区| 欧美激情91| 久久久久久久综合色一本| 亚洲视频电影图片偷拍一区| 欧美国产91| 久久久午夜视频| 午夜精品视频在线| av成人天堂| 亚洲国产日韩欧美在线99| 国产欧美日韩免费| 国产精品久久精品日日| 欧美.www| 久久艳片www.17c.com| 小黄鸭视频精品导航| 99精品欧美一区二区三区| 欧美国产欧美综合| 蜜乳av另类精品一区二区| 亚洲欧美国产77777| 制服丝袜亚洲播放| 亚洲另类黄色| 亚洲人成在线观看网站高清| 在线不卡a资源高清| 国产一区香蕉久久| 国产欧美日韩在线视频| 国产乱码精品一区二区三区五月婷| 欧美精品一区二区精品网| 蜜桃av一区二区三区| 久久精品成人欧美大片古装| 欧美一区二区国产| 欧美一级理论片| 久久国产精品久久久久久久久久| 亚洲视屏一区| 亚洲女同在线| 欧美亚洲一区二区三区| 久久爱www| 久久精品欧美| 麻豆91精品| 欧美激情中文字幕一区二区| 欧美韩日一区二区三区| 欧美人成网站| 国产精品人人爽人人做我的可爱 | 国产欧美 在线欧美| 国产精品男女猛烈高潮激情| 国产乱码精品一区二区三区五月婷| 欧美先锋影音| 国产欧美日韩高清| 精品不卡在线| 亚洲精品中文字幕在线观看| 亚洲视频每日更新| 午夜视频在线观看一区| 久久久久久久精| 欧美高清自拍一区| 日韩午夜激情| 欧美一区二区精品| 鲁大师影院一区二区三区| 欧美另类亚洲| 国产手机视频一区二区| 1024亚洲| 亚洲尤物视频网| 久久五月激情| 亚洲精品免费在线播放| 亚洲免费一级电影| 久久伊人一区二区| 欧美视频在线观看一区二区| 国产亚洲一本大道中文在线| 亚洲狠狠婷婷| 亚洲欧美视频一区| 亚洲电影在线| 羞羞色国产精品| 欧美日韩hd| 在线观看视频一区二区| 亚洲自拍偷拍麻豆| 欧美激情按摩在线| 亚洲欧美日韩天堂一区二区| 欧美bbbxxxxx| 国模 一区 二区 三区| 亚洲视频一区| 亚洲电影在线播放| 欧美综合国产| 国产精品久久久久一区二区| 亚洲清纯自拍| 久久综合久色欧美综合狠狠| 一本色道久久综合亚洲精品按摩| 久久精品成人一区二区三区蜜臀 | 久久久噜噜噜久噜久久| 国产精品成人一区二区| 91久久夜色精品国产九色| 久久精品二区三区|