Deprecated: Function ereg_replace() is deprecated
作者:admin 日期:2012-09-30
在php5.3.0后的版本,取消了对ereg函数的支持,惹得若干程序需要改动,譬如我安装的zen-card1.3.8,颇不方便。
错误:Deprecated: Function ereg() is deprecated in ……
解决方法一:退回去用php5.2。(众人皆赞道:果是好法子!)
解决方法二:继续用php5.3,但是修改devel/devel.modul的460行:if ($errno & (E_ALL ^ E_NOTICE)) {改为if ($errno & (E_ALL & ~E_NOTICE & ~E_DEPRECATED)) {把丫deprecated错误给忽略掉。(众人皆又赞道:果……果……果是好法子!)
不同编码网站内容之间的JS调用方法
作者:admin 日期:2012-09-27
两个网站编码格式不同导致js调用乱码,UTF-8的文字内容在GB2312的编码页面下是不显示的。对于这样的问题处理的办法是更改JS代码如下:
- <script type="text/javascript" src="..../" charset="utf-8"></script>
对于其他类似情况,只要更改“charset=”后边的参数为你要调用页面的编码即可。
vb中webbrowser禁止新窗口打开超链接的方法
作者:admin 日期:2012-09-26
创建一个窗体上的 web 浏览器控件。
-
在该窗体的声明部分中添加以下:
ASP/Visual Basic代码- Dim WithEvents Web_V1 as SHDocVwCtl.WebBrowser_V1
-
这将声明 WebBrowser_V1 变量可以接收 WebBrowser_V1 为您提供 NewWindow 事件的事件。
-
在 Form_Load 事件中添加以下:
ASP/Visual Basic代码- Set Web_V1 = WebBrowser1.Object
- WebBrowser1.Navigate2 "http://www.microsoft.com/"
-
这样会将 WebBrowser_V1 对象设置为现有的 Internet 浏览器的 web 浏览器对象。
-
NewWindow2 事件触发后,Web_V1_NewWindow 事件将作为其输入参数之一触发与该链接的 URL。请记住不,将取消设置为 True NewWindow2 中。此外,设置处理变量为 True 将 NewWindow 中的事件处理程序,以便不会创建 Internet Explorer 的新实例。下面的代码演示了此事件处理程序和代码以便在当前窗口中浏览必要:
ASP/Visual Basic代码- Private Sub Web_V1_NewWindow(ByVal URL As String, _
- ByVal Flags As Long, _
- ByVal TargetFrameName As String, _
- PostData As Variant, _
- ByVal Headers As String, _
- Processed As Boolean)
- Processed = True
- WebBrowser1.Navigate URL
- End Sub
右键单击一个链接,然后选择"打开在新窗口中",您将找到链接仍会打开您的 web 浏览器控件内。
Php提升效率优化技巧
作者:admin 日期:2012-09-24
PHP生成GIF动画实现动态图片验证码
作者:admin 日期:2012-09-24
使用php的类编写的动画验证码模块
- <?php
- /**
- * 调用示例
- * */
- session_start();
- $randCode = ”;
- $chars = ‘abcdefghjkmnpqrstuvwxyzABCDEFGHJKLMNPRSTUVWXYZ23456789′;
- for ( $i = 0; $i < 4; $i++ )
- {
- $randCode .= substr($chars, mt_rand(0, strlen($chars) – 1), 1);
- }
- $_SESSION['code'] = strtoupper($randCode); // 记录session
- ImageCode($randCode, 60); // 显示GIF动画
- /**
- * ImageCode 生成GIF图片验证
- * @param $string 字符串
- * @param $width 宽度
- * @param $height 高度
- * */
- function ImageCode($string = ”, $width = 75, $height = 25)
- {
- $authstr = $string ? $string : ((time() % 2 == 0) ? mt_rand(1000, 9999) : mt_rand(10000, 99999));
- $board_width = $width;
- $board_height = $height;
- // 生成一个32帧的GIF动画
- for($i = 0; $i < 32; $i++)
- {
- ob_start();
- $image = imagecreate($board_width, $board_height);
- imagecolorallocate($image, 0,0,0);
- // 设定文字颜色数组
- $colorList[] = ImageColorAllocate($image, 15,73,210);
- $colorList[] = ImageColorAllocate($image, 0,64,0);
- $colorList[] = ImageColorAllocate($image, 0,0,64);
- $colorList[] = ImageColorAllocate($image, 0,128,128);
- $colorList[] = ImageColorAllocate($image, 27,52,47);
- $colorList[] = ImageColorAllocate($image, 51,0,102);
- $colorList[] = ImageColorAllocate($image, 0,0,145);
- $colorList[] = ImageColorAllocate($image, 0,0,113);
- $colorList[] = ImageColorAllocate($image, 0,51,51);
- $colorList[] = ImageColorAllocate($image, 158,180,35);
- $colorList[] = ImageColorAllocate($image, 59,59,59);
- $colorList[] = ImageColorAllocate($image, 0,0,0);
- $colorList[] = ImageColorAllocate($image, 1,128,180);
- $colorList[] = ImageColorAllocate($image, 0,153,51);
- $colorList[] = ImageColorAllocate($image, 60,131,1);
- $colorList[] = ImageColorAllocate($image, 0,0,0);
- $fontcolor = ImageColorAllocate($image, 0,0,0);
- $gray = ImageColorAllocate($image, 245,245,245);
- $color = imagecolorallocate($image, 255,255,255);
- $color2 = imagecolorallocate($image, 255,0,0);
- imagefill($image, 0, 0, $gray);
- $space = 15; // 字符间距
- if($i > 0) // 屏蔽第一帧
- {
- for ($k = 0; $k < strlen($authstr); $k++)
- {
- $colorRandom = mt_rand(0,sizeof($colorList)-1);
- $float_top = rand(0,4);
- $float_left = rand(0,3);
- imagestring($image, 6, $space * $k, $top + $float_top, substr($authstr, $k, 1), $colorList[$colorRandom]);
- }
- }
- for ($k = 0; $k < 20; $k++)
- {
- $colorRandom = mt_rand(0,sizeof($colorList)-1);
- imagesetpixel($image, rand()%70 , rand()%15 , $colorList[$colorRandom]);
- }
- // 添加干扰线
- for($k = 0; $k < 3; $k++)
- {
- $colorRandom = mt_rand(0, sizeof($colorList)-1);
- // $todrawline = rand(0,1);
- $todrawline = 1;
- if($todrawline)
- {
- imageline($image, mt_rand(0, $board_width), mt_rand(0,$board_height), mt_rand(0,$board_width), mt_rand(0,$board_height), $colorList[$colorRandom]);
- }
- else
- {
- $w = mt_rand(0,$board_width);
- $h = mt_rand(0,$board_width);
- imagearc($image, $board_width – floor($w / 2) , floor($h / 2), $w, $h, rand(90,180), rand(180,270), $colorList[$colorRandom]);
- }
- }
- imagegif($image);
- imagedestroy($image);
- $imagedata[] = ob_get_contents();
- ob_clean();
- ++$i;
- }
- $gif = new GIFEncoder($imagedata);
- Header (‘Content-type:image/gif’);
- echo $gif->GetAnimation();
- }
- /**
- * GIFEncoder类
- * */
- Class GIFEncoder
- {
- var $GIF = “GIF89a”; /* GIF header 6 bytes */
- var $VER = “GIFEncoder V2.06″; /* Encoder version */
- var $BUF = Array ( );
- var $LOP = 0;
- var $DIS = 2;
- var $COL = -1;
- var $IMG = -1;
- var $ERR = Array (
- ‘ERR00′ =>”Does not supported function for only one image!”,
- ‘ERR01′ =>”Source is not a GIF image!”,
- ‘ERR02′ =>”Unintelligible flag “,
- ‘ERR03′ =>”Could not make animation from animated GIF source”,
- );
- function GIFEncoder ($GIF_src, $GIF_dly = 100, $GIF_lop = 0, $GIF_dis = 0, $GIF_red = 0, $GIF_grn = 0, $GIF_blu = 0, $GIF_mod = ‘bin’ )
- {
- if (!is_array($GIF_src) && !is_array($GIF_tim))
- {
- printf ( “%s: %s”, $this->VER, $this->ERR['ERR00']);
- exit( 0 );
- }
- $this->LOP = ($GIF_lop > -1) ? $GIF_lop : 0;
- $this->DIS = ($GIF_dis > -1) ? (( $GIF_dis < 3 ) ? $GIF_dis : 3) : 2;
- $this->COL = ($GIF_red > -1 && $GIF_grn > -1 && $GIF_blu > -1) ? ($GIF_red | ($GIF_grn << 8) | ($GIF_blu << 16)) : -1;
- for ($i = 0, $src_count = count($GIF_src); $i < $src_count; $i++ )
- {
- if (strToLower( $GIF_mod ) == “url”)
- {
- $this->BUF[] = fread (fopen($GIF_src [$i], “rb”), filesize ($GIF_src [$i]));
- }
- elseif(strToLower($GIF_mod) == “bin”)
- {
- $this->BUF [ ] = $GIF_src [ $i ];
- }
- else
- {
- printf(“%s: %s ( %s )!”, $this->VER, $this->ERR [ 'ERR02' ], $GIF_mod);
- exit(0);
- }
- if (substr($this->BUF[$i], 0, 6) != “GIF87a” && substr($this->BUF [$i], 0, 6) != “GIF89a”)
- {
- printf( “%s: %d %s”, $this->VER, $i, $this->ERR ['ERR01']);
- exit(0);
- }
- for ($j = (13 + 3 * (2 << (ord($this->BUF[$i]{10}) & 0×07 ))), $k = TRUE; $k; $j++)
- {
- switch ($this->BUF [$i]{$j})
- {
- case “!”:
- if ((substr($this->BUF[$i], ($j + 3), 8)) == “NETSCAPE”)
- {
- printf( “%s: %s ( %s source )!”, $this->VER, $this->ERR ['ERR03'], ($i + 1));
- exit( 0 );
- }
- break;
- case “;”:
- $k = FALSE;
- break;
- }
- }
- }
- GIFEncoder::GIFAddHeader();
- for($i = 0, $count_buf = count($this->BUF); $i < $count_buf; $i++)
- {
- GIFEncoder::GIFAddFrames($i, $GIF_dly[$i]);
- }
- GIFEncoder::GIFAddFooter();
- }
- function GIFAddHeader ( )
- {
- $cmap = 0;
- if (ord($this->BUF[0]{10}) & 0×80 )
- {
- $cmap = 3 * ( 2 << ( ord ( $this->BUF [ 0 ]{10} ) & 0×07 ));
- $this->GIF .= substr ( $this->BUF [ 0 ], 6, 7);
- $this->GIF .= substr ( $this->BUF [ 0 ], 13, $cmap);
- $this->GIF .= “!\377\13NETSCAPE2.0\3\1″ . GIFEncoder::GIFWord ( $this->LOP ) . “\0″;
- }
- }
- function GIFAddFrames ( $i, $d )
- {
- $Locals_str = 13 + 3 * (2 <<(ord($this->BUF[$i]{10}) & 0×07));
- $Locals_end = strlen($this->BUF[$i]) – $Locals_str – 1;
- $Locals_tmp = substr ($this->BUF[$i], $Locals_str, $Locals_end);
- $Global_len = 2 << (ord( $this->BUF [0]{10} ) & 0×07 );
- $Locals_len = 2 << (ord( $this->BUF[$i]{10}) & 0×07);
- $Global_rgb = substr($this->BUF[0], 13, 3 * (2 << ( ord ( $this->BUF[0]{10} ) & 0×07)));
- $Locals_rgb = substr ( $this->BUF[$i], 13, 3 * (2 << ( ord ( $this->BUF[$i]{10} ) & 0×07)));
- $Locals_ext = “!\xF9\x04″ . chr(($this->DIS << 2) + 0) . chr(($d >> 0) & 0xFF) . chr(($d >> 8) & 0xFF) . “\x0\x0″;
- if ( $this->COL > -1 && ord($this->BUF[$i]{10}) & 0×80)
- {
- for($j = 0; $j < (2 << (ord( $this->BUF[$i]{10}) & 0×07)); $j++ )
- {
- if(ord ($Locals_rgb{3 * $j + 0}) == ($this->COL >> 0) & 0xFF && ord ( $Locals_rgb { 3 * $j + 1 } ) == ( $this->COL >> 8 ) & 0xFF && ord ( $Locals_rgb { 3 * $j + 2 } ) == ( $this->COL >> 16 ) & 0xFF )
- {
- $Locals_ext = “!\xF9\x04″ . chr(($this->DIS << 2) + 1) . chr (( $d >> 0) & 0xFF) . chr (( $d >> 8) & 0xFF) . chr ($j) . “\x0″;
- break;
- }
- }
- }
- switch ( $Locals_tmp { 0 } )
- {
- case “!”:
- $Locals_img = substr($Locals_tmp, 8, 10);
- $Locals_tmp = substr($Locals_tmp, 18, strlen ($Locals_tmp) – 18);
- break;
- case “,”:
- $Locals_img = substr($Locals_tmp, 0, 10);
- $Locals_tmp = substr($Locals_tmp, 10, strlen($Locals_tmp) – 10);
- break;
- }
- if ( ord ( $this->BUF[$i]{10} ) & 0×80 && $this->IMG > -1 )
- {
- if ( $Global_len == $Locals_len )
- {
- if ( GIFEncoder::GIFBlockCompare ( $Global_rgb, $Locals_rgb, $Global_len ) )
- {
- $this->GIF .= ( $Locals_ext . $Locals_img . $Locals_tmp );
- }
- else
- {
- $byte = ord ( $Locals_img{9});
- $byte |= 0×80;
- $byte &= 0xF8;
- $byte |= ( ord ( $this->BUF [ 0 ]{10}) & 0×07);
- $Locals_img{9} = chr($byte);
- $this->GIF .= ($Locals_ext . $Locals_img . $Locals_rgb . $Locals_tmp);
- }
- }
- else
- {
- $byte = ord($Locals_img{9});
- $byte |= 0×80;
- $byte &= 0xF8;
- $byte |= (ord($this->BUF[$i]{10}) & 0×07);
- $Locals_img {9} = chr($byte);
- $this->GIF .= ($Locals_ext . $Locals_img . $Locals_rgb . $Locals_tmp);
- }
- }
- else
- {
- $this->GIF .= ( $Locals_ext . $Locals_img . $Locals_tmp );
- }
- $this->IMG = 1;
- }
- function GIFAddFooter ( ) {
- $this->GIF .= “;”;
- }
- function GIFBlockCompare ( $GlobalBlock, $LocalBlock, $Len )
- {
- for ( $i = 0; $i < $Len; $i++ )
- {
- if($GlobalBlock { 3 * $i + 0 } != $LocalBlock { 3 * $i + 0 } || $GlobalBlock { 3 * $i + 1 } != $LocalBlock { 3 * $i + 1 } || $GlobalBlock { 3 * $i + 2 } != $LocalBlock{3 * $i + 2})
- {
- return ( 0 );
- }
- }
- return ( 1 );
- }
- function GIFWord ( $int )
- {
- return ( chr ( $int & 0xFF ) . chr ( ( $int >> 8 ) & 0xFF ) );
- }
- function GetAnimation ( )
- {
- return ($this->GIF);
- }
- }
用PHP判断gif图片是不是动画
作者:admin 日期:2012-09-24
- <?php
- function IsAnimatedGif($filename)
- {
- $fp = fopen($filename, 'rb');
- $filecontent = fread($fp, filesize($filename));
- fclose($fp);
- return strpos($filecontent,chr(0x21).chr(0xff).chr(0x0b).'NETSCAPE2.0') === FALSE?0:1;
- }
- echo IsAnimatedGif("51windows.gif");
- ?>
为什么使用”NETSCAPE2.0″这一段呢?那时因为:
识别是否是动画,要检查文件中是否包含chr(0×21).chr(0xff).chr(0x0b).’NETSCAPE2.0‘chr(0×21).chr(0xff) 是gif图片中扩展功能段的标头‘NETSCAPE2.0‘是扩展功能执行的程序名
转载:六招教您提高B2B行业网站客户转化率
作者:admin 日期:2012-09-22
每一个B2B行业网站的运营者都希望每天有很多目标客户通过电话、QQ、在线留言等方式来咨 询收费服务,每个月主动咨询后成交的客户占总成交的客户数量越多,说明网站可能运营的越成功,这应该是一个综合的考核指标。在日常的QQ咨询服务中,有很多人问我:“李学江,为什么我的B2B行业网站每天有上万IP,但是每天通过电话、QQ、在线留言等方式来咨询收费服务的人却却寥寥无几呢?甚至有时一周一个咨询也没有”。还有人告诉我说,销售人员打电话向注册用户推荐网站的收费服务时,很多潜在客户都不知道网站有这个收费服务,即使知道,也了解的不多,他们很排斥我们给他们介绍,直接挂我们电话。
出现这些问题,当然有可能是各个方面的问题,除了网站的赢利模式设计可能有问题外,最关键的还是网站设计可能有问题,没有分析用户的心理,做用户行为研究,最大限度的向免费用户推广收费服务。一个B2B行业网站能否运营成功,细节很重要,每个环节都不能疏忽,是一个系统的工程。下面从几个方面来简要讲解。
1 在用户最需要的时候向他推广收费服务
网站的访问者都带着各种目的,有来采购产品的,有想发布信息,免费推广自己产品的,有来了解行业动态的,有想学习行业知识的等等 。从用户行为分析,网站收费服务推广,只有在用户最需要的时候,推广才是最有效的, 因为用户都很忙,大部分都是带着目的来的,完成自己想做的事,就很快离开了。比如某个采购信息、采购商名录,只想给收费会员看,所有用户都可以点,都可以登录后给买家留言3次,但是要看到对方的联系方式,必须要成为收费会员,这个时候就要在本应该显示联系方式的地方,全方位显示收费服务的介绍链接,比如:VIP服务介绍、成功案例等链接,并要用很吸引人的广告语,吸引目标客户点击。让免费会员看了后,有想咨询我们的冲动,通过这个方式就把一个可能付费的用户告诉了网站的销售人员,增加了促进销售的 可能,这个大家看的很多了。同时为了让更多人留下联系方式,一般不能在未注册前就告诉这个收费信息要交费才能看,先只告诉用户要先登录才能查看,登录后才显示收费服务介绍等。这个实际可以叫提升用户注册转化率,是提升客户转化率的方法之一。
360提供的Asp版和Php版的防注入代码
作者:admin 日期:2012-09-22
Php版本的:
- <?php
- //Code By Safe3
- function customError($errno, $errstr, $errfile, $errline)
- {
- echo "<b>Error number:</b> [$errno],error on line $errline in $errfile<br />";
- die();
- }
- set_error_handler("customError",E_ERROR);
- $getfilter="'|(and|or)\\b.+?(>|<|=|in|like)|\\/\\*.+?\\*\\/|<\\s*script\\b|\\bEXEC\\b|UNION.+?Select|Update.+?SET|Insert\\s+INTO.+?VALUES|(Select|Delete).+?FROM|(Create|Alter|Drop|TRUNCATE)\\s+(TABLE|DATABASE)";
- $postfilter="\\b(and|or)\\b.{1,6}?(=|>|<|\\bin\\b|\\blike\\b)|\\/\\*.+?\\*\\/|<\\s*script\\b|\\bEXEC\\b|UNION.+?Select|Update.+?SET|Insert\\s+INTO.+?VALUES|(Select|Delete).+?FROM|(Create|Alter|Drop|TRUNCATE)\\s+(TABLE|DATABASE)";
- $cookiefilter="\\b(and|or)\\b.{1,6}?(=|>|<|\\bin\\b|\\blike\\b)|\\/\\*.+?\\*\\/|<\\s*script\\b|\\bEXEC\\b|UNION.+?Select|Update.+?SET|Insert\\s+INTO.+?VALUES|(Select|Delete).+?FROM|(Create|Alter|Drop|TRUNCATE)\\s+(TABLE|DATABASE)";
- function StopAttack($StrFiltKey,$StrFiltValue,$ArrFiltReq){
- if(is_array($StrFiltValue))
- {
- $StrFiltValue=implode($StrFiltValue);
- }
- if (preg_match("/".$ArrFiltReq."/is",$StrFiltValue)==1){
- //slog("<br><br>操作IP: ".$_SERVER["REMOTE_ADDR"]."<br>操作时间: ".strftime("%Y-%m-%d %H:%M:%S")."<br>操作页面:".$_SERVER["PHP_SELF"]."<br>提交方式: ".$_SERVER["REQUEST_METHOD"]."<br>提交参数: ".$StrFiltKey."<br>提交数据: ".$StrFiltValue);
- print "360websec notice:Illegal operation!";
- exit();
- }
- }
- //$ArrPGC=array_merge($_GET,$_POST,$_COOKIE);
- foreach($_GET as $key=>$value){
- StopAttack($key,$value,$getfilter);
- }
- foreach($_POST as $key=>$value){
- StopAttack($key,$value,$postfilter);
- }
- foreach($_COOKIE as $key=>$value){
- StopAttack($key,$value,$cookiefilter);
- }
- if (file_exists('update360.php')) {
- echo "请重命名文件update360.php,防止黑客利用<br/>";
- die();
- }
- function slog($logs)
- {
- $toppath=$_SERVER["DOCUMENT_ROOT"]."/log.htm";
- $Ts=fopen($toppath,"a+");
- fputs($Ts,$logs."\r\n");
- fclose($Ts);
- }
- ?>
Asp版本的:
- <%
- 'Code by safe3
- On Error Resume Next
- if request.querystring<>"" then call stophacker(request.querystring,"'|(and|or)\b.+?(>|<|=|in|like)|/\*.+?\*/|<\s*script\b|\bEXEC\b|UNION.+?Select|Update.+?SET|Insert\s+INTO.+?VALUES|(Select|Delete).+?FROM|(Create|Alter|Drop|TRUNCATE)\s+(TABLE|DATABASE)")
- if request.Form<>"" then call stophacker(request.Form,"\b(and|or)\b.{1,6}?(=|>|<|\bin\b|\blike\b)|/\*.+?\*/|<\s*script\b|\bEXEC\b|UNION.+?Select|Update.+?SET|Insert\s+INTO.+?VALUES|(Select|Delete).+?FROM|(Create|Alter|Drop|TRUNCATE)\s+(TABLE|DATABASE)")
- if request.Cookies<>"" then call stophacker(request.Cookies,"\b(and|or)\b.{1,6}?(=|>|<|\bin\b|\blike\b)|/\*.+?\*/|<\s*script\b|\bEXEC\b|UNION.+?Select|Update.+?SET|Insert\s+INTO.+?VALUES|(Select|Delete).+?FROM|(Create|Alter|Drop|TRUNCATE)\s+(TABLE|DATABASE)")
- ms()
- function stophacker(values,re)
- dim l_get, l_get2,n_get,regex,IP
- for each n_get in values
- for each l_get in values
- l_get2 = values(l_get)
- set regex = new regexp
- regex.ignorecase = true
- regex.global = true
- regex.pattern = re
- if regex.test(l_get2) then
- IP=Request.ServerVariables("HTTP_X_FORWARDED_FOR")
- If IP = "" Then
- IP=Request.ServerVariables("REMOTE_ADDR")
- end if
- 'slog("<br><br>操作IP: "&ip&"<br>操作时间: " & now() & "<br>操作页面:"&Request.ServerVariables("URL")&"<br>提交方式: "&Request.ServerVariables("Request_Method")&"<br>提交参数: "&l_get&"<br>提交数据: "&l_get2)
- Response.Write "360websec notice:Illegal operation!"
- Response.end
- end if
- set regex = nothing
- next
- next
- end function
- sub slog(logs)
- dim toppath,fs,Ts
- toppath = Server.Mappath("/log.htm")
- Set fs = CreateObject("scripting.filesystemobject")
- If Not Fs.FILEEXISTS(toppath) Then
- Set Ts = fs.createtextfile(toppath, True)
- Ts.close
- end if
- Set Ts= Fs.OpenTextFile(toppath,8)
- Ts.writeline (logs)
- Ts.Close
- Set Ts=nothing
- Set fs=nothing
- end sub
- sub ms()
- dim path,fs
- path = Server.Mappath("update360.asp")
- Set fs = CreateObject("scripting.filesystemobject")
- If Fs.FILEEXISTS(path) Then
- Response.Write "请重命名升级文件update360.asp防止黑客利用"
- Response.End
- end if
- Set fs=nothing
- end sub
- %>
php统计mysql记录条数
作者:admin 日期:2012-09-17
<?php
/* 取记录条数 */
$sql="select * from info";
$result=mysql_query($sql);
echo mysql_num_rows($result)."<br/>";
$sql="select count(*) as sum from info";
$result=mysql_query($sql);
$row=mysql_fetch_array($result);
echo $row["sum"]."<br/>";
/* 当前时间 */
date_default_timezone_set("asia/shanghai"); /* 设置时区 */
echo date("y-m-d h:i:s");
?>
计算机如何识别色情图片?
作者:admin 日期:2012-09-16
是不是色情作品,一般人扫一眼心里就有数了。但对电脑来说,它们可不会自己分辨屏幕上那对男女是在谈情说爱,还是在宽衣解带。想让电脑知道哪些东西是不和谐的,还得靠程序员们的调教。不过,想教会电脑看AV并不是一件很容易的事情,因为机器没有七情六欲,没有感情,没有性冲动,唯一能接受的只有各种数据,程序员们要做的,就是让电脑识别色情作品特有的数据特征。
识色、辨形、听声
我们知道,每张图片里的任何一个点都包括亮度值、色相值、饱和度值,通过这三个值的大小的范围,电脑就能识别出“肉色”,进而猜测出图片里裸露的人体皮肤区域。 而那些“色图”相比于正常图片,最明显的特点就是画面像素中人体皮肤的颜色所占的比例比较大,整张图片比较“黄”,确切地说,研究者发现虽然不同肤色的主角在光线明暗不同环境下拍出来的皮肤颜色不尽相同,但是画面里人体皮肤的颜色总是在一定的范围内。另外,研究人员还发现暴露的区域图片一般纹理值比较小,颜色比较平滑,这也可以作为判断人体皮肤的依据之一。
电脑自动识别出图片里的人体皮肤区域
计算肤色区域的几何关系
当电脑“看到了”图片上有类似于人体皮肤颜色的一些区域之后,需要进一步确定这些区域的来源,看看它们是没穿衣服的女主角,还是来源于正常物体。假设两块黄色区域分别是两条腿或两只胳膊,另外一块区域是人的身体,这些区域的长度值、宽度值必须符合人体的大小比例,之间的位置必须满足一定的几何关系,这些都可以依靠电脑的计算得出结果。如果这些区域之间大小和位置不像是人的身体,就可以排除掉色情图片的嫌疑了。
把肤色和人体构造比例这两招教给电脑是研究者最先想到的解决方案,也是应用得最多的图片自动扫黄方法。凭借这两个简单而有效的主意,美国爱荷华大学和加州伯克利大学的研究人员在1996年发表了一篇名为《找到裸露的身体》( Finding Naked People )的论文(有点标题党的嫌疑)。
后来,世界各国对于此领域情有独钟的研究人员又想出了各种各样提高识别AV图片准确率的方法。
例如斯坦福大学的研究者通过对图片进行“小波分析”(编者按:这只是一个数学方法的名称)可以把色情图片里的人体轮廓提取出来,由于同一个女主角可以被摄像机从不同的角度拍摄,研究者还对提取出的轮廓进行了平移、转动、伸缩的数学变换。接下来,比对被测试的画面提取出的数据和几百张真正色情图片数学变换提取出的信息,两者越接近就说明被测试的图片越可能是色情图片。这样就能让电脑来判定被测试的图片里,不和谐内容出现的概率大小。
提取图片里的人体轮廓
而中科院自动化研究所的研究人员提出的方法里,为了识别电影里是否有限制级片段,可以先分析一下电影里是否含有限制级的声音。他们收集了592段“声优”的声音片段,然后分析了这些声音信号的十几项参数。根据需要被测试的声音片段的各项参数与这些例子的接近程度,可以计算出一个声音片段是“限制级声音”的概率,如果概率足够大,就要检查声音对应的视频画面有没有问题了。
错杀与漏放
在此类研究中,各个研究论文里都提到了作者测试了大量的样本,收集了包括几百部、上千部高清无码的片子和正常的片子(看来这一类研究做起来还是蛮有意思的,工作之余还可以欣赏一下影片),有的研究识别准确率可以达到90%以上,不过电脑的人工智能还是经常有失手的时候,把正常的画面冤枉成AV画面,或者让真正的“咸湿图片”漏网,市面上此类的软件也都不免有“看走眼”的问题。
比如下面三张图片就是此类软件算法出错的例子,让无辜的图片受冤屈。图片(a)(b)因为整张图片颜色“太黄”了,很像人皮肤的颜色,被电脑误判;图片(c)大老爷们光着膀子的画面让电脑来区分是否属于色情就颇有难度。此外,动物和雕像的图片也容易被错划入不健康图片。
让电脑迷惑的图片1
与此相反,以下三张应该被处理掉的图片却因为背景颜色纹理过多或者清晰度不够高而漏网
让电脑迷惑的图片2
由此可见,要想给视频和图片来个靠谱的自动分级,还需要让电脑更聪明才行。
相信以后计算机会在这个领域取得新的进展,不过至少目前的常用方法,还是通过征募一些有牺牲精神的壮士,进行人工鉴定来实现的。
网站分类的一点想法
作者:admin 日期:2012-09-14
广告位