哈希感知算法生成图片指纹phash

class ImagesList {

    private $rate = 3;

public function hash($file){
    if (!file_exists($file)){
        return false;
    }
    $height = 8 * $this->rate;
    $width = 8 * $this->rate;
    $img = imagecreatetruecolor($width, $height);
    list($w, $h) = getimagesize($file);
    $source = $this->createImg($file);
    imagecopyresampled($img, $source, 0, 0, 0, 0, $width, $height, $w, $h);
    $value = $this->getHashValue($img);
    imagedestroy($img);

    return $this->getBin2hex($value);
}
public function getHashValue($img){
    $width = imagesx($img);
    $height = imagesy($img);
    $total = 0;
    $array = array();
    for ($y=0;$y<$height;$y++){
        for ($x=0;$x<$width;$x++){
            $gray = ( imagecolorat($img, $x, $y) >> 8 ) & 0xFF;
            if (!is_array($array[$y])){
                $array[$y] = array();
            }
            $array[$y][$x] = $gray;
            $total += $gray;
        }
    }
    $average = intval($total / (64 * $this->rate * $this->rate));
    $result = '';
    for ($y=0;$y<$height;$y++){
        for ($x=0;$x<$width;$x++){
            if ($array[$y][$x] >= $average){
                $result .= '1';
            }else{
                $result .= '0';
            }
        }
    }
    return $result;
}
public function createImg($file){
    $ext = $this->getFileExt($file);
    if ($ext === 'jpeg') $ext = 'jpg';
    $img = null;
    switch ($ext){
        case 'png' : $img = imagecreatefrompng($file);break;
        case 'jpg' : $img = imagecreatefromjpeg($file);break;
        case 'gif' : $img = imagecreatefromgif($file);
    }
    return $img;
}
public function getFileExt($file){
    $infos = explode('.', $file);
    $ext = strtolower($infos[count($infos) - 1]);
    return $ext;
}
public function getBin2hex($str,$len = '4'){
    $string = '';
    $time = ceil(strlen($str)/$len);
    for($i=0;$i<$time;$i++){
        $start = $i*4;
        $string .= dechex(bindec(substr($str,$start,$len)));
    }
    return $string;
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值