php实现商城购物车的思路和源码分析


Posted in PHP onJuly 23, 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 相关文章推荐
WindowsXP中快速配置Apache+PHP5+Mysql
Jun 05 PHP
让PHP以ROOT权限执行系统命令的方法
Feb 10 PHP
php通过COM类调用组件的实现代码
Jan 11 PHP
shell脚本作为保证PHP脚本不挂掉的守护进程实例分享
Jul 15 PHP
php Session存储到Redis的方法
Nov 04 PHP
thinkphp实现多语言功能(语言包)
Mar 04 PHP
php将图片保存为不同尺寸图片的图片类实例
Mar 30 PHP
Yii中CArrayDataProvider和CActiveDataProvider区别实例分析
Mar 02 PHP
PHP的Yii框架中Model模型的学习教程
Mar 29 PHP
php连接oracle数据库的方法(测试成功)
May 26 PHP
PHP Callable强制指定回调类型的方法
Aug 30 PHP
php5.6.x到php7.0.x特性小结
Aug 17 PHP
PHP安全之register_globals的on和off的区别
Jul 23 #PHP
PHP代码覆盖率统计详解
Jul 22 #PHP
php实现统计IP数及在线人数的示例代码
Jul 22 #PHP
Yii使用DbTarget实现日志功能的示例代码
Jul 21 #PHP
浅谈PHP之ThinkPHP框架使用详解
Jul 21 #PHP
浅谈php常用的7大框架的优缺点
Jul 20 #PHP
KindEditor在php环境下上传图片功能集成的方法示例
Jul 20 #PHP
You might like
PHP输出控制功能在简繁体转换中的应用
2006/10/09 PHP
163的邮件用phpmailer发送(实例详解)
2013/06/24 PHP
PHP实现链式操作的核心思想
2015/06/23 PHP
PHP读取大文件的几种方法介绍
2016/10/27 PHP
详解PHP安装mysql.so扩展的方法
2016/12/31 PHP
PHP预定义接口――Iterator用法示例
2020/06/05 PHP
extjs 为某个事件设置拦截器
2010/01/15 Javascript
Exjs 入门篇
2010/04/07 Javascript
jquery实现商品拖动选择效果代码(自写)
2013/05/28 Javascript
JS JSON对象转为字符串的简单实现方法
2013/11/18 Javascript
JQUERY dialog的用法详细解析
2013/12/19 Javascript
js动态改变select选择变更option的index值示例
2014/07/10 Javascript
node.js中的http.createServer方法使用说明
2014/12/14 Javascript
Javascript中引用类型传递的知识点小结
2017/03/06 Javascript
彻底理解js面向对象之继承
2018/02/04 Javascript
vuejs实现标签选项卡动态更改css样式的方法
2018/05/31 Javascript
vue.js的vue-cli脚手架中使用百度地图API的实例
2019/01/21 Javascript
vue中利用Promise封装jsonp并调取数据
2019/06/18 Javascript
vue学习之Vue-Router用法实例分析
2020/01/06 Javascript
element中table高度自适应的实现
2020/10/21 Javascript
python实现apahce网站日志分析示例
2014/04/02 Python
Python实现给文件添加内容及得到文件信息的方法
2015/05/28 Python
python 3.6 +pyMysql 操作mysql数据库(实例讲解)
2017/12/20 Python
用Python做一个久坐提醒小助手的示例代码
2020/02/10 Python
Scrapy框架介绍之Puppeteer渲染的使用
2020/06/19 Python
Django利用elasticsearch(搜索引擎)实现搜索功能
2020/11/26 Python
html5是什么_动力节点Java学院整理
2017/07/07 HTML / CSS
捷克浴室和厨房设备购物网站:SIKO
2018/08/11 全球购物
《水上飞机》教学反思
2014/04/10 职场文书
行政部经理助理岗位职责
2014/06/15 职场文书
财会专业大学生求职信
2014/09/26 职场文书
2014年财政工作总结
2014/12/10 职场文书
2015年毕业生自荐信范文
2015/03/24 职场文书
医疗纠纷调解协议书
2015/08/06 职场文书
反邪教教育心得体会
2016/01/15 职场文书
Ruby处理CSV数据方法详解
2022/04/18 Ruby