信息摘要算法-CRC(循环冗余校验)

一、简述

  确切的说CRC不算是信息摘要算法,但是他的原理也是散列函数。他经历过很多版本的改进。现阶段CRC-32算法是通信领域实现差错控制的的主要应用。

 

二、模型分析(以传递压缩数据模型为例):

  甲方对自己的数据做循环冗余校验(CRC)处理,然后向数据尾部追加冗余校验码,然后压缩,发送数据给乙方

  乙方解压缩,分离数据和校验码。然后对分离出的数据进行CRC处理,看得出的冗余校验码和分离出的校验码是否一致。进而判断数据的正确性。

三、java实现

package com.ca.test; import java.util.zip.CRC32; /** * 测试循环冗余校验 * @author kongqz * */ public class CRC { /** * @param args */ public static void main(String[] args) { String str="测试CRC-32"; CRC32 c32=new CRC32(); c32.update(str.getBytes()); String hex=Long.toHexString(c32.getValue()); System.out.println("原文:"+str); System.out.println("CRC-32处理后:"+hex); } } 控制台输出结果: 原文:测试CRC-32 CRC-32处理后:8734140f

四、总结

1、CRC32算法很常见。类似消息摘要算法,只不过它是将原文和摘要信息组合后发送给对方

2、算法是公开的。验证也很方便。上述算法调整下就可以做文件校验了

 

 

 

你可能感兴趣的:(java,算法,String,测试,Class,hex)