PHP实现购物车的思路和源码分析

举报
lxw1844912514 发表于 2022/03/27 01:44:25 2022/03/27
【摘要】 正文内容 这里主要是记录下自己的购物车的思路,具体功能实现,但是尚未在实际项目中用到,不对之处欢迎指正 项目中需要添加购物车。 目录说明 buy.php 点击购买之后的操作car.php 购物车,显示购买的东西conn.php 数据库连接参数delete.php 删除商品index...

正文内容

这里主要是记录下自己的购物车的思路,具体功能实现,但是尚未在实际项目中用到,不对之处欢迎指正

项目中需要添加购物车。

目录说明

  

    
  1. buy.php 点击购买之后的操作
  2. car.php 购物车,显示购买的东西
  3. conn.php 数据库连接参数
  4. delete.php 删除商品
  5. index.php 入口文件
  6. shop.sql 数据库sql文件
  7. test.png 商品图片

首先需要理解的是,购物车操作是SESSION的原理

一个物品加进去是一个数组,存ID NAME NUM

那么两个物品就是二维数组,所以用二维数组来操作就可以了。

1.创建数据库shop,导入shop.sql。这是我们的产品

2.修改conn中的链接数据库密码

3.仔细阅读源码

3.1 点击购买之后转到buy.php中

3.2.0 判断购物车的SESSION是否是数组,是则购物车有物品[产品ID是数组的KEY]

3.2.1 判断传递的ID在购物车的SESSION是否存在,不存在就添加进去,数量默认为1[产品ID是数组的KEY]

3.2.2 判断传递的ID在购物车的SESSION是否存在,存在就把数量+1[产品ID是数组的KEY]

3.2.3 判断购物车的SESSION是否是数组,不是则直接存入SESSION[产品ID是数组的KEY]

3.3 添加完成后转到car.php,循环展示出购买的东西

3.4 点击不想购买的商品,删除delete.php,删除对应SESSION下key对应的ID值即可

index.php


    
  1. <?php
  2. include ("conn.php");//引入数据配置
  3. $sql="select * from produce";//查询所有商品
  4. $rs=mysql_query($sql,$conn);//执行sql语句,得到一个结果集
  5. while($row=mysql_fetch_array($rs))//遍历结果集
  6. {
  7. ?>
  8. <table width="343" height="152" border="1" style="float:left">
  9. <tr>
  10. <td width="124" rowspan="3"><img src="<?php echo $row['pimg']?>" width="123" height="121" border="0"/></td>
  11. <td width="203" height="35">货物名称:<?php echo $row["name"]?></td>
  12. </tr>
  13. <tr>
  14. <td height="28">货物价格:<?php echo $row["price"]?></td>
  15. </tr>
  16. <tr>
  17. <td height="27"align="center"><a href="buy.php?id=<?php echo $row["id"]?>&pname=<?php echo $row["name"]?>">购买</a></td>
  18. </tr>
  19. </table>
  20. <?php
  21. }
  22. ?>

buy.php


    
  1. <?php
  2. session_start();//使用session之前一定要将session开启
  3. ob_start();//要清空缓存就必须ob_start()
  4. $pid=$_GET["id"];//得到购买物品的id
  5. $name=$_GET["pname"];//得到购买物品的名字
  6. $arr=$_SESSION["mycar"];//将session中的变量取出来
  7. //下面先判断这个变量是否是数组,可以得到以前是否买过东西
  8. if(is_array($arr))
  9. {
  10. //如果是数组,说明以前买过东西
  11. //如果买过东西又分两种情况:
  12. if(array_key_exists($pid,$arr))
  13. {
  14. //1、array_key_exists($pid,$arr)判断$arr中是否存在键值为$pid的一个一维数组,如果存在的话,就说明此商品以前购买过,只需要把数量加1
  15. $uu=$arr[$pid]; //从二维数组里拿出对应的一维数组,该一维数组包括id name num 三个值
  16. $uu["num"]=$uu["num"]+1; //改变数量,将数量加1
  17. $arr[$pid]=$uu; //改完后再将此一维数组放回二维数组中
  18. }
  19. else
  20. { //2.此商品第一次购买,就将得到的id和name值组成一个一维数组
  21. $arr[$pid]=array("pid"=>$pid,"name"=>$name,"num"=>1);
  22. }
  23. }
  24. else
  25. {
  26. //还没有买过东西
  27. $arr[$pid]=array("pid"=>$pid,"name"=>$name,"num"=>1);
  28. }
  29. $_SESSION["mycar"]=$arr;//购买完后,将此数组重新放入session中,便可以在各个页面看到此session
  30. ob_clean();//清空缓存
  31. header("location:car.php");//跳转到购物车界面(car.php)
  32. //var_dump($_SESSION);
  33. ?>

car.php


    
  1. <?php
  2. session_start();//启用session
  3. $arr=$_SESSION["mycar"];//从session中拿出二维数组
  4. ?>
  5. 将数组里的数据即客户所购买的物品展示出来
  6. <table width="600" height="37"border="1">
  7. <tr>
  8. <td width="96">商品ID</td>
  9. <td width="158">商品名称</td>
  10. <td width="154">商品数量</td>
  11. <td width="177">删除</td>
  12. </tr>
  13. <?php
  14. foreach($arr as $a)//遍历这个二维数组
  15. {
  16. ?>
  17. <tr>
  18. <td width="96"><?php echo $a["pid"]?></td>//物品的id
  19. <td width="158"><?php echo $a["name"]?></td>//物品的名称
  20. <td width="154"><?php echo $a["num"]?></td>//物品的数量
  21. <td width="177"><a href="delete.php?id=<?php echo $a['pid']?>">删除</a></td>//点击删除超链接到”delete.php”,将物品的id传过去
  22. </tr>
  23. <?php
  24. }
  25. ?>
  26. </table>
  27. <a href="index.php">返回继续购物</a>

conn.php


    
  1. <?php
  2. $conn=mysql_connect("localhost","root","root");//连接数据库服务器
  3. mysql_select_db("shop",$conn);//选择数据库
  4. mysql_query("set names utf8");//设置连接数据库编码
  5. ?>

delete.php


    
  1. <?php
  2. session_start();//启动session
  3. ob_start();//清空缓存必须启动的项
  4. $pid=$_GET["id"];//得到通过get方式传过来的id
  5. $arr=$_SESSION["mycar"];//拿出session里的二维数组
  6. foreach($arr as$key=>$proId)//遍历该二维数组中的键值,这里也就是商品的id
  7. {
  8. if($key==$pid)//判断键值等于传过来的商品id
  9. {
  10. unset($arr[$key]);//清除该一维数组
  11. }
  12. }
  13. $_SESSION["mycar"]=$arr;//将清除之后的二维数组重新放到session里
  14. ob_clean();//清除缓存
  15. header("location:car.php");//跳转到购物车
  16. ?>

shop.sql


    
  1. /*
  2. Navicat MySQL Data Transfer
  3. Source Server : 127.0.0.1
  4. Source Server Version : 50536
  5. Source Host : localhost:3306
  6. Source Database : shop
  7. Target Server Type : MYSQL
  8. Target Server Version : 50536
  9. File Encoding : 65001
  10. Date: 2016-04-25 09:35:18
  11. */
  12. SET FOREIGN_KEY_CHECKS=0;
  13. -- ----------------------------
  14. -- Table structure for `produce`
  15. -- ----------------------------
  16. DROP TABLE IF EXISTS `produce`;
  17. CREATE TABLE `produce` (
  18. `id` int(11) NOT NULL AUTO_INCREMENT,
  19. `name` varchar(50) DEFAULT NULL,
  20. `pimg` varchar(200) DEFAULT NULL,
  21. `price` int(11) DEFAULT NULL,
  22. PRIMARY KEY (`id`)
  23. ) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;
  24. -- ----------------------------
  25. -- Records of produce
  26. -- ----------------------------
  27. INSERT INTO `produce` VALUES ('1', '测试', 'test.png', '1');
  28. INSERT INTO `produce` VALUES ('2', '测试2', 'test.png', '2');
  29. INSERT INTO `produce` VALUES ('3', '测试3', 'test.png', '1');
  30. INSERT INTO `produce` VALUES ('4', '测试4', 'test.png', '2');
  31. INSERT INTO `produce` VALUES ('5', '测试5', 'test.png', '9');

 
  

test.png,这个图自己随便找一个测试。

文章来源: blog.csdn.net,作者:lxw1844912514,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/lxw1844912514/article/details/100028590

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。