分组校验和的java实现

分组校验和的算法用在了很多分组的计算中。现在只针对IP分组而言,IP分组只对IP分组头进行计算,算法如下:
1、计算校验和
1)初始时,将校验和域都设置为0
2)每16bit做二进制反码求和。
3)得到的结果取反便是检验和
2、验证校验和
1)将IP分组头中每16bit分为一小组,进行二进制反码求和
2)查看结果是否为0,如果为0,表示正确,否则表示错误。

何为二进制反码和?
下面是我个人理解:我们知道计算机中对数字有三种表示方法:原码、反码和补码,比如对8而言,1000为其原码,0111为其反码,1000为其补码。通常,计算机存储数字时都以补码形式存储。因此我们平时所做的加减法也可以说是二进制补码和。而反码求和,自然就是以反码表示的数字进行求和。比如8+9,补码(原码)求和:1000 + 1001 = 0001(17),反码求和0111 + 0110 = 1101。
经过总结规律,可以发现反码求和的结果满足如下规律:原码和+原码和高位移除之后再取反的结果。0001+0001(溢出) = 0010,取反为1101。

由于加法具有结合律,因此可以先对整个数组做原码加法,然后再取反

package com.IP;

/**
 * Created by dave on 2016/2/19.
 */
//计算头部校验和
public class HeaderCheckSum {
    public String caculate(int[] data){//data以16bit形式传入,如0xabcd
        int sum = 0;
        for(int i = 0;i<data.length;i++){
            sum += data[i];
        }
        for(int i = 0;i<2;i++) {//这里循环两次,是因为sum溢出后的高位与低16bit相加之后仍然可能会溢出,所以需要再重复一次,那么会不会再次溢出呢?肯定不会,不妨试一试。
            int low = sum & 0xffff;
            int high = (sum >> 16) & 0xffff;

            sum = low + high;
        }
        //16进制表示
        String hexString = Integer.toHexString(~sum & 0xffff);
        System.out.println("校验和:"+hexString);
        return hexString;
    }
    //判断是否有效
    public boolean isValid(int[] data){
        int sum = 0;
        for(int tmp:data){
            sum += tmp;
        }
        for(int i = 0;i<2;i++){
            int low = sum & 0xffff;
            int high = (sum >> 16)&0xffff;

            sum = low + high;
        }
        boolean res = false;
        if((~sum & 0xffff) == 0)
            res = true;
        System.out.println("valid:"+res);
        return res;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DES(Data Encryption Standard)是一种对称加密算法,它将明文按照一定的规则转换成密文,以保障数据的保密性。下面是使用Java实现DES分组加密算法的示例代码: ```java import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; import javax.crypto.spec.SecretKeySpec; import java.security.NoSuchAlgorithmException; import java.security.SecureRandom; public class DESExample { private static final String ALGORITHM = "DES"; private static final String CHARSET = "UTF-8"; public static void main(String[] args) throws Exception { String message = "Hello, world!"; String password = "12345678"; // 生成密钥 SecretKey secretKey = generateKey(password); // 加密 byte[] encryptedData = encrypt(message.getBytes(CHARSET), secretKey); System.out.println("Encrypted data: " + new String(encryptedData, CHARSET)); // 解密 byte[] decryptedData = decrypt(encryptedData, secretKey); System.out.println("Decrypted data: " + new String(decryptedData, CHARSET)); } /** * 生成密钥 */ public static SecretKey generateKey(String password) throws NoSuchAlgorithmException { KeyGenerator keyGenerator = KeyGenerator.getInstance(ALGORITHM); SecureRandom secureRandom = new SecureRandom(password.getBytes()); keyGenerator.init(secureRandom); return keyGenerator.generateKey(); } /** * 加密 */ public static byte[] encrypt(byte[] data, SecretKey secretKey) throws Exception { Cipher cipher = Cipher.getInstance(ALGORITHM); cipher.init(Cipher.ENCRYPT_MODE, secretKey); return cipher.doFinal(data); } /** * 解密 */ public static byte[] decrypt(byte[] data, SecretKey secretKey) throws Exception { Cipher cipher = Cipher.getInstance(ALGORITHM); cipher.init(Cipher.DECRYPT_MODE, secretKey); return cipher.doFinal(data); } } ``` 在上面的示例代码中,我们使用了Java自带的`javax.crypto`包中的一些类来实现DES分组加密算法。具体来说,我们使用了`KeyGenerator`类来生成密钥,使用`Cipher`类来进行加密和解密操作。在生成密钥时,我们指定了密钥生成器的算法为DES,并使用了一个随机数生成器来生成密钥。在加密和解密操作时,我们都需要传入一个`SecretKey`对象,这个对象就是我们生成的密钥。 需要注意的是,DES算法的密钥长度为56位,但是Java默认只支持64位的密钥长度。如果想要使用56位的密钥,需要手动将密钥的奇偶校验位去掉,或者使用其他的库来实现。另外,由于DES算法已经被认为不安全,建议使用更加安全的AES算法来进行加密。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值