简单的php购物车代码


Posted in PHP onJune 05, 2020

本文介绍一个php实现的购物车代码,功能实现完整,具有一定的参考价值

这里我们为你提供个简单的php购物车代码,从增加购物产品与发生购买了,在商城开发中,这个功能是少不了的

具体分析如下:

对购物车里商品的操作大体上有以下几个:添加商品,删除商品,以及提交订单;

方法本质是:把session存入array,对array进行增加、删除、修改操作,array中的每一组记录都是一个商品的信息(个数,价格等);

解决购物车的思路是用session记录一个二维数组。一维代表每一个商品,二维包含了商品的id,商品的数量...等可以自行增加,反正都是二维了,自己愿意带多少个商品属性就加上去。

购物车的操作流程:首先,登录到网站中浏览商品;然后,购买指定的商品,进入购物车页面中,在该页面可以实现更改商品数量、删除商品、清空购物车、继续购物等;最后,生成订单,提交订单等操作。

详细请看强大的注释;

首先登入;

<body>
<h1>登入页面</h1>
<form action="dengrucl.php" method="post">
  <div>帐号:<input type="text" name="zhang"/></div>
  <div>密码:<input type="text" name="mi"/></div>
  <input type="submit" value="登入"/>
</form>

</body>

图:

简单的php购物车代码

登入处理:

<?php
session_start();
include ("db.class.php");
$db = new db();
$zhang = $_POST["zhang"];
$mi = $_POST["mi"];
$sql = "select mi from yonghu WHERE zhang = '{$zhang}'";
$arr = $db->Query($sql);
if(!empty($zhang)&&!empty($mi)&&$mi = $arr){
  $_SESSION["zhang"] = $zhang;
  header("location:zym.php");
}
else
{
  echo "登入失败";
}

?>

很简单的一个登入,没啥说的;

他登入完了以后直接进入主页面:

<body>
<h1>长腿璇购物商城</h1>
<table border="1" cellpadding="0" cellspacing="0" width="100%" >
  <tr>
    <td>代号</td>
    <td>水果名称</td>
    <td>水果价格</td>
    <td>水果产地</td>
    <td>水果库存</td>
    <td>操作</td>
  </tr>
  <?php
  session_start();
$_SESSION["zhang"] = "xiaoming";//不做登入的情况下,直接存sessiion
  include ("db.class.php");
  $db = new db();
  $sql = "select * from sgbiao";
  $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>
    <a href='zymcl.php?ids={$v[0]}'>加入购物车</a>
    
</td>
  </tr>";
  }

  ?>
  <?php
  //这里显示的是 购物车有多少产品,和产品的总价格
  $ann=array();
  if(!empty($_SESSION["gwc"]))
  {
    $ann=$_SESSION["gwc"];

  }
  $zhonglei = count($ann);

  $aa=0;
  foreach($ann as $k)
  {

    $k[0];//水果代号
    $k[1];//水果数量
    $sql1="select jiage from sgbiao where ids='{$k[0]}'";

    $danjia=$db->Query($sql1);

    foreach($danjia as $n)
    {

      $aa=$aa + $n[0]*$k[1];
    }


  }
  echo"数量:{$zhonglei}<br/>
价格:<mark>{$aa}元";
  ?>
</table>

<a href="tijiao.php" rel="external nofollow" rel="external nofollow" >查看账户</a>
<a href="ckgwc.php" rel="external nofollow" >查看购物车</a>

</body>

来图:

简单的php购物车代码

当我点击添加到购物车:

简单的php购物车代码

上面的数量与价格变了,说明已经加到了购物车里面;

来看一下是怎么处理的(强大的注释):

<?php
session_start();
//
$ids = $_GET["ids"];
if(empty($_SESSION["gwc"]))
{
  //如果点击的购物车是空的(第一次添加)

  //如果购物车里是空的,造二维数组,
  $arr = array(
    array($ids,1)
    //一维数组,取ids,第一次点击增加一个
  );
  $_SESSION["gwc"]=$arr;
  //扔到session里面
}
else
  //这里不是第一次点击
{
  //先判断购物车里是否已经有了该商品,用$ids
  $arr = $_SESSION["gwc"];
  //把购物车的状态取出来

  $chuxian = false;
//定义一个变量;用来表示是否出现,默认是未出现
  foreach ($arr as $v) {
    //便利他
    //如果这里面有这件商品
    if ($v[0] == $ids) //如果取过来的$v[0](商品的代号)等于$ids那么就证明购物车中已经有了这一件商品
    {
      $chuxian = true;
      //如果出现,直接把chuxian改成true

    }
  }
  if($chuxian)
  {
    //购物车中有此商品
    for($i=0;$i<count($arr);$i++)
    {
      if($arr[$i][0] == $ids)
      {
        //把点到的商品编号加1
        $arr[$i][1] += 1;
      }
    }
    $_SESSION["gwc"] = $arr;

  }
    else
      {
        //这里就只剩下:购物车里有东西,但是并没有这件商品
        $asg = array($ids,1);
        //设一个小数组
        $arr[] = $asg;
        $_SESSION["gwc"]=$arr;
      }

}
header("location:zym.php")


?>

接下来做一下购物车的页面:

<body>
<h1>查看购物车</h1>
<table width="100%" border="1"cellspacing="0" cellpadding="0">
  <tr>
    <td>商品名称</td>
    <td>商品单价</td>
    <td>商品数量</td>
    <td>操作</td>
  </tr>

  <?php
  session_start();
  if(!empty($_SESSION["gwc"]))
  {
    $arr = array();
    $arr = $_SESSION["gwc"];
    //造数组
  }
  include ('db.class.php');
  $db = new db();
  foreach ($arr as $v)
  {
    global $db;
    $sql = "select * from sgbiao WHERE ids = '{$v[0]}'";
    $att = $db->query($sql);
    foreach ($att as $a)
    {
      echo "<tr>
    <td>{$a[1]}</td>
    <td>{$a[2]}</td>
    <td>{$v[1]}</td>
    <td><a href='shanchu.php?ids={$a[0]}'>删除</a> </td>
  </tr> ";
//      蔬果的名称
//      单价
//      取int数量
//    这个地方也可以加索引shanchu.php?sy={$v}
    }
  }
  ?>

</table>

<a href="tijiao.php" rel="external nofollow" rel="external nofollow" >提交订单</a>
</body>

上图:

简单的php购物车代码

可以看到大苹果的数量是4,若是我点删除,其条件便是存在大苹果,且数量大于一,点击删除使数量减一:

白葡萄的数量是1,若我点击删除,其条件是数量不大于一,使其移除数组;

说了这些快来看看删除页面吧:

<?php
session_start();
$ids = $_GET["ids"];
$arr = $_SESSION["gwc"];
//var_dump($arr);
//取索引2(数量)
foreach ($arr as $key=>$v)
{
  if($v[0]==$ids)
  {
    if($v[1]>1){
      //要删除的数据
      $arr[$key][1]-=1;
    }
    else{
      //数量为1的情况下,移除该数组
      unset($arr[$key]);
    }
  }

}

$_SESSION["gwc"] = $arr;
//记得扔到session里面
header("location:ckgwc.php");
//删除完跳转回去

高能!!

提交订单页面,我只来一个处理页面吧,小伙伴若有需要自己填链接即可:

<?php
session_start();
include ("db.class.php");
$db = new db();

//判断用余额是否满足
$zhang = $_SESSION["zhang"];
//获取到用户名
$sye = "select zhanghu from yonghu WHERE zhang = '{$zhang}'";
$ye = $db->query($sye);
$ye[0][0];//这是余额

$ann=array();
if(!empty($_SESSION["gwc"]))
{
  $ann=$_SESSION["gwc"];

}
$zhonglei = count($ann);

$aa=0;//总价格
foreach($ann as $k)
{

  $k[0];//水果代号
  $k[1];//水果数量
  $sql1="select jiage from sgbiao where ids='{$k[0]}'";

  $danjia=$db->Query($sql1);

  foreach($danjia as $n)
  {

    $aa=$aa + $n[0]*$k[1];
  }


}
//判断余额是否满足
if($ye[0][0]>=$aa)
{
  //钱够,判断库存

  foreach($ann as $v)
  {
    $skc = "select sgname,kucun from sgbiao WHERE ids='{$v[0]}'";
    //水果代号$v[0]
    $akc = $db->query($skc);
    $akc[0][1];//库存
    //比较是否满足库存
    if($akc[0][1]<$v[1])
    {
      echo "{$akc[0][0]}库存不足";
      //退出
      exit;
    }

  }
//提交订单:
//i.  从用户账户中扣除本次购买的总价格
//ii.  从商品库存中扣除本次每种商品的购买数量
//iii.  向订单表和订单内容表中加入本次购买的商品信息
  //扣除账户余额
$skcye = "update yonghu set zhanghu = zhanghu-{$aa} WHERE zhang = '{$zhang}'";
  $db->query($skcye,0);
  //扣除库存
  foreach($ann as $v)
  {
    $skckc = "update sgbiao set kucun = kucun-{$v[1]} WHERE ids='{$v[0]}'";
    //水果代号$v[0]
    $db->query($skckc,0);
  }
  //添加订单信息
  //取当前时间
  $time = time();
  //自动生成订单号
  $ddh = date("YmdHis");
  $sdd = "insert into dingdan VALUES ('{$ddh}','$zhang','$time')";
  $db->query($sdd,0);
  //添加订单内容
  foreach ($ann as $v)
  {
    $sddxq = "insert into ddneirong VALUES ('','$ddh','{$v[0]}','{$v[1]}')";
    $db->query($sddxq,0);
  }


}
else
{
  echo "钱不够";
  exit;
}

如此一来,购物车大体上的功能都已实现;

来看看点击提交订单后的效果:

1.减少水果库存:

简单的php购物车代码

2.添加订单:

简单的php购物车代码

3.添加订单内容:

简单的php购物车代码

4.扣除购买人的账户余额:

简单的php购物车代码

以上便是购物车内容

以上就是简单的php购物车代码的详细内容,更多关于PHP购物车的资料请关注三水点靠木其它相关文章!

PHP 相关文章推荐
Ajax+PHP 边学边练 之二 实例
Nov 24 PHP
mysql总结之explain
Feb 27 PHP
php多文件上传下载示例分享
Feb 20 PHP
ThinkPHP、ZF2、Yaf、Laravel框架路由大比拼
Mar 25 PHP
PHP rsa加密解密使用方法
Apr 27 PHP
php封装的smartyBC类完整实例
Oct 19 PHP
php获取flash尺寸详细数据的方法
Nov 12 PHP
thinkphp3.2实现跨控制器调用其他模块的方法
Mar 14 PHP
JS+PHP实现用户输入数字后显示最大的值及所在位置
Jun 19 PHP
PHP 实现人民币小写转换成大写的方法及大小写转换函数
Nov 17 PHP
PHP中有关长整数的一些操作教程
Sep 11 PHP
PHP中通过getopt解析GNU C风格命令行选项
Nov 18 PHP
实例化php类时传参的方法分析
Jun 05 #PHP
PHP页面静态化――纯静态与伪静态用法详解
Jun 05 #PHP
PHP预定义接口――Iterator用法示例
Jun 05 #PHP
PHP中abstract(抽象)、final(最终)和static(静态)原理与用法详解
Jun 05 #PHP
PHP标准库 (SPL)――Countable用法示例
Jun 05 #PHP
PHP类的自动加载与命名空间用法实例分析
Jun 05 #PHP
如何在PHP中生成随机数
Jun 04 #PHP
You might like
php操作MongoDB基础教程(连接、新增、修改、删除、查询)
2014/03/25 PHP
PHP is_subclass_of函数的一个BUG和解决方法
2014/06/01 PHP
Windows7下的php环境配置教程
2015/02/28 PHP
JQUERY复选框CHECKBOX全选,取消全选
2008/08/30 Javascript
E3 tree 1.6在Firefox下显示问题的修复方法
2013/01/30 Javascript
JS定时器实例
2013/04/17 Javascript
jquery scrollTop方法根据滚动像素显示隐藏顶部导航条
2013/05/27 Javascript
javascript获得网页窗口实际大小的示例代码
2013/09/21 Javascript
javascript 获取浏览器版本
2015/01/21 Javascript
chrome不支持form.submit的解决方案
2015/04/28 Javascript
jQuery多条件筛选如何实现
2015/11/04 Javascript
JavaScript获取IP获取的是IPV6 如何校验
2016/06/12 Javascript
JS实现移动端整屏滑动的实例代码
2017/11/10 Javascript
微信小程序ajax实现请求服务器数据及模版遍历数据功能示例
2017/12/15 Javascript
vue中如何动态绑定图片,vue中通过data返回图片路径的方法
2018/02/07 Javascript
如何解决vue2.0下IE浏览器白屏问题
2018/09/13 Javascript
详解Axios统一错误处理与后置
2018/09/26 Javascript
微信小程序动态添加view组件的实例代码
2019/05/23 Javascript
解决layer.confirm快速点击会重复触发事件的问题
2019/09/23 Javascript
浅谈python中的__init__、__new__和__call__方法
2017/07/18 Python
Python 基础教程之str和repr的详解
2017/08/20 Python
在Sublime Editor中配置Python环境的详细教程
2020/05/03 Python
OpenCV Python实现图像指定区域裁剪
2021/03/12 Python
利用CSS3实现文本框的清除按钮相关的一些效果
2015/06/23 HTML / CSS
简述Html5 IphoneX 适配方法
2018/02/08 HTML / CSS
adidas官方旗舰店:德国运动用品制造商
2017/11/25 全球购物
BISSELL官网:北美吸尘器第一品牌
2019/03/14 全球购物
意大利单身交友网站:Meetic
2020/07/12 全球购物
写自荐信三大法宝
2014/01/24 职场文书
一夜的工作教学反思
2014/02/08 职场文书
超市商业计划书
2014/05/04 职场文书
签约仪式策划方案
2014/06/02 职场文书
幼儿园教师师德师风演讲稿:爱我所爱 无悔青春
2014/09/10 职场文书
2015年初中教师个人工作总结
2015/07/21 职场文书
SQL Server中使用判断语句(IF ELSE/CASE WHEN )案例
2021/07/07 SQL Server
SQL Server 忘记密码以及重新添加新账号
2022/04/26 SQL Server