php mysql购物车实现原理_PHP实现购物车的思路和源码分析

这篇博客详细介绍了使用PHP实现购物车功能的思路和步骤,包括数据库设计、SESSION原理的应用以及添加、删除商品的处理。通过示例代码展示了如何存储和操作购物车数据,并提供了相关源码供参考学习。
摘要由CSDN通过智能技术生成

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

项目中需要添加购物车。

目录说明

buy.php 点击购买之后的操作

car.php 购物车,显示购买的东西

conn.php 数据库连接参数

delete.php 删除商品

index.php 入口文件

shop.sql 数据库sql文件

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

include ("conn.php");//引入数据配置

$sql="select * from produce";//查询所有商品

$rs=mysql_query($sql,$conn);//执行sql语句,得到一个结果集

while($row=mysql_fetch_array($rs))//遍历结果集

{

?>

<?php%20echo%20%24row%5B'pimg'%5D?>货物名称:<?php echo $row["name"]?>
货物价格:<?php echo $row["price"]?>
&pname=<?php echo $row["name"]?>">购买

}

?>

buy.php

session_start();//使用session之前一定要将session开启

ob_start();//要清空缓存就必须ob_start()

$pid=$_GET["id"];//得到购买物品的id

$name=$_GET["pname"];//得到购买物品的名字

$arr=$_SESSION["mycar"];//将session中的变量取出来

//下面先判断这个变量是否是数组,可以得到以前是否买过东西

if(is_array($arr))

{

//如果是数组,说明以前买过东西

//如果买过东西又分两种情况:

if(array_key_exists($pid,$arr))

{

//1、array_key_exists($pid,$arr)判断$arr中是否存在键值为$pid的一个一维数组,如果存在的话,就说明此商品以前购买过,只需要把数量加1

$uu=$arr[$pid]; //从二维数组里拿出对应的一维数组,该一维数组包括id name num 三个值

$uu["num"]=$uu["num"]+1; //改变数量,将数量加1

$arr[$pid]=$uu; //改完后再将此一维数组放回二维数组中

}

else

{ //2.此商品第一次购买,就将得到的id和name值组成一个一维数组

$arr[$pid]=array("pid"=>$pid,"name"=>$name,"num"=>1);

}

}

else

{

//还没有买过东西

$arr[$pid]=array("pid"=>$pid,"name"=>$name,"num"=>1);

}

$_SESSION["mycar"]=$arr;//购买完后,将此数组重新放入session中,便可以在各个页面看到此session

ob_clean();//清空缓存

header("location:car.php");//跳转到购物车界面(car.php)

//var_dump($_SESSION);

?>

car.php

session_start();//启用session

$arr=$_SESSION["mycar"];//从session中拿出二维数组

?>

将数组里的数据即客户所购买的物品展示出来

商品ID商品名称商品数量删除

foreach($arr as $a)//遍历这个二维数组

{

?>

<?php echo $a["pid"]?>//物品的id<?php echo $a["name"]?>//物品的名称<?php echo $a["num"]?>//物品的数量 删除//点击删除超链接到”delete.php”,将物品的id传过去

}

?>

返回继续购物

conn.php

$conn=mysql_connect("localhost","root","root");//连接数据库服务器

mysql_select_db("shop",$conn);//选择数据库

mysql_query("set names utf8");//设置连接数据库编码

?>

delete.php

session_start();//启动session

ob_start();//清空缓存必须启动的项

$pid=$_GET["id"];//得到通过get方式传过来的id

$arr=$_SESSION["mycar"];//拿出session里的二维数组

foreach($arr as$key=>$proId)//遍历该二维数组中的键值,这里也就是商品的id

{

if($key==$pid)//判断键值等于传过来的商品id

{

unset($arr[$key]);//清除该一维数组

}

}

$_SESSION["mycar"]=$arr;//将清除之后的二维数组重新放到session里

ob_clean();//清除缓存

header("location:car.php");//跳转到购物车

?>

shop.sql

/*

Navicat MySQL Data Transfer

Source Server : 127.0.0.1

Source Server Version : 50536

Source Host : localhost:3306

Source Database : shop

Target Server Type : MYSQL

Target Server Version : 50536

File Encoding : 65001

Date: 2016-04-25 09:35:18

*/

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------

-- Table structure for `produce`

-- ----------------------------

DROP TABLE IF EXISTS `produce`;

CREATE TABLE `produce` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`name` varchar(50) DEFAULT NULL,

`pimg` varchar(200) DEFAULT NULL,

`price` int(11) DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;

-- ----------------------------

-- Records of produce

-- ----------------------------

INSERT INTO `produce` VALUES ('1', '测试', 'test.png', '1');

INSERT INTO `produce` VALUES ('2', '测试2', 'test.png', '2');

INSERT INTO `produce` VALUES ('3', '测试3', 'test.png', '1');

INSERT INTO `produce` VALUES ('4', '测试4', 'test.png', '2');

INSERT INTO `produce` VALUES ('5', '测试5', 'test.png', '9');

以上内容希望帮助到大家,很多PHPer在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值