预览模式: 普通 | 列表

Deprecated: Function ereg_replace() is deprecated

 在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错误给忽略掉。(众人皆又赞道:果……果……果是好法子!)

查看更多...

Tags: php

分类:技术文章 | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 2020

不同编码网站内容之间的JS调用方法

两个网站编码格式不同导致js调用乱码,UTF-8的文字内容在GB2312的编码页面下是不显示的。对于这样的问题处理的办法是更改JS代码如下:

XML/HTML代码
  1. <script type="text/javascript" src="..../" charset="utf-8"></script>   

对于其他类似情况,只要更改“charset=”后边的参数为你要调用页面的编码即可。

 

Tags: javascript

分类:技术文章 | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 2207

 创建一个窗体上的 web 浏览器控件。

  1. 在该窗体的声明部分中添加以下:

    ASP/Visual Basic代码
    1. Dim WithEvents Web_V1 as SHDocVwCtl.WebBrowser_V1  

  1. 这将声明 WebBrowser_V1 变量可以接收 WebBrowser_V1 为您提供 NewWindow 事件的事件。

  2. 在 Form_Load 事件中添加以下:

    ASP/Visual Basic代码
    1. Set Web_V1 = WebBrowser1.Object  
    2. WebBrowser1.Navigate2 "http://www.microsoft.com/"  

  1. 这样会将 WebBrowser_V1 对象设置为现有的 Internet 浏览器的 web 浏览器对象。

     

  2. NewWindow2 事件触发后,Web_V1_NewWindow 事件将作为其输入参数之一触发与该链接的 URL。请记住不,将取消设置为 True NewWindow2 中。此外,设置处理变量为 True 将 NewWindow 中的事件处理程序,以便不会创建 Internet Explorer 的新实例。下面的代码演示了此事件处理程序和代码以便在当前窗口中浏览必要:

    ASP/Visual Basic代码
    1. Private Sub Web_V1_NewWindow(ByVal URL As String, _  
    2.                           ByVal Flags As Long, _  
    3.                           ByVal TargetFrameName As String, _  
    4.                           PostData As Variant, _  
    5.                           ByVal Headers As String, _  
    6.                           Processed As Boolean)  
    7.         Processed = True  
    8.         WebBrowser1.Navigate URL  
    9. End Sub  

右键单击一个链接,然后选择"打开在新窗口中",您将找到链接仍会打开您的 web 浏览器控件内。

Tags: vb

分类:技术文章 | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 3516

[私密日志] 私密日志

该日志是私密日志,只有博主或发布者可以查看!
分类:技术文章 | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 1446

Php提升效率优化技巧

确实很有用的,大家平常开发中应该注意下

0、用单引号代替双引号来包含字符串,这样做会更快一些。因为PHP会在双引号包围的字符串中搜寻变量,单引号则不会,注意:只有echo能这么做,它是一种可以把多个字符串当作参数的“函数”(译注:PHP手册中说echo是语言结构,不是真正的函数,故把函数加上了双引号)。

1、如果能将类的方法定义成static,就尽量定义成static,它的速度会提升将近4倍。

 

查看更多...

Tags: php

分类:技术文章 | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 1887

PHP生成GIF动画实现动态图片验证码

 使用php的类编写的动画验证码模块

PHP代码
  1. <?php  
  2. /** 
  3. * 调用示例 
  4. * */  
  5. session_start();  
  6. $randCode = ”;  
  7. $chars = ‘abcdefghjkmnpqrstuvwxyzABCDEFGHJKLMNPRSTUVWXYZ23456789′;  
  8. for ( $i = 0; $i < 4; $i++ )  
  9. {  
  10. $randCode .= substr($chars, mt_rand(0, strlen($chars) – 1), 1);  
  11. }  
  12. $_SESSION['code'] = strtoupper($randCode); // 记录session  
  13. ImageCode($randCode, 60); // 显示GIF动画  
  14.   
  15. /** 
  16. * ImageCode 生成GIF图片验证 
  17. * @param $string 字符串 
  18. * @param $width 宽度 
  19. * @param $height 高度 
  20. * */  
  21. function ImageCode($string = ”, $width = 75, $height = 25)  
  22. {  
  23. $authstr = $string ? $string : ((time() % 2 == 0) ? mt_rand(1000, 9999) : mt_rand(10000, 99999));  
  24.   
  25. $board_width = $width;  
  26. $board_height = $height;  
  27. // 生成一个32帧的GIF动画  
  28. for($i = 0; $i < 32; $i++)  
  29. {  
  30. ob_start();  
  31. $image = imagecreate($board_width$board_height);  
  32. imagecolorallocate($image, 0,0,0);  
  33. // 设定文字颜色数组  
  34. $colorList[] = ImageColorAllocate($image, 15,73,210);  
  35. $colorList[] = ImageColorAllocate($image, 0,64,0);  
  36. $colorList[] = ImageColorAllocate($image, 0,0,64);  
  37. $colorList[] = ImageColorAllocate($image, 0,128,128);  
  38. $colorList[] = ImageColorAllocate($image, 27,52,47);  
  39. $colorList[] = ImageColorAllocate($image, 51,0,102);  
  40. $colorList[] = ImageColorAllocate($image, 0,0,145);  
  41. $colorList[] = ImageColorAllocate($image, 0,0,113);  
  42. $colorList[] = ImageColorAllocate($image, 0,51,51);  
  43. $colorList[] = ImageColorAllocate($image, 158,180,35);  
  44. $colorList[] = ImageColorAllocate($image, 59,59,59);  
  45. $colorList[] = ImageColorAllocate($image, 0,0,0);  
  46. $colorList[] = ImageColorAllocate($image, 1,128,180);  
  47. $colorList[] = ImageColorAllocate($image, 0,153,51);  
  48. $colorList[] = ImageColorAllocate($image, 60,131,1);  
  49. $colorList[] = ImageColorAllocate($image, 0,0,0);  
  50. $fontcolor = ImageColorAllocate($image, 0,0,0);  
  51. $gray = ImageColorAllocate($image, 245,245,245);  
  52.   
  53. $color = imagecolorallocate($image, 255,255,255);  
  54. $color2 = imagecolorallocate($image, 255,0,0);  
  55.   
  56. imagefill($image, 0, 0, $gray);  
  57.   
  58. $space = 15; // 字符间距  
  59. if($i > 0) // 屏蔽第一帧  
  60. {  
  61. for ($k = 0; $k < strlen($authstr); $k++)  
  62. {  
  63. $colorRandom = mt_rand(0,sizeof($colorList)-1);  
  64. $float_top = rand(0,4);  
  65. $float_left = rand(0,3);  
  66. imagestring($image, 6, $space * $k$top + $float_topsubstr($authstr$k, 1), $colorList[$colorRandom]);  
  67. }  
  68. }  
  69.   
  70. for ($k = 0; $k < 20; $k++)  
  71. {  
  72. $colorRandom = mt_rand(0,sizeof($colorList)-1);  
  73. imagesetpixel($image, rand()%70 , rand()%15 , $colorList[$colorRandom]);  
  74.   
  75. }  
  76. // 添加干扰线  
  77. for($k = 0; $k < 3; $k++)  
  78. {  
  79. $colorRandom = mt_rand(0, sizeof($colorList)-1);  
  80. // $todrawline = rand(0,1);  
  81. $todrawline = 1;  
  82. if($todrawline)  
  83. {  
  84. imageline($image, mt_rand(0, $board_width), mt_rand(0,$board_height), mt_rand(0,$board_width), mt_rand(0,$board_height), $colorList[$colorRandom]);  
  85. }  
  86. else  
  87. {  
  88. $w = mt_rand(0,$board_width);  
  89. $h = mt_rand(0,$board_width);  
  90. imagearc($image$board_width – floor($w / 2) , floor($h / 2), $w$h, rand(90,180), rand(180,270), $colorList[$colorRandom]);  
  91. }  
  92. }  
  93. imagegif($image);  
  94. imagedestroy($image);  
  95. $imagedata[] = ob_get_contents();  
  96. ob_clean();  
  97. ++$i;  
  98. }  
  99.   
  100. $gif = new GIFEncoder($imagedata);  
  101. Header (‘Content-type:image/gif’);  
  102. echo $gif->GetAnimation();  
  103. }  
  104. /** 
  105. * GIFEncoder类 
  106. * */  
  107. Class GIFEncoder  
  108. {  
  109. var $GIF = “GIF89a”; /* GIF header 6 bytes */  
  110. var $VER = “GIFEncoder V2.06″; /* Encoder version */  
  111.   
  112. var $BUF = Array ( );  
  113. var $LOP = 0;  
  114. var $DIS = 2;  
  115. var $COL = -1;  
  116. var $IMG = -1;  
  117.   
  118. var $ERR = Array (  
  119. ‘ERR00′ =>”Does not supported function for only one image!”,  
  120. ‘ERR01′ =>”Source is not a GIF image!”,  
  121. ‘ERR02′ =>”Unintelligible flag “,  
  122. ‘ERR03′ =>”Could not make animation from animated GIF source”,  
  123. );  
  124.   
  125. 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’ )  
  126. {  
  127. if (!is_array($GIF_src) && !is_array($GIF_tim))  
  128. {  
  129. printf ( “%s: %s”, $this->VER, $this->ERR['ERR00']);  
  130. exit( 0 );  
  131. }  
  132. $this->LOP = ($GIF_lop > -1) ? $GIF_lop : 0;  
  133. $this->DIS = ($GIF_dis > -1) ? (( $GIF_dis < 3 ) ? $GIF_dis : 3) : 2;  
  134. $this->COL = ($GIF_red > -1 && $GIF_grn > -1 && $GIF_blu > -1) ? ($GIF_red | ($GIF_grn << 8) | ($GIF_blu << 16)) : -1;  
  135.   
  136. for ($i = 0, $src_count = count($GIF_src); $i < $src_count$i++ )  
  137. {  
  138. if (strToLower$GIF_mod ) == “url”)  
  139. {  
  140. $this->BUF[] = fread (fopen($GIF_src [$i], “rb”), filesize ($GIF_src [$i]));  
  141. }  
  142. elseif(strToLower($GIF_mod) == “bin”)  
  143. {  
  144. $this->BUF [ ] = $GIF_src [ $i ];  
  145. }  
  146. else  
  147. {  
  148. printf(“%s: %s ( %s )!”, $this->VER, $this->ERR [ 'ERR02' ], $GIF_mod);  
  149. exit(0);  
  150. }  
  151. if (substr($this->BUF[$i], 0, 6) != “GIF87a” && substr($this->BUF [$i], 0, 6) != “GIF89a”)  
  152. {  
  153. printf( “%s: %d %s”, $this->VER, $i$this->ERR ['ERR01']);  
  154. exit(0);  
  155. }  
  156. for ($j = (13 + 3 * (2 << (ord($this->BUF[$i]{10}) & 0×07 ))), $k = TRUE; $k$j++)  
  157. {  
  158. switch ($this->BUF [$i]{$j})  
  159. {  
  160. case “!”:  
  161. if ((substr($this->BUF[$i], ($j + 3), 8)) == “NETSCAPE”)  
  162. {  
  163. printf( “%s: %s ( %s source )!”, $this->VER, $this->ERR ['ERR03'], ($i + 1));  
  164. exit( 0 );  
  165. }  
  166. break;  
  167. case “;”:  
  168. $k = FALSE;  
  169. break;  
  170. }  
  171. }  
  172. }  
  173. GIFEncoder::GIFAddHeader();  
  174. for($i = 0, $count_buf = count($this->BUF); $i < $count_buf$i++)  
  175. {  
  176. GIFEncoder::GIFAddFrames($i$GIF_dly[$i]);  
  177. }  
  178. GIFEncoder::GIFAddFooter();  
  179. }  
  180.   
  181. function GIFAddHeader ( )  
  182. {  
  183. $cmap = 0;  
  184.   
  185. if (ord($this->BUF[0]{10}) & 0×80 )  
  186. {  
  187. $cmap = 3 * ( 2 << ( ord ( $this->BUF [ 0 ]{10} ) & 0×07 ));  
  188.   
  189. $this->GIF .= substr ( $this->BUF [ 0 ], 6, 7);  
  190. $this->GIF .= substr ( $this->BUF [ 0 ], 13, $cmap);  
  191. $this->GIF .= “!\377\13NETSCAPE2.0\3\1″ . GIFEncoder::GIFWord ( $this->LOP ) . “\0″;  
  192. }  
  193. }  
  194.   
  195. function GIFAddFrames ( $i$d )  
  196. {  
  197.   
  198. $Locals_str = 13 + 3 * (2 <<(ord($this->BUF[$i]{10}) & 0×07));  
  199.   
  200. $Locals_end = strlen($this->BUF[$i]) – $Locals_str – 1;  
  201. $Locals_tmp = substr ($this->BUF[$i], $Locals_str$Locals_end);  
  202.   
  203. $Global_len = 2 << (ord( $this->BUF [0]{10} ) & 0×07 );  
  204. $Locals_len = 2 << (ord( $this->BUF[$i]{10}) & 0×07);  
  205.   
  206. $Global_rgb = substr($this->BUF[0], 13, 3 * (2 << ( ord ( $this->BUF[0]{10} ) & 0×07)));  
  207. $Locals_rgb = substr ( $this->BUF[$i], 13, 3 * (2 << ( ord ( $this->BUF[$i]{10} ) & 0×07)));  
  208.   
  209. $Locals_ext = “!\xF9\x04″ . chr(($this->DIS << 2) + 0) . chr(($d >> 0) & 0xFF) . chr(($d >> 8) & 0xFF) . “\x0\x0″;  
  210.   
  211. if ( $this->COL > -1 && ord($this->BUF[$i]{10}) & 0×80)  
  212. {  
  213. for($j = 0; $j < (2 << (ord( $this->BUF[$i]{10}) & 0×07)); $j++ )  
  214. {  
  215. 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 )  
  216. {  
  217. $Locals_ext = “!\xF9\x04″ . chr(($this->DIS << 2) + 1) . chr (( $d >> 0) & 0xFF) . chr (( $d >> 8) & 0xFF) . chr ($j) . “\x0″;  
  218. break;  
  219. }  
  220. }  
  221. }  
  222. switch ( $Locals_tmp { 0 } )  
  223. {  
  224. case “!”:  
  225. $Locals_img = substr($Locals_tmp, 8, 10);  
  226. $Locals_tmp = substr($Locals_tmp, 18, strlen ($Locals_tmp) – 18);  
  227. break;  
  228. case “,”:  
  229. $Locals_img = substr($Locals_tmp, 0, 10);  
  230. $Locals_tmp = substr($Locals_tmp, 10, strlen($Locals_tmp) – 10);  
  231. break;  
  232. }  
  233. if ( ord ( $this->BUF[$i]{10} ) & 0×80 && $this->IMG > -1 )  
  234. {  
  235. if ( $Global_len == $Locals_len )  
  236. {  
  237. if ( GIFEncoder::GIFBlockCompare ( $Global_rgb$Locals_rgb$Global_len ) )  
  238. {  
  239. $this->GIF .= ( $Locals_ext . $Locals_img . $Locals_tmp );  
  240. }  
  241. else  
  242. {  
  243. $byte = ord ( $Locals_img{9});  
  244. $byte |= 0×80;  
  245. $byte &= 0xF8;  
  246. $byte |= ( ord ( $this->BUF [ 0 ]{10}) & 0×07);  
  247. $Locals_img{9} = chr($byte);  
  248. $this->GIF .= ($Locals_ext . $Locals_img . $Locals_rgb . $Locals_tmp);  
  249. }  
  250. }  
  251. else  
  252. {  
  253. $byte = ord($Locals_img{9});  
  254. $byte |= 0×80;  
  255. $byte &= 0xF8;  
  256. $byte |= (ord($this->BUF[$i]{10}) & 0×07);  
  257. $Locals_img {9} = chr($byte);  
  258. $this->GIF .= ($Locals_ext . $Locals_img . $Locals_rgb . $Locals_tmp);  
  259. }  
  260. }  
  261. else  
  262. {  
  263. $this->GIF .= ( $Locals_ext . $Locals_img . $Locals_tmp );  
  264. }  
  265. $this->IMG = 1;  
  266. }  
  267.   
  268. function GIFAddFooter ( ) {  
  269. $this->GIF .= “;”;  
  270. }  
  271.   
  272. function GIFBlockCompare ( $GlobalBlock$LocalBlock$Len )  
  273. {  
  274. for ( $i = 0; $i < $Len$i++ )  
  275. {  
  276. 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})  
  277. {  
  278. return ( 0 );  
  279. }  
  280. }  
  281. return ( 1 );  
  282. }  
  283.   
  284. function GIFWord ( $int )  
  285. {  
  286. return ( chr ( $int & 0xFF ) . chr ( ( $int >> 8 ) & 0xFF ) );  
  287. }  
  288.   
  289. function GetAnimation ( )  
  290. {  
  291. return ($this->GIF);  
  292. }  
  293. }  

 

Tags: php

分类:技术文章 | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 3725

用PHP判断gif图片是不是动画

 

PHP代码
  1. <?php  
  2. function IsAnimatedGif($filename)  
  3. {  
  4.     $fp = fopen($filename'rb');  
  5.     $filecontent = fread($fpfilesize($filename));  
  6.     fclose($fp);  
  7.     return strpos($filecontent,chr(0x21).chr(0xff).chr(0x0b).'NETSCAPE2.0') === FALSE?0:1;  
  8. }  
  9. echo IsAnimatedGif("51windows.gif");  
  10. ?>  

为什么使用”NETSCAPE2.0″这一段呢?那时因为:

识别是否是动画,要检查文件中是否包含chr(0×21).chr(0xff).chr(0x0b).’NETSCAPE2.0‘chr(0×21).chr(0xff) 是gif图片中扩展功能段的标头‘NETSCAPE2.0‘是扩展功能执行的程序名

Tags: php

分类:技术文章 | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 2627

每一个B2B行业网站的运营者都希望每天有很多目标客户通过电话、QQ、在线留言等方式来咨 询收费服务,每个月主动咨询后成交的客户占总成交的客户数量越多,说明网站可能运营的越成功,这应该是一个综合的考核指标。在日常的QQ咨询服务中,有很多人问我:“李学江,为什么我的B2B行业网站每天有上万IP,但是每天通过电话、QQ、在线留言等方式来咨询收费服务的人却却寥寥无几呢?甚至有时一周一个咨询也没有”。还有人告诉我说,销售人员打电话向注册用户推荐网站的收费服务时,很多潜在客户都不知道网站有这个收费服务,即使知道,也了解的不多,他们很排斥我们给他们介绍,直接挂我们电话。

出现这些问题,当然有可能是各个方面的问题,除了网站的赢利模式设计可能有问题外,最关键的还是网站设计可能有问题,没有分析用户的心理,做用户行为研究,最大限度的向免费用户推广收费服务。一个B2B行业网站能否运营成功,细节很重要,每个环节都不能疏忽,是一个系统的工程。下面从几个方面来简要讲解。

1 在用户最需要的时候向他推广收费服务

网站的访问者都带着各种目的,有来采购产品的,有想发布信息,免费推广自己产品的,有来了解行业动态的,有想学习行业知识的等等 。从用户行为分析,网站收费服务推广,只有在用户最需要的时候,推广才是最有效的, 因为用户都很忙,大部分都是带着目的来的,完成自己想做的事,就很快离开了。比如某个采购信息、采购商名录,只想给收费会员看,所有用户都可以点,都可以登录后给买家留言3次,但是要看到对方的联系方式,必须要成为收费会员,这个时候就要在本应该显示联系方式的地方,全方位显示收费服务的介绍链接,比如:VIP服务介绍、成功案例等链接,并要用很吸引人的广告语,吸引目标客户点击。让免费会员看了后,有想咨询我们的冲动,通过这个方式就把一个可能付费的用户告诉了网站的销售人员,增加了促进销售的 可能,这个大家看的很多了。同时为了让更多人留下联系方式,一般不能在未注册前就告诉这个收费信息要交费才能看,先只告诉用户要先登录才能查看,登录后才显示收费服务介绍等。这个实际可以叫提升用户注册转化率,是提升客户转化率的方法之一。

查看更多...

Tags: 网站运营

分类:业界文摘 | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 1732

360提供的Asp版和Php版的防注入代码

 Php版本的:

PHP代码
  1. <?php  
  2. //Code By Safe3   
  3. function customError($errno$errstr$errfile$errline)  
  4. {   
  5.  echo "<b>Error number:</b> [$errno],error on line $errline in $errfile<br />";  
  6.  die();  
  7. }  
  8. set_error_handler("customError",E_ERROR);  
  9. $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)";  
  10. $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)";  
  11. $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)";  
  12. function StopAttack($StrFiltKey,$StrFiltValue,$ArrFiltReq){    
  13.   
  14. if(is_array($StrFiltValue))  
  15. {  
  16.     $StrFiltValue=implode($StrFiltValue);  
  17. }    
  18. if (preg_match("/".$ArrFiltReq."/is",$StrFiltValue)==1){     
  19.         //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);  
  20.         print "360websec notice:Illegal operation!";  
  21.         exit();  
  22. }        
  23. }    
  24. //$ArrPGC=array_merge($_GET,$_POST,$_COOKIE);  
  25. foreach($_GET as $key=>$value){   
  26.     StopAttack($key,$value,$getfilter);  
  27. }  
  28. foreach($_POST as $key=>$value){   
  29.     StopAttack($key,$value,$postfilter);  
  30. }  
  31. foreach($_COOKIE as $key=>$value){   
  32.     StopAttack($key,$value,$cookiefilter);  
  33. }  
  34. if (file_exists('update360.php')) {  
  35.     echo "请重命名文件update360.php,防止黑客利用<br/>";  
  36.     die();  
  37. }  
  38. function slog($logs)  
  39. {  
  40.   $toppath=$_SERVER["DOCUMENT_ROOT"]."/log.htm";  
  41.   $Ts=fopen($toppath,"a+");  
  42.   fputs($Ts,$logs."\r\n");  
  43.   fclose($Ts);  
  44. }  
  45. ?>  

Asp版本的:

ASP/Visual Basic代码
  1. <%   
  2. 'Code by safe3  
  3. On Error Resume Next  
  4. 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)")  
  5. 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)")  
  6. 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)")   
  7. ms()  
  8. function stophacker(values,re)  
  9.  dim l_get, l_get2,n_get,regex,IP  
  10.  for each n_get in values  
  11.   for each l_get in values  
  12.    l_get2 = values(l_get)  
  13.    set regex = new regexp  
  14.    regex.ignorecase = true  
  15.    regex.global = true  
  16.    regex.pattern = re  
  17.    if regex.test(l_get2) then  
  18.                                 IP=Request.ServerVariables("HTTP_X_FORWARDED_FOR")  
  19.                                 If IP = "" Then   
  20.                                   IP=Request.ServerVariables("REMOTE_ADDR")  
  21.                                 end if  
  22.                                 'slog("<br><br>操作IP: "&ip&"<br>操作时间: " & now() & "<br>操作页面:"&Request.ServerVariables("URL")&"<br>提交方式: "&Request.ServerVariables("Request_Method")&"<br>提交参数: "&l_get&"<br>提交数据: "&l_get2)  
  23.     Response.Write "360websec notice:Illegal operation!"  
  24.     Response.end  
  25.    end if  
  26.    set regex = nothing  
  27.   next  
  28.  next  
  29. end function   
  30.   
  31. sub slog(logs)  
  32.         dim toppath,fs,Ts  
  33.         toppath = Server.Mappath("/log.htm")  
  34.                                 Set fs = CreateObject("scripting.filesystemobject")  
  35.                                 If Not Fs.FILEEXISTS(toppath) Then   
  36.                                     Set Ts = fs.createtextfile(toppath, True)  
  37.                                     Ts.close  
  38.                                 end if  
  39.                                     Set Ts= Fs.OpenTextFile(toppath,8)  
  40.                                     Ts.writeline (logs)  
  41.                                     Ts.Close  
  42.                                     Set Ts=nothing  
  43.                                     Set fs=nothing  
  44. end sub  
  45. sub ms()  
  46.         dim path,fs  
  47.         path = Server.Mappath("update360.asp")  
  48.         Set fs = CreateObject("scripting.filesystemobject")  
  49.         If Fs.FILEEXISTS(path) Then   
  50.         Response.Write "请重命名升级文件update360.asp防止黑客利用"  
  51.         Response.End  
  52.         end if  
  53.         Set fs=nothing  
  54. end sub  
  55. %>  

Tags: asp php

分类:业界文摘 | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 3728

php统计mysql记录条数

<?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");
?>

查看更多...

Tags: php

分类:技术文章 | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 4952

计算机如何识别色情图片?

是不是色情作品,一般人扫一眼心里就有数了。但对电脑来说,它们可不会自己分辨屏幕上那对男女是在谈情说爱,还是在宽衣解带。想让电脑知道哪些东西是不和谐的,还得靠程序员们的调教。不过,想教会电脑看AV并不是一件很容易的事情,因为机器没有七情六欲,没有感情,没有性冲动,唯一能接受的只有各种数据,程序员们要做的,就是让电脑识别色情作品特有的数据特征。

识色、辨形、听声

我们知道,每张图片里的任何一个点都包括亮度值、色相值、饱和度值,通过这三个值的大小的范围,电脑就能识别出“肉色”,进而猜测出图片里裸露的人体皮肤区域。 而那些“色图”相比于正常图片,最明显的特点就是画面像素中人体皮肤的颜色所占的比例比较大,整张图片比较“黄”,确切地说,研究者发现虽然不同肤色的主角在光线明暗不同环境下拍出来的皮肤颜色不尽相同,但是画面里人体皮肤的颜色总是在一定的范围内。另外,研究人员还发现暴露的区域图片一般纹理值比较小,颜色比较平滑,这也可以作为判断人体皮肤的依据之一。

电脑自动识别出图片里的人体皮肤区域

计算肤色区域的几何关系

当电脑“看到了”图片上有类似于人体皮肤颜色的一些区域之后,需要进一步确定这些区域的来源,看看它们是没穿衣服的女主角,还是来源于正常物体。假设两块黄色区域分别是两条腿或两只胳膊,另外一块区域是人的身体,这些区域的长度值、宽度值必须符合人体的大小比例,之间的位置必须满足一定的几何关系,这些都可以依靠电脑的计算得出结果。如果这些区域之间大小和位置不像是人的身体,就可以排除掉色情图片的嫌疑了。

把肤色和人体构造比例这两招教给电脑是研究者最先想到的解决方案,也是应用得最多的图片自动扫黄方法。凭借这两个简单而有效的主意,美国爱荷华大学和加州伯克利大学的研究人员在1996年发表了一篇名为《找到裸露的身体》( Finding Naked People )的论文(有点标题党的嫌疑)。

后来,世界各国对于此领域情有独钟的研究人员又想出了各种各样提高识别AV图片准确率的方法。

例如斯坦福大学的研究者通过对图片进行“小波分析”(编者按:这只是一个数学方法的名称)可以把色情图片里的人体轮廓提取出来,由于同一个女主角可以被摄像机从不同的角度拍摄,研究者还对提取出的轮廓进行了平移、转动、伸缩的数学变换。接下来,比对被测试的画面提取出的数据和几百张真正色情图片数学变换提取出的信息,两者越接近就说明被测试的图片越可能是色情图片。这样就能让电脑来判定被测试的图片里,不和谐内容出现的概率大小。

提取图片里的人体轮廓

而中科院自动化研究所的研究人员提出的方法里,为了识别电影里是否有限制级片段,可以先分析一下电影里是否含有限制级的声音。他们收集了592段“声优”的声音片段,然后分析了这些声音信号的十几项参数。根据需要被测试的声音片段的各项参数与这些例子的接近程度,可以计算出一个声音片段是“限制级声音”的概率,如果概率足够大,就要检查声音对应的视频画面有没有问题了。

错杀与漏放

在此类研究中,各个研究论文里都提到了作者测试了大量的样本,收集了包括几百部、上千部高清无码的片子和正常的片子(看来这一类研究做起来还是蛮有意思的,工作之余还可以欣赏一下影片),有的研究识别准确率可以达到90%以上,不过电脑的人工智能还是经常有失手的时候,把正常的画面冤枉成AV画面,或者让真正的“咸湿图片”漏网,市面上此类的软件也都不免有“看走眼”的问题。

比如下面三张图片就是此类软件算法出错的例子,让无辜的图片受冤屈。图片(a)(b)因为整张图片颜色“太黄”了,很像人皮肤的颜色,被电脑误判;图片(c)大老爷们光着膀子的画面让电脑来区分是否属于色情就颇有难度。此外,动物和雕像的图片也容易被错划入不健康图片。

让电脑迷惑的图片1

与此相反,以下三张应该被处理掉的图片却因为背景颜色纹理过多或者清晰度不够高而漏网

让电脑迷惑的图片2

由此可见,要想给视频和图片来个靠谱的自动分级,还需要让电脑更聪明才行。

相信以后计算机会在这个领域取得新的进展,不过至少目前的常用方法,还是通过征募一些有牺牲精神的壮士,进行人工鉴定来实现的。

分类:业界文摘 | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 2122

网站分类的一点想法

网站分类很简单,无非就是横向行业产品属性价格分类,纵向省市地区街道小区,数据量足够大的前提下,越细分越好。个人看法,欢迎拍砖!

分类:随笔杂记 | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 1916

 广告位

↑返回顶部↑