<?php
session_start();
include_once("DB.class.php"); //接受并解析前端传过来的json,转换成数组。
$goods_list =$_POST['order'];
$goods_list= json_decode($goods_list, true); //1.获取session信息
$arr = $_SESSION['gwc'];
//获得订单数组
$item_list = $goods_list['order']; //一维实现,每次先清空订单。
$order = ''; //把商品信息存到订单,并且把他们从购物车中删除
foreach($item_list as $k=> $item){ //把商品信息存到订单
$order[$k] = $arr[$k]; //把商品信息从购物车中删除
unset($arr[$k]); } //更新购车的商品信息
if(!empty($arr)){
$_SESSION['gwc'] = $arr;
}else{
$_SESSION['gwc'] = '';
} //最后将订单信息存到session
$_SESSION['order'] = $order; // var_dump($_SESSION);
// die();
echo "OK";
exit; ?>

注:例子中是使用的工具类代码DB.class.php要在https://www.cnblogs.com/mzzone/p/10911891.html

业务逻辑

  • 从购物车中点击结算,即是把商品信息从购物车中转移到订单中。
  • 技术点:接受的方式是json。要先在前台以json的形式传过来,这里再把它解析为数组,再运用。

购物车页面的结算按钮注册点击事件(需要引入jquery文件)

$('#jiesuan').click( function(){
//间接设置订单金额
var j = $('.total_text').text();
// 去除¥符号
var order_toal = j.substring(1);
//将标签的值赋给input传过去
$("#order_total").val(order_toal);
//用插件将表单生成json,在ajax发送过去后台
var serializeObj=$('#form1').serializeJSON();
var serializeStr=JSON.stringify(serializeObj);
console.log
(serializeStr);
$.ajax({
cache: false,
type: "POST",
url : "add_to_order.php",
traditional:true,
data: {order : serializeStr}, //注意这里的写法,键为order
success: function(msg){
if(msg=="OK"){
        
alert("下单成功");
// location.reload();
//window.location.href='order.php';
}else{
alert(msg);
alert("下单失败");
}
}
});

表单中的一部分代码,展示如何把选中的商品传过去。关键在于checbox键值设置:在foreache循环中,所以键值得有变量混合进去。

<!-- 1.遍历店铺,查看有多少商品并遍历。-->
<div class="shop_info">
<div class="all_check">
<!--店铺全选-->
<input type='checkbox' id='shop_a' class='shopChoice'> <label for='shop_a' class='shop'></label> </div>
<div class="shop_name">
店铺:<a href="javascript:;">蜜食专家</a>
</div>
</div> <?php
session_start();
include_once("DB.class.php"); if(isset($_SESSION['gwc'])&&!empty($_SESSION['gwc'])){
$arr2 = $_SESSION['gwc'];
foreach($arr2 as $k1=> $arr){ $goods_id = $arr['goods_id'];
$sql="select * from tb_goods where id=$goods_id";
$goods = $dao->getRow($sql); $goods_num = $arr['num']; $sum = $goods['price']*$goods_num; ?>
<div class="order_content">
<!-- 最低应该在这里开始遍历,有分割线 --> <!-- 利用上面的php变量,遍历一个商品或sku -->
<ul class="order_lists"> <li class="list_chk">
<!-- 每个复选框的值存她的商品id或sku_id -->
<?php echo "<input type='checkbox' id='checkbox_$goods_id' name='order[$goods_id]' value='$goods_id' class='son_check'>"; ?> <!-- 打勾对应文本框的id -->
<?php echo "<label for='checkbox_$goods_id'></label>"; ?>
</li>
<li class="list_con">
<div class="list_img"><a href="javascript:;">
<?php echo "<img src='./images/$goods[img]' alt=''>";?>
</a></div>
<div class="list_text"><a href="javascript:;"><?php echo "$goods[goodsname]"; ?></a></div>
</li>
<li class="list_info">
<p>规格:默认</p> </li>
<li class="list_price">
<p class="price"><?php echo '¥'."$goods[price]"; ?></p> <?php echo "<input type='hidden' value='$goods[price]'>"; ?>
</li>
<li class="list_amount">
<div class="amount_box">
<!-- 对商品的数量进行加减 -->
<?php echo "<a href='change_number.php?goods_id=$goods_id&choice=jian' class='reduce reSty'>-</a> "; ?>
<!-- 数量,要从session或数据库中查出来 -->
<?php echo "<input type='text' value='$goods_num' class='sum'>"; ?> <?php echo "<a href='change_number.php?goods_id=$goods_id&choice=jia' class='plus'>+</a> "; ?>
<?php echo "<input type='hidden' value='$goods[number]'>"; ?> </div>
</li>
<li class="list_sum">
<p class="sum_price"><?php echo '¥'."$sum"; ?></p>
</li>
<li class="list_op">
<p class="del">
<?php echo "<a href='delete_goods.php?goods_id=$goods_id' class='delBtn'>删除宝贝</a> "; ?></p>
</li>
</ul> </div>
<?php }} else{
echo "<h1 style='margin-top:150px;text-align:center;font-size: 39px;color:#c18e2cdb;'>兄
dei,你的购物车只剩下尊严了!!!</h1>";
}
?>


注意事项

可以给商品的checkbox类型添加name属性是因为他有selected属性,而其他像hidden类型的不能给它name属性,否则也会提交到后台。要保持提交过去的数据不能有冗余,需要遍历。

而且添加到订单也只需商品id就行,订单的商品数量可以在根据key在gwc中获得。具体看add_to_order.php.

使用session存储,购物车结算add_to_order.php(学生笔记)的更多相关文章

  1. 添加商品到购物车add_to_cart.php(学生笔记)

    <?php session_start();//启动session $goods_id = $_POST['goods_id'];//获取商品id $number = $_POST['num'] ...

  2. Jetty集群配置Session存储到MySQL、MongoDB

    在Web开发中,Session表示HTTP服务器与客户端(例如浏览器)的“会话”,每个客户端会有其对应的Session保存在服务器端,通常用来保存和客户端关联的一些信息,例如是否登录.购物车等. Se ...

  3. Jetty容器集群配置Session存储到MySQL、MongoDB

    在Web开发中,Session表示HTTP服务器与客户端(例如浏览器)的"会话",每个客户端会有其对应的Session保存在服务器端,通常用来保存和客户端关联的一些信息,例如是否登 ...

  4. 【ASP】session实现购物车

    1.问题提出 利用session内置对象,设计并实现一个简易的购物车,要求如下: 1)利用用户名和密码,登录进入购物车首页 2)购物首页显示登录的用户名以及该用户是第几位访客.(同一用户的刷新应该记录 ...

  5. 原生JS实现购物车结算功能代码+zepto版

    html <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3 ...

  6. Session 知识点再整理(二) 自定义 Session 存储机制

    对于访问量大的网站,用默认的 Session 存储方式(以文件存储)不适合,因为文件的 I/O 开销会非常大,另外 Session 机制本身使 Session 不能跨机访问,在 Web 集群中无法达到 ...

  7. session 存储方式

    Session 的存储方式 在 php.ini 文件中,进行配置. 涉及配置参数: - session.save_handler - session.save_path 注意:这两个参数可以在 PHP ...

  8. C# redis 分布式session存储

    https://github.com/uliian/SessionExtentionStore 一个基于Redis的Session存储扩展方案,解决ASP.NET中Session的局限性和跨应用程序使 ...

  9. YII session存储 调用login方法

    当要进行用户的session存储的时候,可以调用里面的login方法进行存储

随机推荐

  1. Python:数字类型和字符串类型的内置方法

    一.数字类型内置方法 1.1 整型的内置方法 作用 描述年龄.号码.id号 定义方式 x = 10 x = int('10') x = int(10.1) x = int('10.1') # 报错 内 ...

  2. Java中数组与集合的相互转换

    数组与List的相互转换 List转数组:采用集合的toArray()方法 数组转List:采用Arrays的asList()方法 数组转换为集合 注意:在数组转集合的过程中,要注意是否使用了视图的方 ...

  3. 【zabbix监控】zabbix监控tomcat服务

    服务器配置(zabbix_server) 1. 安装jdk 版本需要1.7以上,我这边安装的是1.8的,可以参考我jdk安装的文章 # 上传到zabbix_server服务端.安装(jdk-8u171 ...

  4. Redis 数据淘汰机制

    为了更好的利用内存,使Redis存储的都是缓存的热点数据,Redis设计了相应的内存淘汰机制(也叫做缓存淘汰机制) 通过maxmemory 配置项来设置允许用户使用的最大内存大小,当内存数据集大小达到 ...

  5. vc6.0 绿色版 下载地址

    最新版的vs2019已经完全不支持生成运行在xp下的应用程序 每次在xp下测试,都需要配置好vc6.0,但乱七八糟的太多了,给出地址,绿色版可用 http://www.downcc.com/soft/ ...

  6. Make a Property Calculable 使属性可计算

    In this lesson, you will learn how to manage calculated properties. For this purpose, the Payment cl ...

  7. 了解Bootstrap和开发响应式网站

    什么是Bootstrap? Bootstrap是Twitter推出的一个开源的用于web前端开发的工具包.它由Twitter的设计师Mark Otto和Jacob Thornton合作开发,是一个CS ...

  8. CODING 2.0 企业级持续交付解决方案

    "The key to DevOps transformation is that there is no end-state-we must continuously evolve.&qu ...

  9. [20191122]oracel SQL parsing function qcplgte.txt

    [20191122]oracel SQL parsing function qcplgte.txt --//昨天看了链接:https://nenadnoveljic.com/blog/memory-l ...

  10. PWA 学习笔记(一)

    PWA 介绍 概念: PWA(Progressive web apps,渐进式 Web 应用)运用现代 Web API 和传统的渐进式增强策略来创建跨平台 Web 应用程序 它并不是一个快捷方式,而能 ...