1. 常用数据校验方法有哪些
奇偶校验”。内存中最小的单位是比特,也称为“位”,位有只有两种状态分别以1和0来标示,每8个连续的比特叫做一个字节(byte)。不带奇偶校验的内存每个字节只有8位,如果其某一位存储了错误的值,就会导致其存储的相应数据发生变化,进而导致应用程序发生错误。而奇偶校验就是在每一字节(8位)之外又增加了一位作为错误检测位。在某字节中存储数据之后,在其8个位上存储的数据是固定的,因为位只能有两种状态1或0,假设存储的数据用位标示为1、1、 1、0、0、1、0、1,那么把每个位相加(1+1+1+0+0+1+0+1=5),结果是奇数,那么在校验位定义为1,反之为0。当CPU读取存储的数据时,它会再次把前8位中存储的数据相加,计算结果是否与校验位相一致。从而一定程度上能检测出内存错误,奇偶校验只能检测出错误而无法对其进行修正,同时虽然双位同时发生错误的概率相当低,但奇偶校验却无法检测出双位错误。
MD5的全称是Message-Digest Algorithm 5,在90年代初由MIT的计算机科学实验室和RSA Data Security Inc 发明,由 MD2/MD3/MD4 发展而来的。MD5的实际应用是对一段Message(字节串)产生fingerprint(指纹),可以防止被“篡改”。举个例子,天天安全网提供下载的MD5校验值软件WinMD5.zip,其MD5值是,但你下载该软件后计算MD5 发现其值却是,那说明该ZIP已经被他人修改过,那还用不用该软件那你可自己琢磨着看啦。
MD5广泛用于加密和解密技术上,在很多操作系统中,用户的密码是以MD5值(或类似的其它算法)的方式保存的,用户Login的时候,系统是把用户输入的密码计算成MD5值,然后再去和系统中保存的MD5值进行比较,来验证该用户的合法性。
MD5校验值软件WinMD5.zip汉化版,使用极其简单,运行该软件后,把需要计算MD5值的文件用鼠标拖到正在处理的框里边,下面将直接显示其MD5值以及所测试的文件名称,可以保留多个文件测试的MD5值,选定所需要复制的MD5值,用CTRL+C就可以复制到其它地方了。
参考资料:http://..com/question/3933661.html
CRC算法原理及C语言实现 -来自(我爱单片机)
摘 要 本文从理论上推导出CRC算法实现原理,给出三种分别适应不同计算机或微控制器硬件环境的C语言程序。读者更能根据本算法原理,用不同的语言编写出独特风格更加实用的CRC计算程序。
关键词 CRC 算法 C语言
1 引言
循环冗余码CRC检验技术广泛应用于测控及通信领域。CRC计算可以靠专用的硬件来实现,但是对于低成本的微控制器系统,在没有硬件支持下实现CRC检验,关键的问题就是如何通过软件来完成CRC计算,也就是CRC算法的问题。
这里将提供三种算法,它们稍有不同,一种适用于程序空间十分苛刻但CRC计算速度要求不高的微控制器系统,另一种适用于程序空间较大且CRC计算速度要求较高的计算机或微控制器系统,最后一种是适用于程序空间不太大,且CRC计算速度又不可以太慢的微控制器系统。
2 CRC简介
CRC 校验的基本思想是利用线性编码理论,在发送端根据要传送的k位二进制码序列,以一定的规则产生一个校验用的监督码(既CRC码)r位,并附在信息后边,构成一个新的二进制码序列数共(k+r)位,最后发送出去。在接收端,则根据信息码和CRC码之间所遵循的规则进行检验,以确定传送中是否出错。
16位的CRC码产生的规则是先将要发送的二进制序列数左移16位(既乘以 )后,再除以一个多项式,最后所得到的余数既是CRC码,如式(2-1)式所示,其中B(X)表示n位的二进制序列数,G(X)为多项式,Q(X)为整数,R(X)是余数(既CRC码)。
(2-1)
求CRC 码所采用模2加减运算法则,既是不带进位和借位的按位加减,这种加减运算实际上就是逻辑上的异或运算,加法和减法等价,乘法和除法运算与普通代数式的乘除法运算是一样,符合同样的规律。生成CRC码的多项式如下,其中CRC-16和CRC-CCITT产生16位的CRC码,而CRC-32则产生的是32位的CRC码。本文不讨论32位的CRC算法,有兴趣的朋友可以根据本文的思路自己去推导计算方法。
CRC-16:(美国二进制同步系统中采用)
CRC-CCITT:(由欧洲CCITT推荐)
CRC-32:
接收方将接收到的二进制序列数(包括信息码和CRC码)除以多项式,如果余数为0,则说明传输中无错误发生,否则说明传输有误,关于其原理这里不再多述。用软件计算CRC码时,接收方可以将接收到的信息码求CRC码,比较结果和接收到的CRC码是否相同。
3 按位计算CRC
对于一个二进制序列数可以表示为式(3-1):
(3-1)
求此二进制序列数的CRC码时,先乘以 后(既左移16位),再除以多项式G(X),所得的余数既是所要求的CRC码。如式(3-2)所示:
(3-2)
可以设: (3-3)
其中 为整数, 为16位二进制余数。将式(3-3)代入式(3-2)得:
(3-4)
再设: (3-5)
其中 为整数, 为16位二进制余数,将式(3-5)代入式(3-4),如上类推,最后得到:
(3-6)
根据CRC的定义,很显然,十六位二进制数 既是我们要求的CRC码。
式(3 -5)是编程计算CRC的关键,它说明计算本位后的CRC码等于上一位CRC码乘以2后除以多项式,所得的余数再加上本位值除以多项式所得的余数。由此不难理解下面求CRC码的C语言程序。*ptr指向发送缓冲区的首字节,len是要发送的总字节数,0x1021与多项式有关。
[code]
unsigned int cal_crc(unsigned char *ptr, unsigned char len) {
unsigned char i;
unsigned int crc=0;
while(len--!=0) {
for(i=0x80; i!=0; i/=2) {
if((crc&0x8000)!=0) {crc*=2; crc^=0x1021;} /* 余式CRC乘以2再求CRC */
else crc*=2;
if((*ptr&i)!=0) crc^=0x1021; /* 再加上本位的CRC */
}
ptr++;
}
return(crc);
}
[code]
按位计算CRC虽然代码简单,所占用的内存比较少,但其最大的缺点就是一位一位地计算会占用很多的处理器处理时间,尤其在高速通讯的场合,这个缺点更是不可容忍。因此下面再介绍一种按字节查表快速计算CRC的方法。
4 按字节计算CRC
不难理解,对于一个二进制序列数可以按字节表示为式(4-1),其中 为一个字节(共8位)。
(4-1)
求此二进制序列数的CRC码时,先乘以 后(既左移16位),再除以多项式G(X),所得的余数既是所要求的CRC码。如式(4-2)所示:
(4-2)
可以设: (4-3)
其中 为整数, 为16位二进制余数。将式(4-3)代入式(4-2)得:
(4-4)
因为:
(4-5)
其中 是 的高八位, 是 的低八位。将式(4-5)代入式(4-4),经整理后得:
(4-6)
再设: (4-7)
其中 为整数, 为16位二进制余数。将式(4-7)代入式(4-6),如上类推,最后得:
(4-
很显然,十六位二进制数 既是我们要求的CRC码。
式(4 -7)是编写按字节计算CRC程序的关键,它说明计算本字节后的CRC码等于上一字节余式CRC码的低8位左移8位后,再加上上一字节CRC右移8位(也既取高8位)和本字节之和后所求得的CRC码,如果我们把8位二进制序列数的CRC全部计算出来,放如一个表里,采用查表法,可以大大提高计算速度。由此不难理解下面按字节求CRC码的C语言程序。*ptr指向发送缓冲区的首字节,len是要发送的总字节数,CRC余式表是按0x11021多项式求出的。
[code]
unsigned int cal_crc(unsigned char *ptr, unsigned char len) {
unsigned int crc;
unsigned char da;
unsigned int crc_ta[256]={ /* CRC余式表 */
0x0000, 0x1021, 0x2042, 0x3063, 0x4084, 0x50a5, 0x60c6, 0x70e7,
0x8108, 0x9129, 0xa14a, 0xb16b, 0xc18c, 0xd1ad, 0xe1ce, 0xf1ef,
0x 1231, 0x0210, 0x3273, 0x2252, 0x52b5, 0x4294, 0x72f7, 0x62d6,
0x9339, 0x8318, 0xb37b, 0xa35a, 0xd3bd, 0xc39c, 0xf3ff, 0xe3de,
0x2462, 0x3443, 0x0420, 0x1401, 0x64e6, 0x74c7, 0x44a4, 0x5485,
0xa56a, 0xb54b, 0x8528, 0x9509, 0xe5ee, 0xf5cf, 0xc5ac, 0xd58d,
0x3653, 0x2672, 0x1611, 0x0630, 0x76d7, 0x66f6, 0x5695, 0x46b4,
0xb75b, 0xa77a, 0x9719, 0x8738, 0xf7df, 0xe7fe, 0xd79d, 0xc7bc,
0x48c4, 0x58e5, 0x6886, 0x78a7, 0x0840, 0x1861, 0x2802, 0x3823,
0xc9cc, 0xd9ed, 0xe98e, 0xf9af, 0x8948, 0x9969, 0xa90a, 0xb92b,
0x5af5, 0x4ad4, 0x7ab7, 0x6a96, 0x1a71, 0x0a50, 0x3a33, 0x2a12,
0xdbfd, 0xcbdc, 0xfbbf, 0xeb9e, 0x9b79, 0x8b58, 0xbb3b, 0xab1a,
0x6ca6, 0x7c87, 0x4ce4, 0x5cc5, 0x2c22, 0x3c03, 0x0c60, 0x1c41,
0xedae, 0xfd8f, 0xcdec, 0xddcd, 0xad2a, 0xbd0b, 0x8d68, 0x9d49,
0x7e97, 0x6eb6, 0x5ed5, 0x4ef4, 0x3e13, 0x2e32, 0x1e51, 0x0e70,
0xff9f, 0xefbe, 0xdfdd, 0xcffc, 0xbf1b, 0xaf3a, 0x9f59, 0x8f78,
0x9188, 0x81a9, 0xb1ca, 0xa1eb, 0xd10c, 0xc12d, 0xf14e, 0xe16f,
0x1080, 0x00a1, 0x30c2, 0x20e3, 0x5004, 0x4025, 0x7046, 0x6067,
0x83b9, 0x9398, 0xa3fb, 0xb3da, 0xc33d, 0xd31c, 0xe37f, 0xf35e,
0x02b1, 0x1290, 0x22f3, 0x32d2, 0x4235, 0x5214, 0x6277, 0x7256,
0xb5ea, 0xa5cb, 0x95a8, 0x8589, 0xf56e, 0xe54f, 0xd52c, 0xc50d,
0x34e2, 0x24c3, 0x14a0, 0x0481, 0x7466, 0x6447, 0x5424, 0x4405,
0xa7db, 0xb7fa, 0x8799, 0x97b8, 0xe75f, 0xf77e, 0xc71d, 0xd73c,
0x26d3, 0x36f2, 0x0691, 0x16b0, 0x6657, 0x7676, 0x4615, 0x5634,
0xd94c, 0xc96d, 0xf90e, 0xe92f, 0x99c8, 0x89e9, 0xb98a, 0xa9ab,
0x5844, 0x4865, 0x7806, 0x6827, 0x18c0, 0x08e1, 0x3882, 0x28a3,
0xcb7d, 0xdb5c, 0xeb3f, 0xfb1e, 0x8bf9, 0x9bd8, 0xabbb, 0xbb9a,
0x4a75, 0x5a54, 0x6a37, 0x7a16, 0x0af1, 0x1ad0, 0x2ab3, 0x3a92,
0xfd2e, 0xed0f, 0xdd6c, 0xcd4d, 0xbdaa, 0xad8b, 0x9de8, 0x8dc9,
0x7c26, 0x6c07, 0x5c64, 0x4c45, 0x3ca2, 0x2c83, 0x1ce0, 0x0cc1,
0xef1f, 0xff3e, 0xcf5d, 0xdf7c, 0xaf9b, 0xbfba, 0x8fd9, 0x9ff8,
0x6e17, 0x7e36, 0x4e55, 0x5e74, 0x2e93, 0x3eb2, 0x0ed1, 0x1ef0
};
crc=0;
while(len--!=0) {
da=(uchar) (crc/256); /* 以8位二进制数的形式暂存CRC的高8位 */
crc<<=8; /* 左移8位,相当于CRC的低8位乘以 */
crc^=crc_ta[da^*ptr]; /* 高8位和当前字节相加后再查表求CRC ,再加上以前的CRC */
ptr++;
}
return(crc);
}
很显然,按字节求CRC时,由于采用了查表法,大大提高了计算速度。但对于广泛运用的8位微处理器,代码空间有限,对于要求256个CRC余式表(共512字节的内存)已经显得捉襟见肘了,但CRC的计算速度又不可以太慢,因此再介绍下面一种按半字节求CRC的算法。
5 按半字节计算CRC
同样道理,对于一个二进制序列数可以按字节表示为式(5-1),其中 为半个字节(共4位)。
(5-1)
求此二进制序列数的CRC码时,先乘以 后(既左移16位),再除以多项式G(X),所得的余数既是所要求的CRC码。如式(4-2)所示:
(5-2)
可以设: (5-3)
其中 为整数, 为16位二进制余数。将式(5-3)代入式(5-2)得:
(5-4)
因为:
(5-5)
其中 是 的高4位, 是 的低12位。将式(5-5)代入式(5-4),经整理后得:
(5-6)
再设: (5-7)
其中 为整数, 为16位二进制余数。将式(5-7)代入式(5-6),如上类推,最后得:
(5-
很显然,十六位二进制数 既是我们要求的CRC码。
式(5 -7)是编写按字节计算CRC程序的关键,它说明计算本字节后的CRC码等于上一字节CRC码的低12位左移4位后,再加上上一字节余式CRC右移4位(也既取高4位)和本字节之和后所求得的CRC码,如果我们把4位二进制序列数的CRC全部计算出来,放在一个表里,采用查表法,每个字节算两次(半字节算一次),可以在速度和内存空间取得均衡。由此不难理解下面按半字节求CRC码的C语言程序。*ptr指向发送缓冲区的首字节,len是要发送的总字节数,CRC余式表是按0x11021多项式求出的。
unsigned cal_crc(unsigned char *ptr, unsigned char len) {
unsigned int crc;
unsigned char da;
unsigned int crc_ta[16]={ /* CRC余式表 */
0x0000,0x1021,0x2042,0x3063,0x4084,0x50a5,0x60c6,0x70e7,
0x8108,0x9129,0xa14a,0xb16b,0xc18c,0xd1ad,0xe1ce,0xf1ef,
}
crc=0;
while(len--!=0) {
da=((uchar)(crc/256))/16; /* 暂存CRC的高四位 */
crc<<=4; /* CRC右移4位,相当于取CRC的低12位)*/
crc^=crc_ta[da^(*ptr/16)]; /* CRC的高4位和本字节的前半字节相加后查表计算CRC,
然后加上上一次CRC的余数 */
da=((uchar)(crc/256))/16; /* 暂存CRC的高4位 */
crc<<=4; /* CRC右移4位, 相当于CRC的低12位) */
crc^=crc_ta[da^(*ptr&0x0f)]; /* CRC的高4位和本字节的后半字节相加后查表计算CRC,
然后再加上上一次CRC的余数 */
ptr++;
}
return(crc);
}
[code]
5 结束语
以上介绍的三种求CRC的程序,按位求法速度较慢,但占用最小的内存空间;按字节查表求CRC的方法速度较快,但占用较大的内存;按半字节查表求CRC的方法是前两者的均衡,即不会占用太多的内存,同时速度又不至于太慢,比较适合8位小内存的单片机的应用场合。以上所给的C程序可以根据各微处理器编译器的特点作相应的改变,比如把CRC余式表放到程序存储区内等。[/code]
hjzgq 回复于:2003-05-15 14:12:51
CRC32算法学习笔记以及如何用java实现 出自:csdn bootcool 2002年10月19日 23:11 CRC32算法学习笔记以及如何用java实现
CRC32算法学习笔记以及如何用java实现
一:说明
论坛上关于CRC32校验算法的详细介绍不多。前几天偶尔看到Ross N. Williams的文章,总算把CRC32算法的来龙去脉搞清楚了。本来想把原文翻译出来,但是时间参促,只好把自己的一些学习心得写出。这样大家可以更快的了解CRC32的主要思想。由于水平有限,还恳请大家指正。原文可以访问:http://www.repairfaq.org/filipg/LINK/F_crc_v31.html 。
二:基本概念及相关介绍
2.1 什么是CRC
在远距离数据通信中,为确保高效而无差错地传送数据,必须对数据进行校验即差错控制。循环冗余校验CRC(Cyclic Rendancy Check/Code)是对一个传送数据块进行校验,是一种高效的差错控制方法。
CRC校验采用多项式编码方法。多项式乘除法运算过程与普通代数多项式的乘除法相同。多项式的加减法运算以2为模,加减时不进,错位,如同逻辑异或运算。
2.2 CRC的运算规则
CRC加法运算规则:0+0=0
0+1=1
1+0=1
1+1=0 (注意:没有进位)
CRC减法运算规则:
0-0=0
0-1=1
1-0=1
1-1=0
CRC乘法运算规则:
0*0=0
0*1=0
1*0=0
1*1=1
CRC除法运算规则:
1100001010 (注意:我们并不关心商是多少。)
_______________
10011 11010110110000
10011,,.,,....
-----,,.,,....
10011,.,,....
10011,.,,....
-----,.,,....
00001.,,....
00000.,,....
-----.,,....
00010,,....
00000,,....
-----,,....
00101,....
00000,....
-----,....
01011....
00000....
-----....
10110...
10011...
-----...
01010..
00000..
-----..
10100.
10011.
-----.
01110
00000
-----
1110 = 余数
2.3 如何生成CRC校验码
(1) 设G(X)为W阶,在数据块末尾添加W个0,使数据块为M+ W位,则相应的多项式为XrM(X);
(2) 以2为模,用对应于G(X)的位串去除对应于XrM(X)的位串,求得余数位串;
(3) 以2为模,从对应于XrM(X)的位串中减去余数位串,结果就是为数据块生成的带足够校验信息的CRC校验码位串。
2.4 可能我们会问那如何选择G(x)
可以说选择G(x)不是一件很容易的事。一般我们都使用已经被大量的数据,时间检验过的,正确的,高效的,生成多项式。一般有以下这些:
16 bits: (16,12,5,0) [X25 standard]
(16,15,2,0) ["CRC-16"]
32 bits: (32,26,23,22,16,12,11,10,8,7,5,4,2,1,0) [Ethernet]
三: 如何用软件实现CRC算法
现在我们主要问题就是如何实现CRC校验,编码和解码。用硬件实现目前是不可能的,我们主要考虑用软件实现的方法。
以下是对作者的原文的翻译:
我们假设有一个4 bits的寄存器,通过反复的移位和进行CRC的除法,最终该寄存器中的值就是我们所要求的余数。
3 2 1 0 Bits
+---+---+---+---+
Pop <-- | | | | | <----- Augmented message(已加0扩张的原始数据)
+---+---+---+---+
1 0 1 1 1 = The Poly
(注意: The augmented message is the message followed by W zero bits.)
依据这个模型,我们得到了一个最最简单的算法:
把register中的值置0.
把原始的数据后添加r个0.
While (还有剩余没有处理的数据)
Begin
把register中的值左移一位,读入一个新的数据并置于register的0 bit的位置。
If (如果上一步的左移操作中的移出的一位是1)
register = register XOR Poly.
End
现在的register中的值就是我们要求的crc余数。
我的学习笔记:
可为什么要这样作呢?我们从下面的实例来说明:
1100001010
_______________
10011 11010110110000
10011,,.,,....
-----,,.,,....
-》 10011,.,,....
10011,.,,....
-----,.,,....
-》 00001.,,....
00000.,,....
-----.,,....
00010,,....
00000,,....
-----,,....
00101,....
00000,....
我们知道G(x)的最高位一定是1,而商1还是商0是由被除数的最高位决定的。而我们并不关心商究竟是多少,我们关心的是余数。例如上例中的G(x)有5 位。我们可以看到每一步作除法运算所得的余数其实就是被除数的最高位后的四位于G(x)的后四位XOR而得到的。那被除数的最高位有什么用呢?我们从打记号的两个不同的余数就知道原因了。当被除数的最高位是1时,商1然后把最高位以后的四位于G(x)的后四位XOR得到余数;如果最高位是0,商0然后把被除数的最高位以后的四位于G(x)的后四位XOR得到余数,而我们发现其实这个余数就是原来被除数最高位以后的四位的值。也就是说如果最高位是0就不需要作XOR的运算了。到这我们总算知道了为什么先前要这样建立模型,而算法的原理也就清楚了。
以下是对作者的原文的翻译:
可是这样实现的算法却是非常的低效。为了加快它的速度,我们使它一次能处理大于4 bit的数据。也就是我们想要实现的32 bit的CRC校验。我们还是假设有和原来一样的一个4 "bit"的register。不过它的每一位是一个8 bit的字节。
3 2 1 0 Bytes
+----+----+----+----+
Pop <-- | | | | | <----- Augmented message
+----+----+----+----+
1<------32 bits------> (暗含了一个最高位的“1”)
根据同样的原理我们可以得到如下的算法:
While (还有剩余没有处理的数据)
Begin
检查register头字节,并取得它的值
求不同偏移处多项式的和
register左移一个字节,最右处存入新读入的一个字节
把register的值和多项式的和进行XOR运算
End
我的学习笔记:
可是为什么要这样作呢? 同样我们还是以一个简单的例子说明问题:
假设有这样的一些值:
当前register中的值: 01001101
4 bit应该被移出的值:1011
生成多项式为: 101011100
Top Register
---- --------
1011 01001101
1010 11100 + (CRC XOR)
-------------
0001 10101101
首4 bits 不为0说明没有除尽,要继续除:
0001 10101101
1 01011100 + (CRC XOR)
-------------
0000 11110001
^^^^
首4 bits 全0说明不用继续除了。
那按照算法的意思作又会有什么样的结果呢?
1010 11100
1 01011100+
-------------
1011 10111100
1011 10111100
1011 01001101+
-------------
0000 11110001
现在我们看到了这样一个事实,那就是这样作的结果和上面的结果是一致的。这也说明了算法中为什么要先把多项式的值按不同的偏移值求和,然后在和 register进行异或运算的原因了。另外我们也可以看到,每一个头字节对应一个值。比如上例中:1011,对应01001101。那么对于 32 bits 的CRC 头字节,依据我们的模型。头8 bit就该有 2^8个,即有256个值与它对应。于是我们可以预先建立一个表然后,编码时只要取出输入数据的头一个字节然后从表中查找对应的值即可。这样就可以大大提高编码的速度了。
+----+----+----+----+
+-----< | | | | | <----- Augmented message
| +----+----+----+----+
| ^
| |
| XOR
| |
| 0+----+----+----+----+
v +----+----+----+----+
| +----+----+----+----+
| +----+----+----+----+
| +----+----+----+----+
| +----+----+----+----+
| +----+----+----+----+
+-----> +----+----+----+----+
+----+----+----+----+
+----+----+----+----+
+----+----+----+----+
+----+----+----+----+
255+----+----+----+----+
以下是对作者的原文的翻译:
上面的算法可以进一步优化为:
1:register左移一个字节,从原始数据中读入一个新的字节.
2:利用刚从register移出的字节作为下标定位 table 中的一个32位的值
3:把这个值XOR到register中。
4:如果还有未处理的数据则回到第一步继续执行。
用C可以写成这样:
r=0;
while (len--)
r = ((r << | p*++) ^ t[(r >> 24) & 0xFF];
可是这一算法是针对已经用0扩展了的原始数据而言的。所以最后还要加入这样的一个循环,把W个0加入原始数据。
我的学习笔记:
注意不是在预处理时先加入W个0,而是在上面算法描述的循环后加入这样的处理。
for (i=0; i<W/4; i++)
r = (r << ^ t[(r >> 24) & 0xFF];
所以是W/4是因为若有W个0,因为我们以字节(8位)为单位的,所以是W/4个0 字节。注意不是循环w/8次
以下是对作者的原文的翻译:
1:对于尾部的w/4个0字节,事实上它们的作用只是确保所有的原始数据都已被送入register,并且被算法处理。
2:如果register中的初始值是0,那么开始的4次循环,作用只是把原始数据的头4个字节送入寄存器。(这要结合table表的生成来看)。就算 register的初始值不是0,开始的4次循环也只是把原始数据的头4个字节把它们和register的一些常量XOR,然后送入register中。
3A xor B) xor C = A xor (B xor C)
总上所述,原来的算法可以改为:
+-----<Message (non augmented)
|
v 3 2 1 0 Bytes
| +----+----+----+----+
XOR----<| | | | |
| +----+----+----+----+
| ^
| |
| XOR
| |
| 0+----+----+----+----+
v +----+----+----+----+
| +----+----+----+----+
| +----+----+----+----+
| +----+----+----+----+
| +----+----+----+----+
| +----+----+----+----+
+----->+----+----+----+----+
+----+----+----+----+
+----+----+----+----+
+----+----+----+----+
+----+----+----+----+
255+----+----+----+----+
算法:
1:register左移一个字节,从原始数据中读入一个新的字节.
2:利用刚从register移出的字节和读入的新字节XOR从而产生定位下标,从table中取得相应的值。
3:把该值XOR到register中
4:如果还有未处理的数据则回到第一步继续执行。
我的学习笔记:
对这一算法我还是不太清楚,或许和XOR的性质有关,恳请大家指出为什么?
谢谢。
到这,我们对CRC32的算法原理和思想已经基本搞清了。下章,我想着重根据算法思想用java语言实现。
hjzgq 回复于:2003-05-15 14:14:51
数学算法一向都是密码加密的核心,但在一般的软路加密中,它似乎并不太为人们所关心,因为大多数时候软体加密本身实现的都是一种编程上的技巧。但近几年来随着序列号加密程序的普及,数学算法在软体加密中的比重似乎是越来越大了。
我们先来看看在网路上大行其道的序列号加密的工作原理。当用户从网路上下载某个Shareware -- 共享软体后,一般都有使用时间上的限制,当过了共享软体的试用期后,你必须到这个软体的公司去注册后方能继续使用。注册过程一般是用户把自己的私人信息(一般主要指名字)连同信用卡号码告诉给软体公司,软体公司会根据用户的信息计算出一个序列码出来,在用户得到这个序列码后,按照注册需要的步骤在软体中输入注册信息和注册码,其注册信息的合法性由软体验证通过后,软体就会取消掉本身的各种限制。这种加密实现起来比较简单,不需要额外的成本,用户购买也非常方便,在网上的软体80%都是以这种方式来保护的。
我们可以注意到软体验证序列号的合法性过程,其实就是验证用户名与序列号之间的换算关系是否正确的过程。其验证最基本的有两种,一种是按用户输入的姓名来生成注册码,再同用户输入的注册码相比较,公式表示如下:
序列号 = F(用户名称)
2. 有哪些常用的调查方法
在我们的学习、工作中,有时会涉及到一些需要进行调查研究的工作。如何开展调研工作?都有哪些调查方法?用什么方法比较合适?回收摆在初入调研行业人面前的几个问题。综合调研工作的实际情况,我们总结了9种比较常用的调研方法,供大家参考:
01
实地观察法
调查者在通过实地观察获得直接、生动、真实可靠的第一手资料。但因为所观察到的往往是事物的表面现象或外部联系,带有一定的偶然性,且受调查者主观因素影响较大,因此,不能进行大样本观察,需结合其他调查方法共同使用。
02
访谈调查法
比实地观察法更深一层次的调查方法,能获得更多、更有价值的信息,适用于调查的问题比较深入、调查的对象差别较大、调查的样本较小,或调查的场所不易接近等情况。
03
会议调查法
因为比较简便易行,在调查研究工作中比较常用。通过邀请若干调查对象以座谈会形式来搜集资料、分析和研究社会问题。优点是工作效率高,可以较快了解到比较详细、可靠的社会信息,节省人力和时间。
04
问卷调查法
优点是方便、快捷,对众多的调查对象同时进行调查,适用于对现时问题、较大样本、较短时期、相对简单的调查。
05
专家调查法
这是一种预测方法,是以专家作为索取信息的对象,依靠其知识和经验,通过调查研究,对问题作出判断和评估。优点是简便直观,特别适用于缺少信息资料和历史数据,而又较多地受到社会的、政治的、人为的因素影响的信息分析与预测课题。
06
抽样调查法
按照一定方式,从调查总体中抽取部分样本进行调查,并用所得结果说明总体情况。优点是节约人力、物力和财力,能在较短的时间内取得相对准确的调查结果,具有较强的时效性。组织全面调查范围广、耗时长、难度大,常采用抽样调查的方法进行检查和验证。
07
典型调查法
在特定范围内选出具有代表性的特定对象进行调查研究,借以认识同类事物的发展变化规律及本质的一种方法。在调查样本太大时,可以采用典型调查。但必须注意对象的选择,要准确地选择对总体情况比较了解、有代表性的对象。
08
统计调查法
通过分析固定统计报表的形式,把下边的情况反映上来的一种调查方法。由于统计报表的内容是比较固定的,因此适用于分析某项事物的发展轨迹和未来走势。
09
文献调查法
通过对文献的搜集和摘取,以获得关于调查对象信息的方法。适用于研究调查对象在一段时期内的发展变化,研究角度往往是探寻一种趋势,或弄清一个演变过程。
在实际的调查研究工作中,调查者一般不局限于某种特定方法,而是相互交错、灵活的运用这些方法。而这些调查方法,调研工厂全都可以支持,而且是免费。
01调研工厂:网络调查
好用的网络问卷编辑与回收工具,免费支持微信红包奖励功能,加速问卷回收。
02调研工厂:明察暗访
专业的实地考察、暗访调查、闭环整改工具。
使用场景:门店网点巡查,设备普查、安全普查;神秘客巡店,服务质量/营商环境暗访;创城检查,垃圾分类检查,园林绿地检查,人居环境监测等。
03调研工厂:面对面访问
通过APP开展面对面访问,监督访问员工作并进行劳务费结算。
使用场景:人口普查、居民用水/用电调查等需要入户访问的调查统计;知晓度、满意度、新品测试记录等街头拦访;地下商超、偏远山区等无网络环境离线调查。
调研工厂:CATI云电话调查
云端CATI电话调查,在线自动拨号,多坐席管理,通话状态跟踪,全过程录音。
使用场景:消费者调研、市场调研、产品调查、社情民意调查;服务质量、教学质量、物业后勤、政府工作满意度调查;客户维系、客户管理、服务满意度回访。
05调研工厂:深度访谈
丰富的企业高管、专家、政府公务员、消费者样本库,一对一访谈,深度了解被调查者潜在动机、态度和情感、决策因素、产品/服务使用情况等。
06调研工厂:座谈会
18年专业调研经验,服务政企客户 10000+,协助政府、企业、机构,组织调查社情民意、消费决策、产品/服务使用等小组座谈会近千场。
3. 常见的信息收集方法有哪些
目前有五种方法:
1.查阅资料法:报纸、行业网站、文献、杂志、广播电视等传媒专访。
2.调查法:(1)拜访调查法;(2)电话采访法;(3)问卷调查法。
3.观察法:通过开会、深入现场、参加生产和经营、实地采样、进行现场观察并准确记录(包括测绘、录音、录相、拍照、笔录等)调研情况。主要包括两个方面:一是对人的行为的观察,二是对客观事物的观察。观察法应用很广泛,常和询问法、搜集实物结合使用,以提高所收集信息的可靠性。
4.实验法:通过实验室实验、现场实验、计算机模拟实验、计算机网络环境下人机结合实验等过程获取信息或结论。可主动控制实验条件,包括对参与者类型的恰当限定、对信息产生条件的恰当限定和对信息产生过程的合理设计,获得重要的、能客观反映事物运动表征的有效信息,在一定程度上直接观察研究某些参量之间的相互关系,有利于对事物本质的研究。
5.互联网信息收集法:通过计算机网络发布、传递和存储的各种信息。互联网信息收集的最终目标是给广大用户提供网络信息资源服务,整个过程包括网络信息搜索、整合、保存和服务四个步骤。
拓展资料:
为了保证信息收集的质量,要遵循几个原则:
1.准确性:收集的信息一定要真实可靠,这是最基本的原则,因此,收集者要对收集的信息反复核实、不断检验。
2.全面性:全面、广泛地收集信息,才能完整的反映调查对象的全貌,保障科学决策。
3.时效性:信息的利用价值取决于该信息是否能及时地提供,信息只有及时、迅速地提供给它的使用者才能有效地发挥作用。
4. 遥感变化信息检测的主要方法
本节所研究的主要是基于像元级的遥感变化信息检测方法。当今国内外常用的遥感变化信息检测方法主要有分类后比较法、代数运算法、光谱特征变异法、主成分分析法等。
( 一) 光谱特征变异法
光谱特征变异法是使用最为广泛的一种遥感变化信息检测方法,其原理是将两时相遥感影像的相关波段进行融合、组合,如果地物类型发生了变化,该区域的光谱就会发生变异或突变,与周围地物失去协调性,使得能通过肉眼识别出来。该方法容易受到研究区域地物光谱特征的影响,可能会丢失细小的变化图斑,但是在一般情况下总体效果良好 ( 冯德俊,2004) 。
图 4 -8 HIS 融合法结果
把研究区震前 IKONOS 的全色波段影像和震后QuickBird 的多光谱影像运用光谱特征变异法中的 HIS进行了融合,结果见图 4 -8。从图中可以看出,没有发生变化的区域光谱特征和分辨率都得到了加强 ( 空间分辨率变为 1m) ,其中水体、河流为蓝色,山地为褐色,植被信息为绿色,白色区域明显与四周的地物和背景信息光谱不协调,这就是发生变化的区域。
( 二) 主成分分析法
主成分分析法在遥感变化信息检测中使用很多,一般能够取得很好的检测效果,它能够在一定程度上消除影像内部各波段间的相关性,提高变化信息检测的效率和精度。
图 4 - 9 为 IKONOS 融合后影像与 QuickBird 融合后影像求差并取绝对值后进行主成分变换的第一个主成分图像。由主成分变换的特性知道,变换结果的第一分量集中了影像绝大部分的变化信息,而其他分量则主要反映了波段之间的差异性。第一分量就代表着变化信息。图 4 -9 中白色区域为发生变化的区域。
基于主成分分析的遥感变化信息检测方法仍然存在着一些缺陷: ① 由于主成分变换所得到的各个分量往往失去了原有的物理意义,所以还需要参考其他数据来分析地物类型变化与否及其因果关系。② 主成分分析 ( PCA) 是基于二阶统计的方法,只有在信号的统计分布满足高斯分布的条件下,才能完全消除信号间的相关性,而对于非高斯信号则只能去除信号间的二阶相关性 ( 钟家强、王润生,2006) 。在多时相遥感影像中,各种地类的光谱特性几乎都不能满足高斯分布,因此经过主成分变换后的各成分图像间仍然存在高阶相关性,而这些相关信息会直接影响到变化信息的检测和提取。由于这个原因,在做主成分分析时,常常导致把这些高阶相关信息转变为噪声,如图 4 -9 所示,白色的 “斑点”遍布整个分量影像,又和变化信息掺杂在一起 ( 变化的区域也为高亮的白色) ,这使得在提取真正变化信息的时候遇到困难,如何有效地消除多时相图像间的高阶相关信息,避免这些 “伪变化”的噪声,对于变化信息的检测和提取具有非常重要的意义。
5. 时序法是常用的信息鉴别方法
是的。对信息进行鉴别的基本方法有类比法、时序法和差重法,时序法是按照事物、事件的发生发展过程或人物的生平事迹存贮和检索文献信息的方法,这种方法广泛用于编制历表、年表和人物年谱。
6. 信息技术教学检测有哪几种方法
7. Win10查看磁盘检查信息的方法
通过查看Win10磁盘检查结果,用户能够及时掌握系统的`运行状态,但Win10系统查看磁盘检查结果的方法并不像之前的系统那么简单,下面我就教大家如何查看Win10磁盘检查结果。
具体方法如下:
1、在Cortana搜索栏输入“事件查看器”后回车,或者在开始按钮点右键,选择“事件查看器”
2、在左边栏展开“Windows日志”,选择“应用程序”,从右边栏选择“筛选当前日志”,如下图——
3、在窗口正中间一行输入事件ID“26226”,点击“确定”,如下图——
4、在“事件查看器”主窗口中间就可以看到目前已有的日志。单击所需日志,下方就会给出该日志信息,此时点击“详细信息”可查看日志内容。
注意:上述“事件ID”序号只适用于Win8.1/Win10,Win7用户若想查看,需输入“1001”。
8. 涉密计算机检查工具有哪些
涉密计算机检查工具
解密、破密系统
针对司法机关办案中遇到的加密计算机及设备,效率源司法专用计算机取证平台可以快速智能地进行破密,并对目标电子证据进行提取,帮助司法机关有效解决加密存储产品破密难题,实现指定目标数据安全读取。
镜像复制系统
针对司法机关对计算机取证过程中对电子证据的提取和分析不能直接在原盘操作的特殊需求,效率源司法专用计算机取证平台提供了目标电子证据快速镜像拷贝功能,将电子证据统一储存管理,保障司法机关在计算机取证中电子证据的可靠、安全。
过滤系统
依赖效率源科技超强的数据恢复技术后盾,效率源司法专用计算机取证平台可针对缺陷存储介质中被删除、修改、隐藏的电子证据进行完整快速的数据恢复,并对电子证据进行分析、查找、搜索、过滤。效率源司法专用计算机取证平台保证整个操作过程绝对“物理只读”,并且可与司法机关常用的计算机取证分析软件进行无缝对接,实现目标数据“一机”搜索、过滤、获取、固化、分析。
固化系统
效率源司法专用计算机取证平台采用USB接口设计,设备可直接通过USB接口与嫌疑存储设备连接,通过底层的“写保护”控制,可有效保障手机、相机、摄像机等目标存储只读无损取证,达到非破坏性取证和分析的目的,以保证司法机关获取电子证据的客观真实性,以免日后对电子证据的有效性滋生争议。
网络“效率源”第一位就是可以进入官网!
9. 常用的信息检索方法有哪些
信息检索方法包括:普通法、追溯法和分段法。
1、普通法是利用书目、文摘、索引等检索工具进行文献资料查找的方法。运用这种方法的关键在于熟悉各种检索工具的性质、特点和查找过程,从不同角度查找。普通法又可分为顺检法和倒检法。
2、追溯法是利用已有文献所附的参考文献不断追踪查找的方法,在没有检索工具或检索工具不全时,此法可获得针对性很强的资料,查准率较高,查全率较差。
3、分段法是追溯法和普通法的综合,它将两种方法分期、分段交替使用,直至查到所需资料为止。
(9)常用信息检查方法扩展阅读
检索原因
信息检索是获取知识的捷径
美国普林斯顿大学物理系一个年轻大学生名叫约瀚·菲利普,在图书馆里借阅有关公开资料,仅用四个月时间,就画出一张制造原子弹的设计图。
他设计的原子弹,体积小(棒球大小)、重量轻(7.5公斤)、威力大(相当广岛原子弹3/4的威力),造价低(当时仅需两千美元),致使一些国家(法国、巴基斯坦等)纷纷致函美国大使馆,争相购买他的设计拷贝。
二十世纪七十年代,美国核专家泰勒收到一份题为《制造核弹的方法》的报告,他被报告精湛的技术设计所吸引,惊叹地说:“至今我看到的报告中,它是最详细、最全面的一份。”
但使他更为惊异的是,这份报告竟出于哈佛大学经济专业的青年学生之手,而这个四百多页的技术报告的全部信息来源又都是从图书馆那些极为平常的、完全公开的图书资料中所获得的。
10. 计算机检修时应遵循什么原则 计算机故障常用的检测方法有什么
1.计算机检修时应遵循什么原则? 2.简述计算机故障常用的检测方法?
1.先软后硬
电脑出了故障时,先从操作系统和软件上来分析故障原因,如:分区表丢失、CMOS设置不当、病毒破坏了主引导扇区、注册表文件出错等。在排除软件方面的原因后,再来检查硬件的故障。一定不要一开始就盲目的拆卸硬件,以免走弯路。
2.先外后内
先外设、再主机,根据系统报错信息进行检修。先检查打印机、键盘、鼠标、扫描仪等外设,查看电源的连接、各种连线是否连接得当,在排除这些方面的原因后,再来检查主机。
3.先电源后部件
电源是电脑是否正常工作的关键,首先要检查电源部分,如是否有电压通到主机,工作电压是否正常、稳定,主机电源的功率是否能负载各部件的正常运行等,然后再检查各个部件。
4.先一般后特殊
在遇到故障时,应最先考虑最可能引起故障的原因,比如硬盘不能正常工作了,应先检查一下电源线、数据线是否松动,把它们重新插接,有时问题就能解决。如不成,再考虑其它原因。
5.先简单后复杂
在排除故障时,先排除简单而易修的故障,再去排除困难的不好解决的故障,有时在排除了简单易修的故障后,不好解决的故障也变得很好解决了,而像需要电路的焊接等就需要有一定的电子维修基础,此类故障不要贸然下手,最好送修。
电脑故障的经典检修方法
对于电脑故障我们可以采用如下方法进行检修:
1.直接观察法
也就是直接观察。看看是否有烧焦、变形、脱落等现象,有没有短路、接触不良等现象,元器件是否有生锈和损坏的明显痕迹,各种电风扇运转是否正常等,看看电源线是否插上(记得有个菜鸟没插上电源线或没打开交流电源开关,愣说无法开机,吓出一身冷汗)。听听是否有异常声音,还可从开机的出错报警声音分析故障的范围,闻一下是否有异常味道,看看是出自主机还是显示器,以便缩小故障的范围。
2.拔插法
检查电源线、各板卡间是否有松动或接触不良的现象,可以把怀疑的板卡拆下,用橡皮擦将金手指擦干净再重新插好,以保证接触良好。还可以利用手指轻轻敲击可能产生故障的部件,比如硬盘的磁头有时无法归位,轻轻用手指头敲击硬盘可把硬盘从“沉睡”中唤醒过来。
3.替换法
可尝试使用相同功能的板卡替换有故障的部件。如声卡不发声,可找一块能正常使用的声卡来判断是主板的扩展槽问题还是声卡的问题等等。
4.升温降温法
利用手指的灵敏感觉触摸有关发热部件,是否过热现象,可人为的利用电吹风对可能出现故障的部件进行升温试验,促使故障提前出现,从而找出故障的原因,或利用酒精对可疑部件进行人为降温试验,如故障消失了,则证明此部件热稳定性差,应予以更换。此方法适用于电脑运行时而正常、时而不正常的故障的检修。
5.最小系统法
除了采取以上办法外,对于一台能够显示但却无法开机的电脑,我们可以采取最小系统法进行诊断。也就是只安装CPU、显卡、主板,然后再试试看,如果没有问题时,才把硬盘接上去重新开机。如果这时候电脑能正常开机。我们就可以确定问题不在主板上的任何元件,也不会是显卡或是硬盘。此时,我们只要把余下的板卡逐一装上去,当电脑又无法开机时,我们就可知道导致电脑不能正常工作的元兇是谁了。