php 登陆程序,PHP(10) 用户登录程序(版本2)

用户登录程序(版本2)

今天,我们把我们上一篇博文中的小项目做一个升级版本!

1、产生彩色的验证码

在上一篇文中,我们产生了随机的验证码,但是我们在有的网站上看到的验证码是彩色的,那么,我们怎么来产生彩色的验证码呢?

如果要产生彩色的验证码,那么就代表在网页上的表现形式就是1AQ9这种形式了,那么就代表网页中的源代码的表现也就只能为x!原因很简单,因为四个数字的颜色是不同的!当然,除了span标记,也可以由其他的标记来代替!如b、i、strong、em等内联标记!

我们再来讨论一个问题:如果有多个页面都要使用随机数的话,每个页面都写这么多代码,这个工作量是可想而知的!那么最好的解决方法就是:首先将其封装成自定义函数,并且其存储在某一个文档内,然后,我们想调用该函数的话,我们只需要调用该文件就可以了(还记得包含文件吗?)!

好了,可以工作了!

functionrandom()

{

$chars = "0123456789";

for($i=0;$i<4;$i++)

{

$char = substr($chars,rand(0,strlen($chars)-1),1);

$randChar .= "" . $char . "";

}

return $randChar;

}

现在我们再将上面的函数来升一级,那就是:我们已经将随机数的长度固定了,最好的方法是我们将系统的配置存储在一个配置文件里,由用户来决定随机数的长度!

好了,我们来创建一个配置文件----config.include.php

$config[“random”][“length”] = 4;

那么现在的问题就是如何将$config[“random”][“length”]的变量引入到函数内部,那就需要在函数内部添加global关键词了!

那么函数就变成了

functionrandom()

{

global$config;

$chars = "0123456789";

for($i=0;$i

{

$char = substr($chars,rand(0,strlen($chars)-1),1);

$randChar .= "" . $char . "";

}

return $randChar;

}

当然,RGB颜色理论上的范围为0至255,但是我们一般的取值范围为50-180之间!

运行后的效果如下:

646f2f026959a554522a989882f17225.png

另外,我们发现产生的验证码中存在相同的数字,如果我现在不想产生相同的数字,那该怎么办呢?当产生一个数字后,我们就把产生的这个数字从原字符串中删除就可以了!

那么函数就变成了:

functionrandom()

{

global$config;

$chars = "0123456789";

for($i=0;$i

{

$char = substr($chars,rand(0,strlen($chars)-1),1);

$chars = str_replace($char,null,$chars);

$randChar .= "" . $char . "";

}

return $randChar;

}

其效果如下:

43aac3da5bc67e9b0934d8b396778742.png

2.数据库问题

在一个项目中会存在多个页面都会操作数据库的情况,如果每个页面都去连接数据库,情况就会变成很繁琐!根据随机数的经验,我们也将其封装成自定义函数!代码如下:

functionconnect()

{

global $config;

$conn = mysql_connect($config["server"]["hostname"],$config["server"]["username"],$config["server"]["password"]);

mysql_select_db($config["server"]["database"]);

return $conn;

}

functionquery($sql)

{

$result = mysql_query($sql);

return $result;

}

functiongetRowsNum($result)

{

$rowsNum = mysql_num_rows($result);

return $rowsNum;

}

functiongetFieldsNum($result)

{

$fieldsNum = mysql_num_fields($result);

return $fieldsNum;

}

functiongetFieldName($result,$fieldIndex)

{

$fieldName = mysql_field_name($result,$fieldName);

return$fieldName;

}

functiongetRow($result)

{

$row = mysql_fetch_assoc($result);

return $row;

}

functioncheckUserLogin($sql)

{

$result = query($sql);

$rowsNum = getRowsNum($result);

$userLogined = $rowsNum ? true : false;

return $userLogined;

}

functionfreeResult($result)

{

return mysql_free_result($result);

}

functionclose()

{

return mysql_close();

}

?>

项目的运行结果如下

0ef42c268d2d9369aa20bd53f3876e70.png

682748b5b58e6fbc3a46bfb7a55b0099.png

源代码在附件里!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值