您好,欢迎访问一九零五行业门户网

PHP 判断是否低俗图片==是否@色@情@图@片

php 判断是否低俗图片==是否@色@情@图@片
方式一:
原理:通过 rgb色彩模型 转成 ycbcr色彩模型 在 ycbcr色彩模型 判断低俗色的占比
if(validatorimage("d:/b.jpg"))<br /> echo '是个低俗图片<br />';<br />else<br /> echo '不是低俗图片<br />';<br />function validatorimage($filename){<br /> $image = getimage($filename);<br /> $width = imagesx($image);<br /> $height = imagesy($image);<br /> $ycb = 0;<br /> for($y=0;$y<$height;$y++){<br /> for($x=0;$x<$width;$x++){<br /> $rgb = imagecolorat($image,$x,$y);<br /> $r = ($rgb >> 16) & 0xff;<br /> $g = ($rgb >> 8) & 0xff;<br /> $b = $rgb & 0xff;<br /> $ycbcr = rgb2ycbcr($r,$g,$b);<br /> if((86<=$ycbcr['cb']&&$ycbcr['cb']<=117)&&(140<=$ycbcr['cr']&&$ycbcr['cr']< 168)){<br /> $ycb++;<br /> }<br /> }<br /> }<br /> imagedestroy($image);</p><p> if($ycb>(floatval($width)*floatval($height)*0.3))<br /> return true;<br /> else<br /> return false;<br />}</p><p>function getimage($filename){<br /> $info = getimagesize($filename);<br /> $ext = null;<br /> switch ($info[2]) {<br /> case 1 :<br /> $ext = "gif";<br /> break;<br /> case 2 :<br /> $ext = "jpeg";<br /> break;<br /> case 3 :<br /> $ext = "png";<br /> break;<br /> }<br /> $function = 'imagecreatefrom'.ucfirst($ext);<br /> $resource = $function($filename);<br /> return $resource;<br />}<br />// rgb 转 ycbcr色彩<br />function rgb2ycbcr($r,$g,$b){<br /> $r = floatval($r);<br /> $g = floatval($g);<br /> $b = floatval($b);</p><p> $y = 0.299*$r + 0.587*$g + 0.114*$b;<br /> $cb = (1 / 1.772) * ($b - $y) + 128;<br /> $cr = (1 / 1.402) * ($r - $y) + 128;</p><p> return array('y'=>$y,'cb'=>$cb,'cr'=>$cr);<br />}<br />
说明:
上面是通过 rgb色彩模型 转成 ycbcr色彩模型 在 ycbcr色彩模型 判断低俗色的占比,如果商用还要加上肌肤色的过滤及对低俗部位的判断,依据比例对图片进行分类。
ycbcr 相关知识,可以参考http://zh.wikipedia.org/wiki/ycbcr
rgb 转成 ycbcr 公式可以参考http://blog.csdn.net/zyl910/archive/2006/05/29/759535.aspx
方式二:
原理就是检测皮肤颜色在图片中的比例。经过测试,漏掉的很少,不过误报很高。
<?php/** * php检查低俗图片 * 作者:书中蠹鱼 */if($argc == 2){ $file_name = $argv[1]; if(is_file($file_name)){ //文件存在 $image = openimagefile($file_name); $rate = testskin($image['image_handle'],$image['width'],$image['height']); if($rate > 0.3){ echo "$file_name 貌似是一张低俗图片.肤色比例:$rate/n"; }else { echo "$file_name 貌似不是一张低俗图片.肤色比例:$rate/n"; } }else { echo "$file_name can't be find!/n"; }}else{ echo "usage: testskin.php filename/n";}function openimagefile($file_name){ list($width, $height, $type, $attr) = getimagesize($file_name); switch ($type){ case 2: $image_handle = imagecreatefromjpeg($file_name); break; } return array('image_handle'=>$image_handle,'width'=>$width,'height'=>$height);}function testskin($image_handle,$width,$height){ $skin_pix = 0; for($w=0;$w<$width;$w++){ for ($h=0;$h<$height;$h++){ //验证图片 $rgb = imagecolorat($image_handle,$w,$h); $r = ($rgb >> 16) & 0xff; $g = ($rgb >> 8) & 0xff; $b = $rgb & 0xff; $y=0.299*$r+0.587*$g+0.114*$b; $cb=0.564*($b-$y)+128; $cr=0.713*($r-$y)+128; if($cb >= 86 && $cb <= 117 && $cr >= 140 && $cr <= 168){ $skin_pix ++; } } } $skin_rate = $skin_pix/($width*$height); return $skin_rate;}?>
需要gd库的支持。在php.ini里面打开gd扩展。
其它类似信息

推荐信息