时间: 2020-09-9|19次围观|0 条评论

实现一个简单的购物网站

一、考试时间: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>

 

效果如图:

php实现一个简单的购物网站插图

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

<?phpsession_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

php实现一个简单的购物网站插图1

现在做主页的页面: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><?phpsession_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 总价格,默认总价格为0foreach($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

<?phpsession_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");    

登录效果如图:

php实现一个简单的购物网站插图2

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

首先购买3中商品:

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>

效果如图所示:

php实现一个简单的购物网站插图4

然后做提交页面 :tijiao.php

 

<?phpsession_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");

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

php实现一个简单的购物网站插图5

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

 

文章转载于:https://www.cnblogs.com/shenzikun1314/p/6529624.html

原著是一个有趣的人,若有侵权,请通知删除

本博客所有文章如无特别注明均为原创。
复制或转载请以超链接形式注明转自起风了,原文地址《php实现一个简单的购物网站
   

还没有人抢沙发呢~