11月14日用ajax、PHP、session做购物车

购物车网页代码

1.登录界面login.php

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<script src="../jquery-1.11.2.min.js"></script>
<title>无标题文档</title>
</head>

<body>
<div>用户名:<input type="text" id="uid" /></div>
<div>密码:<input type="text" id="pwd" /></div>
<input type="button" value="登录" id="btn" />
</body>
<script type="text/javascript">
$("#btn").click(function(){
    var uid = $("#uid").val();
    var pwd = $("#pwd").val();
    $.ajax({
            url:"loginchuli.php",
            data:{u:uid,p:pwd},
            type:"POST",
            dataType:"TEXT",
            success: function(data){
                if(data.trim()=="OK")
                {
                    window.location.href="main.php";
                }
                else
                {
                    alert("用户名或密码错误");
                }
            }
        })
    })
</script>
</html>

2.登录处理页面loginchuli.php

<?phpsession_start();

include("../DBDA.class.php");
$db = new DBDA();
$uid = $_POST["u"];
$pwd = $_POST["p"];
$sql = "select password from login where username=‘{$uid}‘";
$mm = $db->StrQuery($sql);
if($mm==$pwd && $pwd!="")
{
    $UserName = $_POST["uid"];
    $_SESSION["uid"]=$uid;
    echo "OK";
}
else
{
    echo "NO";
}?>

3.主页面main.php

<?php
session_start();
include("../DBDA.class.php");
$db = new DBDA();
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title><br />
<style type="text/css">
.list{ width:100%; height:30px; margin-top:10px; text-align:center; line-height:30px; vertical-align:middle}
</style>
</head>
<body>
<div style="width:100%; height:100px; background-color:#6CC">
    <h1 style="float:left">大苹果商城</h1>
    <a style="float:right; margin-top:40px" href="zhuxiao.php">注销</a>
</div>
<br />
<div style="width:100%; height:600px">
    <div id="left" style="width:20%; float:left">
        <a href="main.php"><div class="list">浏览商品</div></a>
        <a href="zhanghu.php"><div class="list">查看账户</div></a>
        <a href="gouwuche.php"><div class="list">查看购物车</div></a>
    </div>

    <div id="right" style="width:80%; float:left">
<?php
    $agwc = array();
    if(!empty($_SESSION["gwc"]))
    {
        $agwc = $_SESSION["gwc"];
    }
    $zhonglei = count($agwc);
    $sum = 0;
    foreach($agwc as $v)
    {
        $sql = "select price from fruit where ids=‘{$v[0]}‘";
        $danjia = $db->StrQuery($sql);
        $sum = $sum +$danjia*$v[1];
    }
    echo "<div>购物车中有:{$zhonglei}种商品,总价格为:{$sum}元.</div>";
    ?>
        <table width="100%" border="1" cellpadding="0" cellspacing="0">
        <tr>
            <td>代号</td>
            <td>水果名称</td>
            <td>水果价格</td>
            <td>源产地</td>
            <td>库存量</td>
            <td>操作</td>
        </tr>
 <?php
        $sql = "select * from fruit";
        $attr = $db->Query($sql);

        foreach($attr as $v)
        {
            echo "<tr><td>{$v[0]}</td>
            <td>{$v[1]}</td>
            <td>{$v[2]}</td>
            <td>{$v[3]}</td>
            <td>{$v[4]}</td>
            <td><a href=‘goumai.php?code={$v[0]}‘>购买</a></td></tr>";
        }
        ?>        
        </table>
    </div>
</div>

</body>
</html>

4.购买处理页面goumai.php

<?php
session_start();
$code = $_GET["code"];

if(empty($_SESSION["gwc"]))
{
    //第一次点击购买
    $attr = array(
        array($code,1)
    );
    $_SESSION["gwc"] = $attr;
}
else
{
    //不是第一次点击购买
    $attr = $_SESSION["gwc"];
    $bs=0;
    foreach($attr as $k=>$v)
    {
        if($v[0]==$code)
        {
            $bs=1;
            $attr[$k][1] = $attr[$k][1]+1;
        }
    }
    //如果没有在数组里面出现
    if($bs==0)
    {
        $shuzu = array($code,1);
        $attr[] = $shuzu;
    }

    $_SESSION["gwc"]=$attr;

}
header("location:main.php");?>

5.订单处理页面,计算选取水果的总价,和水果剩余量。dingdan.php

<?php
session_start();
include("../DBDA.class.php");
$db = new DBDA();
$uid = $_SESSION["uid"];
$attr = array();
if(!empty($_SESSION["gwc"]))
{
    $attr = $_SESSION["gwc"];
}
//看下两个条件是否都满足
$bs = true;

//判断余额是否满足
    //根据用户名找余额
    $syue = "select account from login where username=‘{$uid}‘";
    $yue = $db->StrQuery($syue);

    //根据购物车数组取总金额
    $sum = 0;
    foreach($attr as $v)
    {
        $sql = "select price from fruit where ids=‘{$v[0]}‘";
        $danjia = $db->StrQuery($sql);
        $sum = $sum +$danjia*$v[1];
    }
    if($yue<$sum)
    {
        $bs = false;
        echo "YEBUZU";
        exit;
    }

//判断库存是否满足

foreach($attr as $v)
{
    $skucun = "select name,numbers from fruit where ids=‘{$v[0]}‘";
    $akucun = $db->Query($skucun);
    if($akucun[0][1]<$v[1])
    {
        $bs = false;
        echo "{$akucun[0][0]}库存不足!";
        exit;

    }
}

//添加订单,减库存,减余额

if($bs)
{
    //减库存
    foreach($attr as $v)
    {
        $sql = "update fruit set numbers = numbers-{$v[1]} where ids=‘{$v[0]}‘";
        $db->Query($sql,0);
    }

    //减余额
    $jianyue="update login set account=account-{$sum} where username=‘{$uid}‘";
    $db->Query($jianyue,0);

    //添加订单
    $dingdanhao = $uid+date("YmdHis");
    $t = time();

    $sorder = "insert into orders values(‘{$dingdanhao}‘,‘{$uid}‘,‘{$t}‘)";
    $db->Query($sorder,0);

    foreach($attr as $v)
    {
        $sxq = "insert into orderdetails values(‘‘,‘{$dingdanhao}‘,‘{$v[0]}‘,‘{$v[1]}‘)";
        $db->Query($sxq,0);
    }
}

echo "OK";?>

6.购物车页面

<?php
session_start();
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title><br />
<style type="text/css">
.list{ width:100%; height:30px; margin-top:10px; text-align:center; line-height:30px; vertical-align:middle}
</style>
<script src="../../jquery-1.11.2.min.js"></script>
</head>

<body>
<div style="width:100%; height:100px; background-color:#6CC">
    <h1 style="float:left">大苹果商城</h1>
    <a style="float:right; margin-top:40px" href="zhuxiao.php">注销</a>
</div>
<br />
<div style="width:100%; height:600px">
    <div id="left" style="width:20%; float:left">
        <a href="main.php"><div class="list">浏览商品</div></a>
        <a href="zhanghu.php"><div class="list">查看账户</div></a>
        <a href="gouwuche.php"><div class="list">查看购物车</div></a>
    </div>

    <div id="right" style="width:80%; float:left">
        <table width="100%" border="1" cellpadding="0" cellspacing="0">
        <tr>
            <td>商品名称</td>
            <td>商品单价</td>
            <td>购买数量</td>
            <td>操作</td>
        </tr>
<?php
        include("../DBDA.class.php");
        $db = new DBDA();
        $attr=array();
        if(!empty($_SESSION["gwc"]))
        {
            $attr = $_SESSION["gwc"];
        }

        foreach($attr as $k=>$v)
        {
            $sql = "select name,price from fruit where ids=‘{$v[0]}‘";
            $ashuiguo = $db->Query($sql);

            echo "<tr><td>{$ashuiguo[0][0]}</td><td>{$ashuiguo[0][1]}</td><td>{$v[1]}</td><td><a href=‘shanchu.php?sy={$k}‘>删除</a></td></tr>";

        }

        ?>
        </table>
        <div id="tj">提交订单</div><div id="ts"></div>
    </div>
</div>

<script type="text/javascript">
$("#tj").click(function(){
        $.ajax({
                url:"dingdan.php",
                dataType:"TEXT",
                success: function(data){
                        if(data.trim()=="OK")
                        {
                            alert("购买成功");
                        }
                        else if(data.trim()=="YEBUZU")
                        {
                            $("#ts").html("余额不足");
                            $("#ts").css("color","red");
                        }
                        else
                        {
                            $("#ts").html(data);
                            $("#ts").css("color","red");
                        }
                    }
            });
    })
</script>
</body>
</html>

7.购物车页面删除处理页面shanchu.php

<?php
session_start();

$sy = $_GET["sy"];

$attr = $_SESSION["gwc"];

if($attr[$sy][1]>1)
{
    $attr[$sy][1] = $attr[$sy][1]-1;
}
else
{
    unset($attr[$sy]);
    $attr = array_values($attr);
}
$_SESSION["gwc"]=$attr;

header("location:gouwuche.php");?>

8.账户余额页面zhanghu.php

<?php
session_start();
$uid = $_SESSION[‘uid‘];
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title><br />
<style type="text/css">
.list{ width:100%; height:30px; margin-top:10px; text-align:center; line-height:30px; vertical-align:middle}
</style>
</head>
<body>
<div style="width:100%; height:100px; background-color:#6CC">
    <h1 style="float:left">大苹果商城</h1>
    <a style="float:right; margin-top:40px" href="zhuxiao.php">注销</a>
</div>
<br />
<div style="width:100%; height:600px">
    <div id="left" style="width:20%; float:left">
        <a href="main.php"><div class="list">浏览商品</div></a>
        <a href="zhanghu.php"><div class="list">查看账户</div></a>
        <a href="gouwuche.php"><div class="list">查看购物车</div></a>
    </div>
    <div id="right" style="width:80%; height:150px; float:left">
<?php
        include("../DBDA.class.php");
        $db = new DBDA();
        $sql = "select Account from login where UserName=‘{$uid}‘";
        $result = $db->strQuery($sql);

        echo ("您的账户中还剩余".$result);
    ?>
    </div>
</div>

</body>
</html>

时间: 2024-10-21 16:13:53

11月14日用ajax、PHP、session做购物车的相关文章

2014年11月12~11月14日,杨学明老师《软件测试管理》内训在北京某银行软件中心成功举办!

2014年11月12~11月14日,北京天气呈现少有的APEC蓝,著名研发管理专家杨学明老师为某银行提供了三天的内训服务,此次培训由两部分组成,第一部分是<软件测试管理高级实务>.第二部分是<软件测试需求分析和测试设计>,三天的培训非常紧张,包括老师讲解,案例演练,专题研讨,过程衔接非常紧密,课堂气氛也比较轻松,来自该银行核心系统和网银两个事业部的同事参加了此次培训,包括开发,需求,测试和维护人员等,课程结束后,举行了考试,大家对三天的学习进行回顾和总结,并准备把这两天学习到知识结

学习笔记(11月14日)--正则

五周二次课(11月14日) 11.1 常用正则表达式 11.2 re正则对象和正则匹配效率比较 11.3 编译正则对象

2016年11月14日--SQL创建数据库、表-查、插、删、改

--创建数据库create database hq20161114go --使用数据库use hq20161114go --创建学生表create table xuesheng(code int,name varchar(10),sex char(10),chengji decimal(18,2)) --添加学生信息insert into xuesheng values(1001,'一','男',11)insert into xuesheng values(1002,'二','男',22)ins

2016年11月14日23:56:58

那段盛夏的记忆始终留在脑海,体校的美好时光在记忆里褶褶生辉,如今每次看卫星地图,第一眼找的就是体校,家,在卫星地图上走一遍,走一遍那曾经我挥洒了热血和汗水的路,找寻那熟悉的感觉. 以上来自一个很怀旧的蒟蒻的一段感想. 今日在机房嗯学♂了一天,嗯,一天,其实有很长时间在逛书市哈哈.雾,今天发现有好多没练,明天把线段树区间查询区间修改和rmq学了,在练下kmp和区间动归,还有二分图最大匹配的那一堆定理看下,还有今天wzq呸昨天给的题,今天看了老窦的视频发现好烦,所以明天先练缩点求环,加上今晚剩余的一

11月14日笔记

namespace(命名空间),用于解决类重名问题,可以看做“类的文件夹”. 如果代码和被使用的类在一个namespace则不需要using. 在不同命名空间下的类调用有两种方法: –写全称  命名空间.类名 –先using引用命名空间,再调用 using可以声明namespace的引入,还可以实现非托管资源的释放,实现了IDisposiable的类在using中创建,using结束后会自动调用该对象的Dispose方法,释放资源. string可以看做是char的只读数组. string st

11月14日 互联网技术-揭秘Java网络爬虫程序原理

%E6%9C%89100%E4%B8%AA%E4%BA%BA%E5%9B%B4%E6%88%90%E4%B8%80%E4%B8%AA%E5%9C%88%E4%BB%8E1%E5%BC%80%E5%A7%8B%E6%8A%A5%E6%95%B0%E6%8A%A5%E5%88%B014%E7%9A%84%E8%BF%99%E4%B8%AA%E4%BA%BA%E5%B0%B1%E8%A6%81 http://auto.315che.com/huiteng/qa24220868.htm http://a

2018年11月14日 Forcing XXE Reflection through Server Error Messages

https://blog.netspi.com/ XML External Entity (XXE) injection attacks are a simple way to extract files from a remote server via web requests. For easy use of XXE, the server response must include a reflection point that displays the injected entity (

2014年ENVI/IDL遥感应用与开发培训班-11月重庆站 开始报名了

主办单位: 中国遥感应用协会 Esri中国信息技术有限公司 内容简介: 根据中国遥感应用协会栾恩杰理事长推动国内遥感技术和应用的指示精神,2014年中国遥感应用协会组织培训交流部与Esri中国信息技术有限公司将共同在多个城市举办以"传递遥感技术,点燃遥感应用"为主题培训班.拟打造企业型培训基地,不断推进中国遥感产业化进程. 在2011中国遥感应用协会四届三次常务理事会上,协会领导对Esri中国信息技术有限公司在遥感技术和应用推广方面所做的工作予以了充分肯定:2012年协会年会上将&qu

11月第4周业务风控关注|国家网信办约谈客户端自媒体平台 主体责任不容缺失

易盾业务风控周报每周呈报值得关注的安全技术和事件,包括但不限于内容安全.移动安全.业务安全和网络安全,帮助企业提高警惕,规避这些似小实大.影响业务健康发展的安全风险. 1.国家网信办约谈客户端自媒体平台 主体责任不容缺失 继上周国家网信办约谈腾讯微信.新浪微博之后,14日下午国家网信办又集体约谈百度.腾讯.新浪.今日头条等10家客户端自媒体平台,就各平台存在的自媒体乱象,责成平台企业切实履行主体责任,按照全网一个标准,全面自查自纠. 国家网信办在约谈中,要求各平台立即对平台自媒体账号进行一次"大