|
效果参考(附源码)http://mail.htjs.net/yanzhengma/test.php
();
?>

[I]
//检验校验码
if(isset(
[color=]$HTTP_POST_VARS
[
[color=]"sub"
])):
if(
[color=]$HTTP_POST_VARS
[
[color=]"number"
] !=
[color=]$HTTP_SESSION_VARS
[
[color=]login_check_number
] || empty(
[color=]$HTTP_POST_VARS
[
[color=]"number"
])){
echo
[color=]"校验码不正确!"
;
}else{
echo
[color=]"验证码通过!"
;
}
endif;
[color=]show_source
(
[color=]'test.php'
);
//以上本页的源码
//以下是生成验证码的源码
[color=]show_source
(
[color=]'YanZhengMa.php'
);
?>
();
[color=]session_register
(
[color=]"login_check_number"
);
//昨晚看到了chianren上的验证码效果,就考虑了一下,用PHP的GD库完成了类似功能
//先成生背景,再把生成的验证码放上去
[color=]$
=
[color=]120
;
//先定义图片的长、宽
[color=]$
=
[color=]40
;
if(
[color=]$HTTP_GET_VARS
[
[color=]"act"
]==
[color=]"init"
){
//srand(microtime() * 100000);//PHP420后,srand不是必须的
for(
[color=]$Tmpa
=
[color=]0
;
[color=]$Tmpa
[color=]4
;
[color=]$Tmpa
++){
[color=]$nmsg
.=
[color=]dechex
(
[color=]rand
(
[color=]0
,
[color=]15
));
}//by sports98
[color=]$HTTP_SESSION_VARS
[
[color=]login_check_number
] =
[color=]$nmsg
;
//$HTTP_SESSION_VARS[login_check_number] = strval(mt_rand("1111","9999")); //生成4位的随机数,放入session中
//谁能做下补充,可以同时生成字母和数字啊??----由sports98完成了
[color=]$a
=
[color=]imageCreate
(
[color=]$
,
[color=]$
);
//生成图片
[color=]ImageColorAllocate
(
[color=]$aimg
,
[color=]255
,
[color=]255
,
[color=]255
);
//图片底色,ImageColorAllocate第1次定义颜色PHP就认为是底色了
[color=]$black
=
[color=]ImageColorAllocate
(
[color=]$aimg
,
[color=]0
,
[color=]0
,
[color=]0
);
//定义需要的黑色
[color=]ImageRectangle
(
[color=]$aimg
,
[color=]0
,
[color=]0
,
[color=]$
-
[color=]1
,
[color=]$
-
[color=]1
,
[color=]$black
);
//先成一黑色的矩形把图片包围
//下面该生成雪花背景了,其实就是在图片上生成一些符号
for (
[color=]$i
=
[color=]1
;
[color=]$i
[color=]100
;
[color=]$i
++) {
//先用100个做测试
[color=]imageString
(
[color=]$aimg
,
[color=]1
,
[color=]mt_rand
(
[color=]1
,
[color=]$
),
[color=]mt_rand
(
[color=]1
,
[color=]$
),
[color=]"*"
,
[color=]imageColorAllocate
(
[color=]$aimg
,
[color=]mt_rand
(
[color=]200
,
[color=]255
),
[color=]mt_rand
(
[color=]200
,
[color=]255
),
[color=]mt_rand
(
[color=]200
,
[color=]255
)));
//哈,看到了吧,其实也不是雪花,就是生成*号而已。为了使它们看起来"杂乱无章、5颜6色",就得在1个1个生成它们的时候,让它们的位置、颜色,甚至大小都用随机数,rand()或mt_rand都可以完成。
}
//上面生成了背景,现在就该把已经生成的随机数放上来了。道理和上面差不多,随机数1个1个地放,同时让他们的位置、大小、颜色都用成随机数~~
//为了区别于背景,这里的颜色不超过200,上面的不小于200
for (
[color=]$i
=
[color=]0
;
[color=]$i
[color=]strlen
(
[color=]$HTTP_SESSION_VARS
[
[color=]login_check_number
]);
[color=]$i
++){
[color=]imageString
(
[color=]$aimg
,
[color=]mt_rand
(
[color=]3
,
[color=]5
),
[color=]$i
*
[color=]$
/
[color=]4
+
[color=]mt_rand
(
[color=]1
,
[color=]10
),
[color=]mt_rand
(
[color=]1
,
[color=]$
/
[color=]2
),
[color=]$HTTP_SESSION_VARS
[
[color=]login_check_number
][
[color=]$i
],
[color=]imageColorAllocate
(
[color=]$aimg
,
[color=]mt_rand
(
[color=]0
,
[color=]100
),
[color=]mt_rand
(
[color=]0
,
[color=]150
),
[color=]mt_rand
(
[color=]0
,
[color=]200
)));
}
[color=]Header
(
[color=]"Content-type: image/png"
);
//告诉浏览器,下面的数据是图片,而不要按文字显示
[color=]ImagePng
(
[color=]$aimg
);
//生成png格式。。。嘿嘿效果蛮像回事的嘛。。。
[color=]ImageDestroy
(
[color=]$aimg
);
}
[color=]?>
|
|