crc64 算法的 PHP 实现,校验文件传输的完整性

用于校验文件传输的完整性,可实现边上传边计算,主要用于分块上传场景。

实现代码

<?php

class Crc64
{
    private static $crc64tab = [];

    private $value = 0;

    public function __construct()
    {
        if (!self::$crc64tab) {
            $crc64tab  = [];
            $poly64rev = (0xC96C5795 << 32) | 0xD7870F42;
            for ($n = 0; $n < 256; ++$n) {
                $crc = $n;
                for ($k = 0; $k < 8; ++$k) {
                    if ($crc & true) {
                        $crc = ($crc >> 1) & ~(0x8 << 60) ^ $poly64rev;
                    } else {
                        $crc = ($crc >> 1) & ~(0x8 << 60);
                    }
                }
                $crc64tab[$n] = $crc;
            }
            self::$crc64tab = $crc64tab;
        }
    }

    public function append($string)
    {
        for ($i = 0; $i < \strlen($string); ++$i) {
            $this->value = ~$this->value;
            $this->value = $this->value(\ord($string[$i]), $this->value);
            $this->value = ~$this->value;
        }
    }

    public function getValue()
    {
        return (string) (sprintf('%u', $this->value));
    }

    private function value($byte, $crc)
    {
        return self::$crc64tab[($crc ^ $byte) & 0xff] ^ (($crc >> 8) & ~(0xff << 56));
    }
}

使用示例

<?php

$crc = new Crc64();

$crc->append('t');
$crc->append('e');
$crc->append('s');
$crc->append('t');

var_dump($crc->getValue());

// output
// string(20) "18020588380933092773"
添加新评论