zoukankan      html  css  js  c++  java
  • php实现一个简单的购物网站

    实现一个简单的购物网站

    一、考试时间:8小时

    二、开发工具:DW

    三、数据库:见附件

    四、需要实现的页面:

    Index:浏览商品页面,显示商品列表,用户可以点击“购买“。

    ViewCart:查看购物车页面,显示已购买的商品信息,可以点击“删除“已买的商品

    ViewAccount:查看个人账户余额

    Login:登录页面

    建议使用的技术:Ajax,Session,数组。

    五、实现功能:

    1、 显示商品列表

    2、 实现购买功能,购买的时候动态显示购物车中的商品数量商品总价格

    3、 点击查看购物车后,显示已购买的商品。注意“购买数量”列,如果对一种商品点击购买多次,其“购买数量”不断增加。

    4、 删除购物车中已购买的商品。
    如果某商品的“购买数量”为1时,则点击“删除”时,直接从购物车中删除该商品;
    如果商品的“购买数量”大于1时,点击一次“删除”时,把其购买数量减1。直到该商品购买数量为1时,再点击删除时,删除该商品

    5、 在查看完购物车后还可以点击“浏览商品”继续购买。并在上面显示已购买的商品数量和总价格。

    6、 “查看购物车“后,可以提交订单

    但在提交订单时,须完成以下功能:

    a) 检查用户是否已登录,未登录则转到Login页面

    b) 检查用户账户余额是否能够满足本次够买

    c) 检查库存数量是否满足本次够买

    d) 如果以上条件都满足则

    1. 从用户账户中扣除本次购买的总价格
    2. 从商品库存中扣除本次每种商品的购买数量
    3. 向订单表和订单内容表中加入本次购买的商品信息

    7、 点击查看账户,可以查看该用户的账户余额。

    开始做,首先先做一个登录页面: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" />
    <title>无标题文档</title>
    </head>
    
    <body>
    <h1>登录页面</h1>
    <div>
    <form action="logincl.php" method="post">
    账号:
    <input type="text" name="uid" />
    </div>
    <div>
    密码:
    <input type="password" name="pwd" />
    </div>
    <input type="submit" value="登录" />
    </form>
    </body>
    </html>

    效果如图:

    在做一个登录的处理页面:logincl.php

    <?php
    session_start();
    include("../fengzhuang/DBDA.class.php");
    $db = new DBDA();
    
    $uid =$_POST["uid"];
    $pwd = $_POST["pwd"];
    
    $sql = "select password from login where username = '{$uid}'";
    $arr = $db->Query($sql);
    
    if($arr[0][0]==$pwd && !empty($pwd))
    {
        $_SESSION["uid"] =$uid;
        header("location:main.php");
    }
    else
    {
        echo"登录失败";
    }

    这样就可以和数据库联系了,这个是数据库的登录帐号和密码,验证帐号,密码,然后跳到主页:main.php

    现在做主页的页面:main.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" />
    <title>无标题文档</title>
    </head>
    
    <body>
    <h1>大苹果购物网</h1>
    
    <?php
    session_start();
    include("../fengzhuang/DBDA.class.php");
    $db = new DBDA();
    date_default_timezone_set("PRC");
    
    //1.找出购物车中多少种商品和总价
    $uid = $_SESSION["uid"];
    $attr = array();
    //如果购物车有商品,取出值
    if(!empty($_SESSION["gwc"]))
    {
        $attr = $_SESSION["gwc"];
    }
    
    $gs = count($attr);//$gs 商品数量
    $sum = 0;//$sum 总价格,默认总价格为0
    foreach($attr as $v)
    {
        $v[0];//水果代号
        $v[1]; //水果数量
        $sql = "select price from fruit where ids ='{$v[0]}'";//查询单价
        
        $ajg = $db->Query($sql);
        $dj = $ajg[0][0];//单价
        
        $sum += $dj * $v[1];//总价=单价*数量
    }
    echo"<div>购物车中有:{$gs}种商品,商品总价为:{$sum}元</div>";
    ?>
    
    
    
    <table width="100%" border="1" cellpadding="0" cellspacing="0">
        <tr>
            <td>代号</td>
            <td>水果名称</td>
            <td>水果价格</td>
            <td>原产地</td>
            <td>货架</td>
            <td>库存量</td>
            <td>&nbsp;&nbsp;</td>
        </tr>
        <?php
        
        //2.从数据库中找出数据
        
        $sql = "select * from fruit";
        $arr = $db->Query($sql);
        
        foreach($arr 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>$v[5]</td>
            <td><a href='add.php?ids={$v[0]}'>购买</a></td>
            </tr>
            
            
            ";
            
        }
        
        
        
          
        ?>
    
    
    </table>
    <a href="gouwuche.php?ids={$v[0]}">查看购物车</a>
    
    
    </body>
    </html>

    然后做主页的处理页面:add.php

    <?php
    session_start();
    //找出点击"购买"的ids
    $ids = $_GET["ids"];
    
    
    //1.第一次点击添加购物车
    //2.如果购物车中没有该商品
    //3.如果购物车中有该商品
    
    //第一步,判断购物车为空,则第一次点击把商品添加到购物车
    if(empty($_SESSION["gwc"]))
    {
        $arr = array(array($ids,1));
        $_SESSION["gwc"] = $arr;
    }
    //如果不为空,则有2种判断,1:该商品为空,则需添加进去,2:该商品有,则需数量上+1;
    else
    {
        //不是第一次点击
        //判断购物车中是否存在该商品
        $arr = $_SESSION["gwc"];
        
        $chuxian = false;
        foreach($arr as $v)
        {
            if($v[0]==$ids)
            {
                $chuxian =true;
            }
        }
        
        if($chuxian)
        {
            //如果购物车中有该商品
            for($i=0;$i<count($arr);$i++)
            {
                $arr[$i][1]+=1;
            }
        
        
            $_SESSION["gwc"] =$arr;
        }
    
        else
            {
            //如果购物车中没有该商品
            $asg = array($ids,1);
            $arr[] =$asg;
            $_SESSION["gwc"] = $arr;
            }
    }
    
    header("location:main.php");    

    登录效果如图:

    然后再做查看购物车页面,能看到购物车中的商品和单价和总价:gouwuche.php

    首先购买3中商品:

    然后代码:

    <!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>
    </head>
    
    <body>
    
    <h1>大苹果购物网</h1>
    
    <h2>购物车中有以下商品:</h2>
    
    <table width="100%" border="1" cellpadding="0" cellspacing="0">
        <tr>
            <td>商品名称</td>
            <td>商品单价</td>
            <td>购买数量</td>
            <td>&nbsp;&nbsp;</td>
        </tr>
        
    <?php
            session_start();
            
            include("../fengzhuang/DBDA.class.php");
            $db = new DBDA();
            
            $uid = $_SESSION["uid"];
            $arr = array();
            if(!empty($_SESSION["gwc"]))
            {
                $arr = $_SESSION["gwc"];
            }
            
            foreach($arr as $k=>$v)
            {
                $sql = "select * from fruit where ids ='{$v[0]}' ";
                $attr =$db->Query($sql);
                
                echo"<tr>
                        <td>{$attr[0][1]}</td>
                        <td>{$attr[0][2]}</td>
                        <td>{$v[1]}</td>
                        <td><a href='shanchu.php?sy={$k}'>删除</a></td>
                    </tr>
                ";
            }
    ?>    
    </table>
    <div>
    <a href="tijiao.php?ids='{$v[0]}'">提交订单</a>
    </div>
    
    
    </body>
    </html>

    效果如图所示:

    然后做提交页面 :tijiao.php

    <?php
    
    
    session_start();
    include("../fengzhuang/DBDA.class.php");
    $db = new DBDA();
     date_default_timezone_set('PRC') ;
    $uid=$_SESSION["uid"];
    $sye="select account from login where username ='{$uid}' ";
    $aye=$db->Query($sye);
    $aye[0][0];//余额
    
    $attr =array();
    if(!empty($_SESSION["gwc"]))
    {
        $attr =$_SESSION["gwc"];
    }
    
    $sum = 0;//总价
    foreach($attr as $v)
    {
        $v[0];//水果代号
        $v[1];//数量
        $sql = "select price from fruit where ids='{$v[0]}'";
        $ajg = $db->Query($sql);
        $dj = $ajg[0][0];//单价
        $sum +=$dj*$v[1];
        
    }
    
    
    //判断余额是否满足购买
    if($aye[0][0]>=$sum)
    {
        //余额满足,判断库存
        foreach($attr as $v)
        {
            $skc = "select name,number from fruit where ids='{$v[0]}'";
            $akc = $db->Query($skc);
            $akc[0][1];//库存
            
            //判库存是否满足
            if($akc[0][1]<$v[1])
            {
                echo"{$akc[0][0]}库存不足";
                exit;
            }
        
            
        }
        
        //提交订单
        //账户扣除余额
        $skcye = "update login set account=account-{$sum} where username ='{$uid}'";
        $db->Query($skcye,0);
        
        
        //扣除库存
        foreach($attr as $v)
        {
            $skckc = "update fruit set number = number-{$v[1]} where ids ='{$v[0]}'";
            $db->Query($skckc,0);
        }
        
        //添加订单
        $ddh = date("YmdHis");
        $time = time();
        $sdd = "insert into orders values('{$ddh}','{$uid}','{$time}')";
        $db->Query($sdd,0);
        
        //添加订单详情
        foreach($attr as $v)
        {
            $sddxq ="insert into orderdetails values('','{$ddh}','{$v[0]}','$v[1]')";
            $db->Query($sddxq,0);
            
        }
    }
    else
    {
        echo"余额不足";
        exit;
    }
    header("location:main.php");

    然后看看数据库有没有改变:

    李四的账户余额已经减少了

  • 相关阅读:
    安装cloudbase-init和qga批处理
    Windows添加自定义服务、批处理文件开机自启动方法
    Windows批处理:自动部署常用软件(静默安装)
    windows auto activate
    XML转译字符
    Leetcode908.Smallest Range I最小差值1
    Leetcode917.Reverse Only Letters仅仅反转字母
    Leetcode896.Monotonic Array单调数列
    Leetcode905.Sort Array By Parity按奇偶排序数组
    Leetcode892.Surface Area of 3D Shapes三维形体的表面积
  • 原文地址:https://www.cnblogs.com/shenzikun1314/p/6529624.html
Copyright © 2011-2022 走看看