PHP+Ajax手机发红包的程序例子
PHP发红包基本流程:当输入完红包数量和总金额后,PHP会根据这两个值进行随机分配每个金额,保证每个人都能领取到一个红包,且每个红包金额不等。也就是每个人领取的红包金额要不同,并且所有红包金额总额等于总金额。如图:
php发红包实现原理:
设定总金额为10元,有N个人随机领取:
N=1 第一个
则红包金额=X元;
N=2 第二个
为保证第二个红包可以正常发出,第一个红包金额=0.01至9.99之间的某个随机数
第二个红包=10-第一个红包金额;
N=3 第三个
红包1=0.01至9.99之间的某个随机数
红包2=0.01至(10-红包1-0.01)的某个随机数
红包3=10-红包1-红包2
……
于是我们得到一个规律,在分配当前红包金额时,先预留剩余红白所需最少金额,然后在0.01至总金额-预留金额间取随机数,得到的随机数就是当前红包分配的金额。
实际应用中,程序先将红包金额分配好,即发红包时,红包个数以及每个红包的金额都分配好了,那么用户来抢红包时,我们随机给用户返回一个红包即可。
jQuery代码:
$(function() {
$("button").click(function() {
$.ajax({
type: 'POST',
url: 'bao.php',
dataType: 'json',
beforeSend: function() {
$("#result").html('正在分配红包');
},
success: function(json) {
if (json.msg == 1) {
var str = '';
var res = json.res;
$.each(res,
function(index, array) {
str += '<p>第<span>' + array['i'] + '</span>个红包,
金额<span>' + array['money'] + '</span>元,余额<span>' +
array['total'] + '元</span></p>';
});
$("#result").html(str);
} else {
$("#result").html('数据出错!');
}
}
});
});
});
PHP代码:bao.php
$total=20;//红包总金额
$num=10;// 分成10个红包,支持10人随机领取
$min=0.01;//每个人最少能收到0.01元
for ($i=1;$i<$num;$i++)
{
$safe_total=($total-($num-$i)*$min)/($num-$i);//随机安全上限
$money=mt_rand($min*100,$safe_total*100)/100;
$total=$total-$money;
echo '第'.$i.'个红包:'.$money.' 元,余额:'.$total.' 元 ';
}
echo '第'.$num.'个红包:'.$total.' 元,余额:0 元';
验证码图片html代码:
<img src="1.php" onclick="this.src = '1.php?t=' + Math.random()" title="点击刷新" />
第一个图像验证码类,其他6种验证码类请下载查看:
class captcha{
/**
+----------------------------------------------------------
* 生成验证码
+----------------------------------------------------------
* @static
* @access public
+----------------------------------------------------------
* @param int $len 验证码字符数
* @param int $font_size 验证码字体大小
* @param string $name session名称
* @param int $width 图片长度
* @param int $height 图片高度
+----------------------------------------------------------
* @return void
+----------------------------------------------------------
*/
static function generate($len=4,$font_size=48,$name='captcha',$width='',$height=''){
if($width=='') $width=($font_size+5)*($len+1);
if($height=='') $height=($font_size)*2;
$chars='bcdefhkmnrstuvwxyABCDEFGHKMNPRSTUVWXY345689';
$str='';
for($i=0;$i<$len;$i++){
$str .= substr($chars,mt_rand(0,strlen($chars)-1),1);
}
$_SESSION[$name]=$str;//写入session
for($num=0;$num<10;$num++){
ob_start();
$image=imagecreatetruecolor($width,$height);//创建图片
$bg_color=imagecolorallocate($image,255,255,255);//设置背景颜色
$border_color=imagecolorallocate($image,100,100,100);//设置边框颜色
$text_color=imagecolorallocate($image,0,0,0);//设置验证码颜色
imagefilledrectangle($image,0,0,$width-1,$height-1,$bg_color);//填充图片背景色
imagerectangle($image,0,0,$width-1,$height-1,$border_color);//填充图片边框颜色
for($i=0;$i<5;$i++){
$line_color=imagecolorallocate($image,rand(0,255),rand(0,255),rand(0,255));//干扰线颜色
imageline($image,rand(0,$width),0,$width,$height,$line_color);//画一条线段
}
for($i=0;$i<500;$i++){
$dot_color=imagecolorallocate($image,rand(0,255),rand(0,255),rand(0,255));//干扰点颜色
imagesetpixel($image,rand()%$width,rand()%$height,$dot_color);//画一个像素点
}
for($i=0;$i<$len;$i++){
imagettftext($image,$font_size,rand(-3,3),$font_size/2+($font_size+5)*$i,$height/1.25-rand(2,3),$text_color,'Groupsex.ttf',$str[$i]);//用规定字体向图像写入文本
}
imagegif($image);
imagedestroy($image);
$imagedata[] = ob_get_contents();
ob_clean();
}
require('GIFEncoder.class.php');
$gif = new GIFEncoder($imagedata);
ob_clean();//防止出现'图像因其本身有错无法显示'的问题
header('Content-type:image/gif');
echo $gif->GetAnimation();
}
}
//调用示例
session_start();
captcha::generate(6,48);
背景
PHP校验邮箱地址的方法很多, 比较常用的就是自己写正则了, 不过正则多麻烦, 我PHP自带了方法做校验。
filter_var
filter_var是PHP内置的一个变量过滤的方法, 提供了很多实用的过滤器, 可以用来校验整数、浮点数、邮箱、URL、MAC地址等。
具体的过滤器参考: filters.validate
filter_var如果返回false, 说明变量无法通过过滤器, 也就是不合法了。
$email = "lastchiliarch@163.com";
var_dump(filter_var($email, FILTER_VALIDATE_EMAIL));
$email = "asb";
var_dump(filter_var($email, FILTER_VALIDATE_EMAIL));
$email = "1@a.com";
var_dump(filter_var($email, FILTER_VALIDATE_EMAIL));
输出:
string(21) "lastchiliarch@163.com"
bool(false)
string(7) "1@a.com"
对于asb这种非法邮箱格式返回了false, 但对于1@a.com则通过了,还是略有瑕疵啊。
不过一般的正则也通过会认为1@a.com是一个合法的邮箱, 那有啥办法可以更精准的验证呢?
checkdnsrr
checkdnsrr其实是用来查询指定的主机的DNS记录的,我们可以借用它来验证邮箱是否存在。
对于1@a.com肯定是MX记录不存在的。
$email = "lastchiliarch@163.com";
var_dump(checkdnsrr(array_pop(explode("@",$email)),"MX"));
$email = "1@a.com";
var_dump(checkdnsrr(array_pop(explode("@",$email)),"MX"));
输出:
bool(true)
bool(false)
可以看到, 很完美, 唯一的缺点就是太慢了, 毕竟是要做一次网络请求。 所以不适合同步对大量的邮箱采用这种做法去校验。
filter_var+checkdnsrr
我们可以接合filter_var 和checkdnsrr做校验, 对于绝大多数的非法邮箱肯定会在filter_var的时候就挂掉了, 剩下的再用
checkdnsrr进一步判断。
$email_arr = array("lastchiliarch@163.com", "1@a.com");
foreach($email_arr as $email) {
if (filter_var($email, FILTER_VALIDATE_EMAIL) === false) {
echo "invalid email: $email \n";
continue;
}
if(checkdnsrr(array_pop(explode("@",$email)),"MX") === false) {
echo "invalid email: $email \n";
continue;
}
}
输出: invalid email: 1@a.com
但要注意的是, 由于只是检查MX记录, 所以只能判断163.com是存在的, 但不能说明lastchiliarch这个用户是存在的。
想要更精确的判断邮箱存在, 那只能连接到smtp服务器去验证了。
判断搜索引擎蜘蛛爬虫其实是非常的简单只要判断来源useragent然后检查有没有搜索引擎蜘蛛指定的字符串了,下面我们来看一篇关于php判断搜索引擎蜘蛛爬虫的方法,希望此教程能够帮助到大家。先来看蜘蛛列表
搜索引擎 | user-agent(包含) | 是否PTR | 备注 |
Googlebot | √ | host ip 得到域名:googlebot.com主域名 | |
baidu | Baiduspider | √ | host ip 得到域名:*.baidu.com 或 *.baidu.jp |
yahoo | Yahoo! | √ | host ip 得到域名:inktomisearch.com主域名 |
Sogou | Sogou | × | *Sogou web spider/3.0(+http://www.sogou.com/docs/help/webmasters.htm#07″)
*Sogou Push Spider/3.0(+http://www.sogou.com/docs/help/webmasters.htm#07″) |
网易 | YodaoBot | × | *Mozilla/5.0 (compatible; YodaoBot/1.0;http://www.yodao.com/help/webmaster/spider/”; ) |
MSN | MSNBot | √ | host ip 得到域名:live.com主域名 |
360 | 360Spider | × | Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.8.0.11) Firefox/1.5.0.11; 360Spider |
soso | Sosospider | × | Sosospider+(+http://help.soso.com/webspider.htm) |
bing | bingbot | √ | host ip 得到域名:msn.com主域名 |
再来看看例子
<?php
//php判断搜索引擎蜘蛛爬虫的方法
function checkrobot($useragent='') {
static $kw_spiders = array('bot', 'crawl', 'spider', 'slurp', 'sohu-search', 'lycos', 'robozilla');
static $kw_browsers = array('msie', 'netscape', 'opera', 'konqueror', 'mozilla');
$useragent = strtolower(empty($useragent) ? $_SERVER['HTTP_USER_AGENT'] : $useragent);
if (strpos($useragent, 'http://') === false && dstrpos($useragent, $kw_browsers))
return false;
if (dstrpos($useragent, $kw_spiders))
return true;
return false;
}
function dstrpos($string, $arr, $returnvalue = false) {
if (empty($string))
return false;
foreach ((array) $arr as $v) {
if (strpos($string, $v) !== false) {
$return = $returnvalue ? $v : true;
return $return;
}
}
return false;
}
if(checkrobot()){
echo '蜘蛛';
}else{
echo '人类';
}
?>
例子
PHP反解析IP方法
<?php
/**
*检查IP及蜘蛛真实性
* (check_spider('66.249.74.44',$_SERVER['HTTP_USER_AGENT']));
* @copyright http://blog.chacuo.net
* @author 8292669
* @param string $ip IP地址
* @param string $ua ua地址
* @return false|spidername false检测失败不在指定列表中
*/
function check_spider($ip,$ua)
{
static $spider_list=array(
'google'=>array('Googlebot','googlebot.com'),
'baidu'=>array('Baiduspider','.baidu.'),
'yahoo'=>array('Yahoo!','inktomisearch.com'),
'msn'=>array('MSNBot','live.com'),
'bing'=>array('bingbot','msn.com')
);
if(!preg_match('/^(\d{1,3}\.){3}\d{1,3}$/',$ip)) return false;
if(empty($ua)) return false;
foreach ($spider_list as $k=>$v)
{
///如果找到了
if(stripos($ua,$v[0])!==false)
{
$domain = gethostbyaddr($ip);
if($domain && stripos($domain,$v[1])!==false)
{
return $k;
}
}
}
return false;
}
目前只加入几个搜索引擎检测,这些是可以做反解析查询的。不能做反解析查询的,最好做速度限制,用户会使用它们来伪造搜索引擎来抓取你的资源
相关文章
- 支付宝支付在国内算是大家了,我们到处都可以使用支付宝了,下文整理介绍的是在安卓app应用中使用支付宝进行支付的开发例子。 之前讲了一篇博客关与支付宝集成获取...2016-09-20
- PHP+Ajax有许多的功能都会用到它小编今天就有使用PHP+Ajax实现的一个微信登录功能了,下面我们来看一个PHP+Ajax手机发红包的程序例子,具体如下所示。 PHP发红包基本...2016-11-25
- 这篇文章主要介绍了C#开发Windows窗体应用程序的简单操作步骤,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-04-12
- 本文通过例子,讲述了C++调用C#的DLL程序的方法,作出了以下总结,下面就让我们一起来学习吧。...2020-06-25
- 很多用安卓智能手机的朋友是用九宫格锁屏,网上也有暴力删除手机图形锁的方法,不过我们可以用程序来破解。本文只提供技术学习,不能干坏事 安卓手机的图形锁(九宫格)...2016-09-20
- 华为手机怎么恢复已卸载的应用?有时候我们在使用华为手机的时候,想知道卸载的应用怎么恢复,这篇文章主要介绍了华为手机恢复应用教程,需要的朋友可以参考下...2020-06-29
- 本文通过两个示例讲解了一下Process类调用外部应用程序的基本用法,并简单讲解了StartInfo属性,有需要的朋友可以参考一下。...2020-06-25
- 这篇文章主要介绍了微信小程序 页面传值详解的相关资料,需要的朋友可以参考下...2017-03-13
- 华为手机怎么开启双时钟?华为手机是可以设置双时钟的,如果来回在两个有时差的地方工作,是可以设置双时钟显示,下面我们就来看看华为添加双时钟的技巧,需要的朋友可以参考下...2020-12-08
安卓手机wifi打不开修复教程,安卓手机wifi打不开解决方法
手机wifi打不开?让小编来告诉你如何解决。还不知道的朋友快来看看。 手机wifi是现在生活中最常用的手机功能,但是遇到手机wifi打不开的情况该怎么办呢?如果手机wifi...2016-12-21- 大概有如下步骤 新建项目Bejs 新建文件package.json 新建文件Gruntfile.js 命令行执行grunt任务 一、新建项目Bejs源码放在src下,该目录有两个js文件,selector.js和ajax.js。编译后代码放在dest,这个grunt会...2014-06-07
- 这篇文章主要介绍了uniapp微信小程序:key失效的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-01-20
- 本文实例讲述了PHP常用的小程序代码段。分享给大家供大家参考,具体如下:1.计算两个时间的相差几天$startdate=strtotime("2009-12-09");$enddate=strtotime("2009-12-05");上面的php时间日期函数strtotime已经把字符串...2015-11-24
将c#编写的程序打包成应用程序的实现步骤分享(安装,卸载) 图文
时常会写用c#一些程序,但如何将他们和photoshop一样的大型软件打成一个压缩包,以便于发布....2020-06-25- 这篇文章主要介绍了微信小程序 网络请求(GET请求)详解的相关资料,需要的朋友可以参考下...2016-11-22
- 这篇文章主要给大家介绍了关于微信小程序如何获取图片宽度与高度的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-03-10
- 这篇文章主要介绍了微信小程序 二维码生成工具 weapp-qrcode详解,教大家如何在项目中引入weapp-qrcode.js文件,通过实例代码给大家介绍的非常详细,需要的朋友可以参考下...2021-10-23
- 这篇文章主要为大家详细介绍了微信小程序自定义tabbar组件,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-03-14
- 这篇文章主要介绍了Python爬取微信小程序通用方法代码实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-09-29
- 这篇文章主要介绍了微信小程序手势操作之单触摸点与多触摸点的相关资料,需要的朋友可以参考下...2017-03-13