亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? idea.c

?? IDEA算法源代碼
?? C
字號:
/*IDEA.C   v2.2
	c source code for IDEA block cipher. IDEA (International Data
	Encryption Algorithm), formerly known as IPES (Improved Proposed
	Encryption Standard). Algorithm developed by Xuejia Lai and James L.
	Massey, of ETH Zurich. This implementation modified and derived from
	original C code developed by Xuejia Lai. Zero-based indexing added,
	names changed from IPES to IDEA. CFB functions added. Random Number
	routines added. Optimized for speed 21 Oct 92 by Colin Plumb
	<colin@nsq.gts.org>  This code assumes that each pair of 8-bit bytes
	comprising a 16-bit word in the key and in the cipher block are
	externally represented with the Most Significant Byte (MSB) first,
	regardless of internal native byte order of the target cpu.
	modified for use with PC files by Colin Maroney 4/1/94*/

/*   USAGE:     pass a key made up of 8 16-bit numbers (word16) in an array
		("word16 key[8];"), an input FILE * and an output temporary
		FILE * to either encode_file() or decode_file().
		where the key comes from is up to you.
		then call swap_files_and_clean_up() with the original file's
		name as the argument, to replace the original file
		with the encoded data (stored in the temporary file).

		you can remname the tempfile to be used in idea.h
		noisy is an integer which tells encrypting/decrypting
		functions to echo a "." every 256 writes, so the user can
		see that something is happening. set it to 0 for quiet
		running.

		please note that for really good security the original file
		is overwritten before being erased if you use the w switch.
		otherwise it outputs a file "<filename>.enc"

		the main() used here as illustration reads the filename
		from the command line arguments, as well as a command
		"e" or "d" to tell it whether to encrypt or
		decrypt, and a key.  the older versions had an interface
		for when a command line was not use.  lack of editing 
		features made this buggy, so i axed it. */


#include "idea.h"

static uint16 inv(uint16 x)
{
   uint16 t0,t1;
   uint16 q,y;
   if (x<=1)
      return x;
   t1=(uint16)(0x10001l/x);
   y=(uint16)(0x10001l%x);
   if (y==1)
	return low16(1-t1);
   t0=1;
   do
   {
      q=x/y;
      x=x%y;
      t0+=q*t1;
      if (x==1)
	return t0;
      q=y/x;
      y=y%x;
      t1+=q*t0;
   } while (y!=1);
   return low16(1-t1);
}

static void en_key_idea(word16 *userkey, word16 *Z)
{
   int i,j;
   /* shifts */
   for (j=0;j<8;j++)
      Z[j]=*userkey++;
   for (i=0;j<KEYLEN;j++)
   {
      i++;
      Z[i+7]=((Z[i&7] << 9) | (Z[i+1 & 7] >> 7));
      Z+=i&8;
      i&=7;
   }
}

static void de_key_idea(IDEAkey Z,IDEAkey DK)
{
   int j;
   uint16 t1,t2,t3;
   IDEAkey T;
   word16 *p=T+KEYLEN;
   t1=inv(*Z++);
   t2=-*Z++;
   t3=-*Z++;
   *--p=inv(*Z++);
   *--p=t3;
   *--p=t2;
   *--p=t1;
   for (j=1;j<ROUNDS;j++)
   {
      t1=*Z++;
      *--p=*Z++;
      *--p=t1;
      t1=inv(*Z++);
      t2=-*Z++;
      t3=-*Z++;
      *--p=inv(*Z++);
      *--p=t2;
      *--p=t3;
      *--p=t1;
   }
   t1=*Z++;
   *--p=*Z++;
   *--p=t1;
   t1=inv(*Z++);
   t2=-*Z++;
   t3=-*Z++;
   *--p=inv(*Z++);
   *--p=t3;
   *--p=t2;
   *--p=t1;
   /*copy and destroy temp copy*/
   for(j=0,p=T;j<KEYLEN;j++)
   {
      *DK++=*p;
      *p++=0;
   }
}


uint16 mul(uint16 a, uint16 b)
{
   word32 p;

   if (a)
   {
      if (b)
      {
	 p=(word32)a*b;
	 b=(uint16)(low16(p));
	 a=(uint16)(p>>16);
	 return b-a+(b<a);
      }
      else
      {
	 return 1-a;
      }
   }
   else
      return 1-b;
}

#define MUL(x,y) (x=mul(low16(x),y))


#define CONST

static void cipher_idea(word16 in[4],word16 out[4],register CONST IDEAkey Z)
{
   register uint16 x1,x2,x3,x4,t1,t2;
   int r=ROUNDS;
   x1=*in++; x2=*in++;
   x3=*in++; x4=*in;
   do
   {
      MUL(x1,*Z++);
      x2+=*Z++;
      x3+=*Z++;
      MUL(x4,*Z++);
      t2=x1^x3;
      MUL(t2,*Z++);
      t1=t2+(x2^x4);
      MUL(t1,*Z++);
      t2=t1+t2;
      x1^=t1;
      x4^=t2;
      t2^=x2;
      x2=x3^t1;
      x3=t2;
   } while (--r);
   MUL(x1,*Z++);
   *out++=x1;
   *out++=(x3+*Z++);
   *out++=(x2+*Z++);
   MUL(x4,*Z);
   *out=x4;
}

char read_char_from_file(FILE *fp)
{
   char temp=0;

   if ((fread(&temp,sizeof(char),1,fp))!=1)
      end_of_file=1;

   return (temp);
}

word16 read_word16_from_file(FILE *fp)
{
   word16 temp=0;

   if ((fread(&temp,sizeof(word16),1,fp))!=1)
      end_of_file=1;

   return temp;
}

void write_char_to_file(char data,FILE *fp)
{
   if ((fwrite(&data,sizeof(char),1,fp))!=1)
   {
      printf("Fatal Error writing output file!!!\n");
      exit(-1);
   }
}

void write_word16_to_file(word16 data,FILE *fp)
{
   if ((fwrite(&data,sizeof(word16),1,fp))!=1)
   {
      printf("Fatal Error writing output file!!!\n");
      exit(-1);
   }
}


void cipher_file(FILE *in,FILE *out,word16 *key)
{
   word16 input[4],output[4];
   IDEAkey Z;
   int x,y;
   int count=0;
   long length;
   int temp;

   en_key_idea(key,Z);
   end_of_file=0;

   length=filelength(fileno(in));
   fwrite(&length,sizeof(long),1,out);

   while (!end_of_file)
   {
      x=0;

      while (x<4)
      {
	 input[x]=((word16)(read_char_from_file(in)<<8));
	 if (!end_of_file)
	 {
	    temp=read_char_from_file(in);
	    if (temp<0) temp+=256;
	    input[x]=input[x]|temp;
	    x++;
	 }
	 if (end_of_file)
	 {
	    while (x<4) input[x++]=0;
	    break;
	 }
      }

      cipher_idea(input,output,Z);

      for (y=0;y<x;y++)
      {
	 if (noisy) if (count++%256==0) printf(".");
	 write_word16_to_file(output[y],out);
      }
   }
}

void decipher_file(FILE *in,FILE *out,word16 *key)
{
   word16 input[4],output[4];
   int x,y;
   IDEAkey Z,DK;
   int count=0;
   long length=0;

   en_key_idea(key,Z);
   de_key_idea(Z,DK);

   end_of_file=0;

   fread(&length,sizeof(long),1,in);


   while (!end_of_file)
   {
      x=0;
      while (x<4)
      {
	 input[x]=read_word16_from_file(in);
	 if (end_of_file)
	    break;
	 x++;
      }
      cipher_idea(input,output,DK);
      for (y=0;y<x;y++)
      {
	 if (noisy) if (count++%256==0) printf(".");
	 if (length-->0)
	    write_char_to_file(((char)(output[y]>>8)),out);
	 if (length-->0)
	    write_char_to_file(((char)(output[y]&255)),out);
      }
   }
}

void swap_files_and_clean_up(char *file)
{
   long fsize,count;
   FILE *fp;
   char temp[100];

   if (overwrite)
   {
      if ((fp=fopen(file,"r+b"))==NULL)
      {
	 printf("\nError overwriting old file, security compromised.\n");
      }
      else
      {
	 fseek(fp,0l,SEEK_END);
	 fsize=ftell(fp);
	 fseek(fp,0l,SEEK_SET);
	 for (count=0;count<fsize;count++)
	    fputc('0',fp);
	 fclose(fp);
      }

      if ((remove(file))!=0)
      {
	 printf("\nERROR removing old file <%s>\n",file);
	 printf("encoded data remains in temporary file <%s>\n",tempfilename);
	 exit(-1);
      }
   }
   else
   {
      strcpy(temp,file);
      file=strtok(temp,".");
      strcat(file,".enc");
   }

   if ((rename(tempfilename,file))!=0)
   {
      printf("\nERROR renaming temporary file <%s>!!\n",tempfilename);
      printf("Data is safely processed and stored in that file.\n");
      exit(-1);
   }
}





/*-----------------------------------------------*/


#define KBYTES 1024

void getuserkeyfromargv(word16 *key,char *arg)
{
   int x;

   for (x=0;x<strlen(arg) && x<8;x++)
   {
       if (x==0) key[x]=arg[x]<<8;
       else key[x]=((arg[x]<<8)|(key[x-1]>>8));
   }

   if (strlen(arg)>8) printf ("\nONLY first *8* characters of key used!!!\n");

   if (x<8) while (x<8) key[x++]=0;
}

main(int argc, char **argv)
{
   word16 userkey[8];
   char filename[100];
   FILE *fp,*temp;
   int to_or_from;


   noisy=1;
   overwrite=0;

   if (argc!=4)
   {
      printf("\nUsage: idea filename.ext [e|d[w]] key\n");
      printf("          e=encode   d=decode   w=overwrite file\n");
      printf("       NOTE: Key must be no longer than 8 characters long!!!\n");
      exit(-1);
   }
   else
   {
      strncpy(filename,argv[1],99);
      filename[99]='\0';
      if (argv[2][0]=='e') to_or_from=1;
      else if (argv[2][0]=='d') to_or_from=0;
      else
      {
	 printf("\nUsage: idea filename.ext [e|d[w]] key\n");
	 printf("		e=encrypt d=decrypt w=overwrite file\n");
	 printf("       NOTE: Key must be no longer than 8 characters long!!!\n");
	 exit(-1);
      }
      if (argv[2][1]=='w') overwrite=1;
      getuserkeyfromargv(userkey,argv[3]);
   }


   if ((fp=fopen(filename,"r+b"))==NULL)
   {
      printf("\nError opening File %s\n",filename);
      exit (-1);
   }

   if ((temp=fopen(tempfilename,"w+b"))==NULL)
   {
      printf("\nError opening temporary file\n");
      exit(-1);
   }

   if (to_or_from==1)
   {
      printf("\nEncoding file %s   ",filename);
      cipher_file(fp,temp,userkey);
   }
   else
   {
      printf("\nDecoding file %s   ",filename);
      decipher_file(fp,temp,userkey);
   }

   fclose (fp);
   fclose(temp);

   swap_files_and_clean_up(filename);

   return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品亚洲国产奇米99| 亚洲午夜激情av| 一区二区免费看| 麻豆精品在线视频| 91黄色激情网站| 中文一区二区完整视频在线观看| 亚洲国产精品久久久男人的天堂| 国产成人综合视频| 欧美成人三级电影在线| 亚洲曰韩产成在线| 99国产精品国产精品久久| 日韩视频一区二区在线观看| 一区二区三区久久久| 成人少妇影院yyyy| 26uuu亚洲综合色欧美| 午夜电影网一区| 在线免费一区三区| 亚洲女同女同女同女同女同69| 精品一区二区三区久久久| 欧美日本乱大交xxxxx| 亚洲精品亚洲人成人网| jiyouzz国产精品久久| 欧美激情在线免费观看| 国产成人在线视频播放| 久久人人超碰精品| 精品一区二区在线看| 在线播放欧美女士性生活| 一区二区三区资源| 在线观看免费亚洲| 亚洲黄色小说网站| 在线亚洲+欧美+日本专区| 亚洲狼人国产精品| 色视频一区二区| 亚洲制服丝袜av| 在线国产电影不卡| 亚洲成人你懂的| 欧美精选一区二区| 蜜乳av一区二区| 26uuu精品一区二区三区四区在线| 蜜桃精品在线观看| 国产视频在线观看一区二区三区 | 欧美视频一区二| 亚洲一区二区三区四区五区黄| 91蜜桃网址入口| 亚洲图片欧美色图| 欧美日韩成人一区| 免费成人av资源网| 精品国产乱码久久久久久1区2区 | 日韩精品一区二区三区在线 | 成人av在线看| 一区二区三区欧美视频| 欧美日韩亚州综合| 开心九九激情九九欧美日韩精美视频电影| 91精品国产综合久久精品性色| 免费成人在线观看视频| 久久亚洲精品国产精品紫薇 | 精品中文字幕一区二区| 久久久久国产精品麻豆ai换脸| 成人在线综合网| 亚洲成人自拍一区| 亚洲精品一线二线三线| eeuss鲁一区二区三区| 亚洲成人黄色影院| 国产喂奶挤奶一区二区三区| 成人网页在线观看| 天天色图综合网| 国产日韩欧美激情| 欧美日韩一卡二卡三卡| 国产自产v一区二区三区c| 亚洲欧洲日本在线| 欧美一区二区三区免费大片| 国产精品资源在线观看| 亚洲一区二区在线免费观看视频 | 免费在线观看日韩欧美| 国产精品无遮挡| 欧美日本韩国一区二区三区视频| 久久99国内精品| 亚洲制服欧美中文字幕中文字幕| 精品久久久久久久久久久久久久久| 成人视屏免费看| 久久国产精品72免费观看| 中文字幕一区二区三区精华液 | 中文字幕乱码亚洲精品一区| 欧美日韩在线亚洲一区蜜芽| 国产乱码精品1区2区3区| 亚洲成a人片在线不卡一二三区 | 成人短视频下载 | 午夜欧美电影在线观看| 国产欧美日韩精品在线| 7777精品伊人久久久大香线蕉经典版下载| 国产成人综合网站| 精品一区二区久久| 日本人妖一区二区| 亚洲美女在线一区| 亚洲国产精品黑人久久久| 日韩欧美一级二级| 欧美日韩在线免费视频| 风间由美性色一区二区三区| 日本不卡的三区四区五区| 亚洲精品高清在线观看| 欧美极品aⅴ影院| 日韩欧美黄色影院| 欧美一区二区性放荡片| 欧美日韩色综合| 欧洲色大大久久| 色先锋资源久久综合| 99re这里只有精品首页| 国产成人8x视频一区二区| 久久爱另类一区二区小说| 日韩电影在线看| 五月天久久比比资源色| 亚洲大片一区二区三区| 亚洲高清免费视频| 亚洲综合图片区| 一个色在线综合| 亚洲一区免费在线观看| 亚洲国产视频一区| 亚洲一区视频在线| 亚洲成在人线免费| 日韩精品亚洲专区| 青青青爽久久午夜综合久久午夜| 亚欧色一区w666天堂| 丝袜亚洲另类丝袜在线| 三级久久三级久久久| 日本伊人色综合网| 麻豆一区二区三| 国产美女av一区二区三区| 国产一区二区精品在线观看| 国产综合一区二区| 成人免费av资源| 91黄色免费观看| 91精品麻豆日日躁夜夜躁| 欧美mv日韩mv| 国产精品污www在线观看| 亚洲欧洲另类国产综合| 亚洲激情图片一区| 日韩高清在线观看| 国产成人免费视频| 在线观看一区日韩| 日韩欧美国产麻豆| 久久久精品tv| 一区二区在线观看视频在线观看| 亚洲国产精品嫩草影院| 激情欧美一区二区三区在线观看| 国产麻豆日韩欧美久久| 99在线精品一区二区三区| 在线观看不卡一区| 久久综合给合久久狠狠狠97色69| 中文字幕在线一区免费| 香蕉av福利精品导航| 国产乱子伦视频一区二区三区| 91麻豆国产精品久久| 欧美欧美午夜aⅴ在线观看| 久久精品一区二区三区不卡牛牛| 自拍偷拍国产亚洲| 久久精品国产免费看久久精品| 风流少妇一区二区| 555www色欧美视频| 亚洲欧洲av在线| 美女视频一区在线观看| 99精品久久久久久| 精品久久五月天| 亚洲第一电影网| 不卡视频一二三四| 日韩欧美黄色影院| 亚洲愉拍自拍另类高清精品| 狠狠色丁香婷婷综合久久片| av亚洲产国偷v产偷v自拍| 日韩欧美第一区| 亚洲18色成人| 一本色道久久综合狠狠躁的推荐| 日韩天堂在线观看| 亚洲午夜电影在线观看| 国产aⅴ精品一区二区三区色成熟| 欧美丝袜丝nylons| 亚洲日本欧美天堂| 国产精品一级黄| 欧美一区二区国产| 午夜欧美在线一二页| 9人人澡人人爽人人精品| 久久精品一区二区三区av| 日韩av一级电影| 久久久久九九视频| 老司机午夜精品| 欧美日韩精品久久久| 亚洲码国产岛国毛片在线| 国产永久精品大片wwwapp| 555夜色666亚洲国产免| 亚洲国产日韩一区二区| 色综合久久久久久久久久久| 国产精品免费丝袜| 国产成人高清在线| 久久精品欧美一区二区三区不卡| 美女视频黄 久久| 欧美v国产在线一区二区三区| 午夜精品免费在线| 在线综合亚洲欧美在线视频| 亚洲在线视频网站| 欧美日韩精品一区二区| 亚洲aⅴ怡春院|