刚刚学习用到的CI管理员验证登陆
热度 1已有 1412 次阅读2012-12-2 10:51
|个人分类:CI框架|
管理员, 验证
application/libraries 下,新建captcha_code.php,代码如下:
<?php
class Captcha_code
{
var $width='68';
var $num='4';
var $height='24';
var $name='randcode';
public function __construct($conf="")
{
if($conf!="")
{
foreach($conf as $key=>$value)
{
$this->$key=$value;
}
}
}
function show()
{
Header("Content-type: image/gif");
/*
* 初始化
*/
$border = 1; //是否要边框 1要:0不要
$how = $this->num; //验证码位数
$w = $this->width; //图片宽度
$h = $this->height; //图片高度
$fontsize = 5; //字体大小
$alpha = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"; //验证码内容1:字母
$number = "023456789"; //验证码内容2:数字
$randcode = ""; //验证码字符串初始化
srand((double)microtime()*1000000); //初始化随机数种子
$im = ImageCreate($w, $h); //创建验证图片
/*
* 绘制基本框架
*/
$bgcolor = ImageColorAllocate($im, 255, 255, 255); //设置背景颜色
ImageFill($im, 0, 0, $bgcolor); //填充背景色
if($border)
{
$black = ImageColorAllocate($im, 0, 0, 0); //设置边框颜色
ImageRectangle($im, 0, 0, $w-1, $h-1, $black); //绘制边框
}
/*
* 逐位产生随机字符
*/
for($i=0; $i<$how; $i++)
{
$alpha_or_number = mt_rand(1, 1); //字母还是数字
$str = $alpha_or_number ? $alpha : $number;
$which = mt_rand(0, strlen($str)-1); //取哪个字符
$code = substr($str, $which, 1); //取字符
$j = !$i ? 4 : $j+15; //绘字符位置
$color3 = ImageColorAllocate($im, mt_rand(0,100), mt_rand(0,100), mt_rand(0,100)); //字符随即颜色
ImageChar($im, $fontsize, $j, 3, $code, $color3);//绘字符
$randcode .= $code; //逐位加入验证码字符串
}
/*
* 添加干扰
*/
for($i=0; $i<5; $i++)//绘背景干扰线
{
$color1 = ImageColorAllocate($im, mt_rand(0,255), mt_rand(0,255), mt_rand(0,255)); //干扰线颜色
ImageArc($im, mt_rand(-5,$w), mt_rand(-5,$h), mt_rand(20,300), mt_rand(20,200), 55, 44, $color1); //干扰线
}
for($i=0; $i<$how*15; $i++)//绘背景干扰点
{
$color2 = ImageColorAllocate($im, mt_rand(0,255), mt_rand(0,255), mt_rand(0,255)); //干扰点颜色
ImageSetPixel($im, mt_rand(0,$w), mt_rand(0,$h), $color2); //干扰点
}
//把验证码字符串写入session
//$this->session->set_userdata(array($this->name=>$randcode));
$CI = & get_instance();
$CI->session->set_userdata($this->name, $randcode);
$_SESSION[$this->name]=$randcode;
/*绘图结束*/
Imagegif($im);
ImageDestroy($im);
/*绘图结束*/
}
}
?>
controllers 处加入:
//管理后台 - 登陆
public function login()
{
if( ! empty($_POST) ) //如果有数据POST过来,执行下面
{
if(strtoupper($_POST['vdcode']) == $this->session->userdata('yzm') ) //验证码正确
{
if($this->admin_model->login( //传POST过来的用户名和密码过去
array(
'username'=>$_POST['username'],
'password'=>$_POST['password']
)))
{ //登陆成功
redirect('admin/admin/index'); //跳转到后台首页
}
else //登陆失败,弹出提示信息
{
echo '<script type="text/javascript">alert("您输入的登陆信息有误!");</script>' ;
}
}
else //验证码不正确
{
echo '<script type="text/javascript">alert("验证码有误!");</script>' ;
}
}
$this->load->view('admin/admin/login'); //视图模板
}
//管理后台 - 验证码
public function yzm()
{
$conf['name']='yzm'; //作为配置参数
$this->load->library('captcha_code',$conf); //加载自定义的captcha_code
$this->captcha_code->show(); //显示验证码
}
视图处加入:
<form method="post" action="">
<dl>
<dt>用户名:</dt>
<dd><input type="text" name="username"/></dd>
<dt>密 码:</dt>
<dd><input type="password" name="password" class="alltxt"/></dd>
<dt>验证码:</dt>
<dd><input type="text" name="vdcode" id="vdcode"/>
<img id="imgcode" src="<?php echo site_url('admin/admin/yzm'); ?>" title="看不清?点击更换" onclick="this.src='<?php echo site_url('admin/admin/yzm');?>/'+ Math.random()" align="absmiddle" style="cursor: pointer;" />
<a href="javascript:viod()" onclick="document.getElementById('imgcode').src='<?php echo site_url('admin/admin/yzm');?>/'+ Math.random()">看不清? </a>
</dd>
<dt> </dt>
<dd><button type="submit" class="login-btn" onclick="this.form.submit();">登录</button></dd>
</dl>
</form>