PHP积分兑换接口实例


Posted in PHP onFebruary 09, 2015

本文实例讲述了PHP积分兑换接口的实现方法。分享给大家供大家参考。具体实现方法如下:

exchange.php接口内容如下:

<?php  

  

/*session_start(); 

if(!isset($_SESSION['zaszh_user_id'])){ 

    echo json_encode(array('status'=>'error','msg'=>'连接超时,请重新打开页面。')); 

    exit; 

} 

$user_id = $_SESSION['zaszh_user_id'];*/  

  

$user_id = 1; // 测试用  

$exchange_points = intval($_GET['exchange_points']);  

  

require('connect_database.php');  

// 扣除答题积分  

$mysqli->query("update zaszh_user set answer_points=answer_points-{$exchange_points} where id='{$user_id}' and answer_points>={$exchange_points}");  

if($mysqli->affected_rows){  

    // 有积分  

    switch($exchange_points){  

        // 5元话费  

        case 200:  

            $mysqli->query("update zaszh_telephone_charge_surplus set charge_surplus=charge_surplus-5 where date=substring(now(),1,10) and charge_surplus>=5");  

            if($mysqli->affected_rows){  

                // 有剩余  

                $mysqli->query("insert into zaszh_award(user_id,prize,create_date) values('{$user_id}','5元话费',unix_timestamp(now()))");  

                if($mysqli->affected_rows){  

                    echo json_encode(array('status'=>'success','msg'=>'5元话费'));  

                }else{  

                    // 获奖失败  

                }  

            }else{  

                // 无剩余  

                // 恢复答题积分  

                $mysqli->query("update zaszh_user set answer_points=answer_points+{$exchange_points} where id='{$user_id}'");  

            }  

            break;  

        // 10元话费  

        case 400:  

            $mysqli->query("update zaszh_telephone_charge_surplus set charge_surplus=charge_surplus-10 where date=substring(now(),1,10) and charge_surplus>=10");  

            if($mysqli->affected_rows){  

                // 有剩余  

                $mysqli->query("insert into zaszh_award(user_id,prize,create_date) values('{$user_id}','10元话费',unix_timestamp(now()))");  

                if($mysqli->affected_rows){  

                    echo json_encode(array('status'=>'success','msg'=>'10元话费'));  

                }else{  

                    // 获奖失败  

                }  

            }else{  

                // 无剩余  

                // 恢复答题积分  

                $mysqli->query("update zaszh_user set answer_points=answer_points+{$exchange_points} where id='{$user_id}'");  

            }  

            break;  

    }  

  

    // 记录积分消耗  

    $mysqli->query("insert into zaszh_answer_points_consume(user_id,points_consume,consume_for,create_date) values('{$user_id}','{$exchange_points}','exchange',unix_timestamp(now()))");  

}else{  

    // 无积分  

    echo json_encode(array('status'=>'error','msg'=>'您的积分不足。'));  

}  

$mysqli->close();

希望本文所述对大家的php程序设计有所帮助。

PHP 相关文章推荐
PHP 学习路线与时间表
Feb 21 PHP
php上的memcache和memcached两个pecl库
Mar 29 PHP
如何让搜索引擎抓取AJAX内容解决方案
Aug 25 PHP
php rsa加密解密使用详解
Jan 14 PHP
php递归遍历删除文件的方法
Apr 17 PHP
ubuntu下配置nginx+php+mysql详解
Sep 10 PHP
9个比较实用的php代码片段
Mar 15 PHP
ThinkPHP框架搭建及常见问题(XAMPP安装失败、Apache/MySQL启动失败)
Apr 15 PHP
php常用字符函数实例小结
Dec 29 PHP
PHP实现自动发送邮件功能代码(qq 邮箱)
Aug 18 PHP
PHP+Ajax实现的博客文章添加类别功能示例
Mar 29 PHP
TP5框架实现自定义分页样式的方法示例
Apr 05 PHP
PHP答题类应用接口实例
Feb 09 #PHP
自己写的php中文截取函数mb_strlen和mb_substr
Feb 09 #PHP
php构造函数的继承方法
Feb 09 #PHP
php继承中方法重载(覆盖)的应用场合
Feb 09 #PHP
php抽象类使用要点与注意事项分析
Feb 09 #PHP
PHP中的socket_read和socket_recv区别详解
Feb 09 #PHP
支持png透明图片的php生成缩略图类分享
Feb 08 #PHP
You might like
PHP 数字左侧自动补0
2008/03/31 PHP
CMS中PHP判断系统是否已经安装的方法示例
2014/07/26 PHP
php使用Cookie实现和用户会话的方法
2015/01/21 PHP
php获取一定范围内取N个不重复的随机数
2016/05/28 PHP
TP3.2框架分页相关实现方法分析
2020/06/03 PHP
js 发个判断字符串是否为符合标准的函数
2009/04/27 Javascript
善用事件代理,警惕闭包的性能陷阱。
2011/01/20 Javascript
30分钟就入门的正则表达式基础教程
2013/02/25 Javascript
javascript避免数字计算精度误差的方法详解
2014/03/05 Javascript
纯JavaScript实现的兼容各浏览器的添加和移除事件封装
2015/03/28 Javascript
Bootstrap每天必学之标签与徽章
2015/11/27 Javascript
JavaScript 监控微信浏览器且自带返回按钮时间
2016/11/27 Javascript
详解angular element()方法使用
2017/04/08 Javascript
Node.js使用Angular简单示例
2018/05/11 Javascript
JS数组的常用10种方法详解
2020/05/08 Javascript
[01:32]2016国际邀请赛中国区预选赛CDEC战队教练采访
2016/06/26 DOTA
Python中的urllib模块使用详解
2015/07/07 Python
Python模拟百度登录实例详解
2016/01/20 Python
Python使用pymysql小技巧
2017/06/04 Python
flask入门之文件上传与邮件发送示例
2018/07/18 Python
详解js文件通过python访问数据库方法
2019/03/03 Python
python matplotlib 画dataframe的时间序列图实例
2019/11/20 Python
Python日志syslog使用原理详解
2020/02/18 Python
通过CSS3的object-fit来调整图片适配尺寸的技巧简介
2016/02/27 HTML / CSS
html5指南-1.html5全局属性(html5 global attributes)深入理解
2013/01/07 HTML / CSS
HTML5+css3:3D旋转木马效果相册
2017/01/03 HTML / CSS
使用Html5中的cavas画一面国旗
2019/09/25 HTML / CSS
Jacques Lemans德国:奥地利钟表品牌
2019/12/26 全球购物
怎样创建、运行java程序
2014/08/01 面试题
服务员岗位责任制
2014/02/11 职场文书
《曹刿论战》教学反思
2014/03/02 职场文书
房屋出售授权委托书
2014/10/12 职场文书
新生开学寄语大全
2015/05/28 职场文书
2016消防宣传标语口号
2015/12/26 职场文书
竞聘演讲报告:基本写作有哪些?附开头范文
2019/10/16 职场文书
MySQL中一条SQL查询语句是如何执行的
2022/04/08 MySQL