今天,我们把我们上一篇博文中的小项目做一个升级版本!
 
1、产生彩色的验证码
 
在上一篇文中,我们产生了随机的验证码, 但是我们在有的网站上看到的验证码是彩色的,那么,我们怎么来产生彩色的验证码呢?
 
如果要产生彩色的验证码,那么就代表在网页上的表现形式就是1AQ9这种形式了,那么就代表网页中的源代码的表现也就只能为<span style=”color:rgb(x,y,z)”>x</span>!原因很简单,因为四个数字的颜色是不同的!当然,除了span标记,也可以由其他的标记来代替!如bistrongem等内联标记!
 
我们再来讨论一个问题:如果有多个页面都要使用随机数的话,每个页面都写这么多代码,这个工作量是可想而知的!那么最好的解决方法就是:首先将其封装成自定义函数,并且其存储在某一个文档内,然后,我们想调用该函数的话,我们只需要调用该文件就可以了(还记得包含文件吗?)
 
好了,可以工作了!
 
function  random()
 
{
 
       $chars = "0123456789";
 
       for($i=0;$i<4;$i++)
 
       {
 
              $char = substr($chars,rand(0,strlen($chars)-1),1);    
       
              $randChar .= "<span style=\"color:rgb(".rand(50,180).",".rand(50,180).",".rand(50,180).")\">" . $char . "</span>";
 
       }
 
       return $randChar;
 
}
 
 
现在我们再将上面的函数来升一级,那就是:我们已经将随机数的长度固定了,最好的方法是我们将系统的配置存储在一个配置文件里,由用户来决定随机数的长度!
 
好了,我们来创建一个配置文件----config.include.php
 
$config[“random”][“length”] = 4;
 
那么现在的问题就是如何将$config[“random”][“length”]的变量引入到函数内部,那就需要在函数内部添加global关键词了!
 
那么函数就变成了
 
function  random()
 
{
 
       global  $config;
       $chars = "0123456789";
 
       for($i=0;$i<$config["random"]["length"];$i++)
 
       {
 
              $char = substr($chars,rand(0,strlen($chars)-1),1);   
        
              $randChar .= "<span style=\"color:rgb(".rand(50,180).",".rand(50,180).",".rand(50,180).")\">" . $char . "</span>";
 
       }
 
       return $randChar;
 
}