PHP 购物车 session(非框架)

这是我的一次面试中的面试题,简单写商城的购物车功能,要求是:

1、自己写简单的前台

2、用户登录前能用购物车

3、不可以用cookie

暂时了解到的解决方法有三个:

1、cookie

2、session

3、数据库

该购物车的主要逻辑是,用session来实现识别不同的用户各自的购物车,以便用户登录后保存的是自己的购物车。流程图如下:

PHP 购物车 session(非框架)


   各文件的代码如下:

   shop_list.php

  1. <?php  
  2. /* shop_list.php 
  3.  * 该文件主要功能为商品展示 
  4.  * 并且把用户需要商品加入购物车 */  
  5.   
  6.   
  7.   
  8. //连接数据库  
  9. include 'mysql_connect.php';  
  10. session_start();  
  11. ?>  
  12. <br>  
  13. <a style="font-size: 150%;color: red" >当前用户:  
  14.     <?php  
  15.     if(isset($_SESSION['user_name']))  
  16.     echo $_SESSION['user_name'] . "     ";  
  17.     else  
  18.     echo '未登录';  
  19.     ?>  
  20.     <a href="login.php">(登录)</a>  
  21.     <?php  
  22.     }  
  23.     ?> </a>  
  24. <a style="font-size: 150%;color: blue" href="shop_cart.php">商品展示</a>  
  25. <table border="1"  height="400px" width="400px">      
  26.     <td style="font-size: 120%;color: blue;text-align: center">商品id</td>  
  27.     <td style="font-size: 120%;color: blue;text-align: center">商品名字</td>  
  28.     <td style="font-size: 120%;color: blue;text-align: center">商品数量</td>  
  29.     <td style="font-size: 120%;color: blue;text-align: center">商品价格</td>  
  30.     <td style="font-size: 120%;color: blue;text-align: center">操作</td>  
  31.   
  32. <?php  
  33. //查询数据库,并处理结果集  
  34. $sql = "select * from goods order by `goods_id`";  
  35. $result = mysql_query($sql$conn);  
  36. while ($row = mysql_fetch_array($result)) {  
  37.     ?>  
  38.         <tr>  
  39.             <td width="50px"><?php echo $row['goods_id'] ?></td>  
  40.             <td ><?php echo $row['goods_name'] ?></td>  
  41.             <td ><?php echo $row['goods_num'] ?></td>  
  42.             <td ><?php echo $row['goods_price'] ?></td>  
  43.             <td style="font_size:150%;color: red;text-align:center" >  
  44.                 <a href="shop_cart.php?goods_id=<?php echo $row['goods_id']; ?>&goods_name=<?php echo $row['goods_name']; ?>">加入购物车</a>  
  45.             </td>  
  46.         </tr>  
  47. <?php } ?>  
  48. </table>  




   shop_cart.php
  1. <?php  
  2.   
  3. /* shop_cart.php 
  4.  * 该文件主要功能为接受用户来自shop_list.php通过GET方式提交的添加购物车商品数据 
  5.  * 并且创建商品的session数据,或者更新session中用户需要商品的数量 
  6.  * 最后跳转到购物车内容页buy.php 
  7.  * */  
  8.   
  9.   
  10. include 'mysql_connect.php'//引入mysql连接方法的文件  
  11. //主要逻辑为:利用session存储加入购物车的数据,从而来区别每一个人用户各自的购物车,  
  12. //而session存储的内容是一个二维数组,格式为array【‘商品的名字’】['商品的具体数据']  
  13. //其中商品的具体数据有两个1、用户选择的商品ID 2、用户选择的数量  
  14. //  
  15. session_start(); //开启session  
  16. $GET_name = $_GET["goods_name"]; //从GET提交的数据提取goods_name  
  17. $GET_id = $_GET["goods_id"];     //从GET提交的数据提取goods_id  
  18. $arr = $_SESSION['shop_cart'];    //把session赋值给一个二维数组  
  19. //$_SESSION['shop_cart']=array($GET_name=>array('goods_id'=>$GET_id,'goods_num'));//将二维数组储存在session里面  
  20. //$arr=$_SESSION["shop_cart"];  
  21. //现在判断二维数组$arr的内容是否存在现添加购物车的商品的名字来实现判断该商品是否第一次添加入购物车,  
  22. //如果是第一次,则为该商品创建session的二维数组中添加商品的全部数据  
  23. //否则不是第一次,则为该商品的session年中二维数据中goods_num增加数目为1件  
  24. if (array_key_exists($GET_name$arr)) {  
  25.     //该商品添加过购物车,进行数量加1的操作  
  26.     $a = $arr[$GET_name]['goods_num'] ++;  
  27.     echo '存在该商品' . $arr[$GET_name]['goods_num'];  
  28. else { //该商品为新商品添加到购物车  
  29.     $sql = "select * from goods where `goods_id` = " . $GET_id;  //建立查找对应商品的具体信息的SQL语句  
  30.     $result = mysql_query($sql);    //商品的具体信息查找结果  
  31.     $row = mysql_fetch_array($result);  
  32.   
  33. //arr0为要添加已存在购物车数组arr的新购物车数组  
  34.     $arr0 = array($GET_name => array('goods_id' => $GET_id'goods_num' => 1, 'goods_name' => $GET_name'goods_price' => $row['goods_price']));  
  35. //arr0赋值到arr1  
  36.   
  37.   
  38.     foreach ($arr0 as $key => $value) {  
  39.         $arr[$key] = $value;  
  40.     }  
  41. }  
  42. //添加完成后,重新把二维数组更新到session  
  43. $_SESSION['shop_cart'] = $arr;  
  44. //成功添加完成,进行跳转页面  
  45. header("location:buy.php"); //跳转到购物车内容界面  
  46. ?>  

buy.php

  1. <?php  
  2. /* buy.php 
  3.  * 该文件主要功能为购物车内容展示 
  4.  * 并且根据用户选择结算购物车来调用finish.php文件 */  
  5.   
  6.   
  7. //开启session  
  8. session_start();   //开启session  
  9. $arr = $_SESSION['shop_cart'];  //从session中读取二维数组  
  10. ?>  
  11. <br>  
  12. <a style="font-size: 150%;color: red" href="buy.php">当前用户:  
  13.     <?php  
  14.     if (isset($_SESSION['user_name'])) {  
  15.         echo $_SESSION['user_name'];  
  16.     } else {  
  17.         echo '未登录';  
  18.     }  
  19.     ?>  
  20. </a>  
  21. <a style="font-size: 150%;color: blue" href="shop_cart.php">购物车状态</a>  
  22. <table border="1"  height="400px" width="400px">      
  23.     <td style="font-size: 120%;color: blue;text-align: center">商品id</td>  
  24.     <td style="font-size: 120%;color: blue;text-align: center">商品名字</td>  
  25.     <td style="font-size: 120%;color: blue;text-align: center">商品数量</td>  
  26.     <td style="font-size: 120%;color: blue;text-align: center">商品价格</td>  
  27.   
  28.   
  29.     <?php  
  30. //遍历二维数组读取加入购物车的商品信息  
  31.   
  32.   
  33.   
  34.   
  35.   
  36.     foreach ($arr as $v => $val) {  
  37.         ?>  
  38.         <tr>  
  39.             <td width="50px"><?php echo $val['goods_id'] ?></td>  
  40.             <td ><?php echo $val['goods_name'] ?></td>  
  41.             <td ><?php echo $val['goods_num'] ?></td>  
  42.             <td ><?php echo $val['goods_price'] ?></td>  
  43.         </tr>  
  44.     <?php } ?>  
  45. </table>  
  46.   
  47. <form name="myform" method="POST" action="finish.php">  
  48.   
  49.     <input type="hidden" name="goods_id" value=" $val['goods_id']" /><br/>  
  50.   
  51.     <input type="hidden" name="goods_name" value="$val['goods_name']" /><br/>  
  52.   
  53.     <input type="hidden" name="goods_num" value="$val['goods_num']" /><br/>  
  54.   
  55.     <input type="hidden" name="goods_price" value="$val['goods_price']" />  
  56.   
  57.     <input type="submit" name="sub" style="font-size: 200%;color: red" value="结算购物车" />  
  58.   
  59. </form>  
  60.   
  61. <form ></form>  

finish.php

  1. <?php  
  2.   
  3. include 'mysql_connect.php';  
  4. //通过session['user_name']判断是否登录。如果已登录则把数据写入数据库,并提示成功跳转到商品展示页  
  5. //如果未登录 ,提示进行登录,并且跳转至登录页面  
  6. session_start();   //开启session  
  7. $arr = $_SESSION['shop_cart'];  //从session中读取二维数组  
  8. if (isset($_SESSION['user_name'])) {  
  9.     //已经登录,从session中取出数据来写入数据库  
  10.     foreach ($arr as $v => $val) {  
  11.         $values = $val['goods_id'] . ",'" . $val['goods_name'] . "'," . $val['goods_num'] . "," . $val['goods_price'] . ",'" . $_SESSION['user_name'] . "'";  
  12.         $sql = "insert into `buy` (`buy_goods_id`,`buy_goods_name`,`buy_goods_num`,`buy_goods_price`,`user_name`) values($values);";  
  13.   
  14.         $rs = mysql_query($sql);  
  15.     }  
  16.   
  17.     if ($rs) {  
  18.         echo "结算成功!!!正在返回首页!";  
  19.         header("refresh:2;url=shop_list.php"); //两秒后跳转  
  20.     } else {  
  21.         echo "结算失败,正在返回购物车!" . mysql_errno();  
  22.         header("refresh:2;url=buy.php"); //两秒后跳转  
  23.     }  
  24. else {  
  25.     echo "请进行登录后再进行结算!";  
  26.     header("refresh:2;url=login.php");  
  27. }  
  28. ?>  

login.php

  1. <html>  
  2. <head>  
  3. <meta charset="utf-8"/>  
  4. <title>用户登陆</title>  
  5. </head>  
  6. <body>  
  7.     <h1>请进行商城用户登录:</h1>  
  8. <form name="myform" method="POST" action="check_login.php">  
  9.   
  10.     用户名:<input type="text" name="user_name" value="" /><br/>  
  11.   
  12.     密码  :<input type="password" name="user_pwd" value="" /><br/>  
  13.   
  14.     <input type="submit" name="sub" value="用户登陆" />  
  15.   
  16. </form>  
  17. </body>  
  18. </html>  
  19.   
  20. <h2>check_login.php</h2><div><pre name="code" class="php"><?php  
  21.   
  22. /* check_login.php 
  23.  * 该文件主要功能为验证登录用户信息是否正确 
  24.  * 并且根据正确跳转到商品展示页shop_list.php 
  25.  * 如果不正确则跳转到登录页面login.php */  
  26.   
  27.   
  28.     include 'mysql_connect.php';  
  29.     session_start(); //开启session  
  30.     $user_name = $_POST['user_name'];  
  31.     $user_pwd = $_POST['user_pwd'];  
  32.     //查询数据库,并先验证用户名是否正确,若正确再进行下一步验证密码  
  33.   
  34.     $user_name_sql = 'select * from `user` where `user_name` = "' . $user_name . '"';  
  35.     $result = mysql_query($user_name_sql$conn);  
  36.     $row = mysql_fetch_array($result);  
  37.     if ($row) {  
  38.         if ($row['user_pwd'] == $user_pwd) {  
  39.             $_SESSION['user_name'] = $user_name;  //把用户名添加到session中  
  40.             echo "<script>alert('登录成功!')</script>";  
  41.             Header("Refresh:1;shop_list.php ");  
  42.         } else {  
  43.             echo '密码错误!请重新登录';  
  44.   
  45.             Header("Refresh:2;login.php ");  
  46.         }  
  47.     } else {  
  48.         echo '不存在该用户,请重新登录';  
  49.         Header("Refresh:2;login.php");  
  50.     }  
  51. ?>  


mysql_connect.php

  1. <?php  
  2.   
  3. /* mysql_connect.php 
  4.  * 该文件主要功能为mysql连接 
  5.  *  */  
  6.   
  7.   
  8.     //连接数据库  
  9.     $conn = mysql_connect('localhost''root''12345');  
  10.     mysql_select_db('ShoppingCart'$conn);  
  11.     $conn_rs = mysql_query('set names utf8');  
  12.     if ($conn_rs)  
  13.     //echo "mysql连接成功!";  
  14.         echo '';  
  15.     else  
  16.         die('mysql连接错误' . mysql_error());  
  17. ?>  


最后是所需要的数据库表:
shoppingcart.sql

  1. --shoppingCart.sql  
  2. --该文件为记录此商城所需要建立的数据库的各种表以及数据  
  3. CREATE DATABASE `ShoppingCart`;  
  4. --Goods表  
  5. DROP TABLE IF EXISTS `Goods`;  
  6.   
  7.     CREATE TABLE `Goods`(  
  8.     `goods_id` tinyint(4) unsigned NOT NULL AUTO_INCREMENT PRIMARY KEY,  
  9.     `goods_name` varchar(20) NOT NULL COMMENT '商品名字',  
  10.     `goods_num` smallint(6) unsigned NOT NULL  COMMENT '商品剩余数量',  
  11.     `goods_Price` smallint(6)  unsigned NOT NULL COMMENT '商品价格'  
  12. )ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;  
  13. --用户表  
  14. DROP TABLE IF EXISTS `User`;  
  15.     CREATE TABLE `User`(  
  16.     `user_id` tinyint(4) unsigned NOT NULL AUTO_INCREMENT PRIMARY KEY,  
  17.     `user_name` varchar(20) NOT NULL COMMENT '用户名',  
  18.     `user_pwd` varchar(20) NOT NULL COMMENT '用户密码'  
  19. )ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;  
  20.   
  21. --订单表  
  22. CREATE TABLE `Buy`(  
  23.     `buy_goods_id` tinyint(4) unsigned NOT NULL ,  
  24.     `buy_goods_name` varchar(20) NOT NULL COMMENT '商品名字',  
  25.     `buy_goods_num` smallint(6) unsigned NOT NULL  COMMENT '商品购买数量',  
  26.     `buy_goods_Price` smallint(6)  unsigned NOT NULL COMMENT '商品价格',  
  27.     `user_name` varchar(20) NOT NULL COMMENT '订单提交者'  
  28. )ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;  
  29. --用户表  
  30.   
  31. insert into `Goods` values(1,'Nokia',100,2000);  
  32. insert into `Goods` values(2,'Samsung',150,3000);  
  33. insert into `Goods` values(3,'Apple',200,4000);  
  34.   
  35.   
  36. insert into `User` values(1,'Tim','123');  
  37. insert into `User`  values(2,'Jack','123');  
  38. insert into `User`  values(3,'Tom','123');  


总结:其实购物车的逻辑很简单,主要是解决如何识别每一个没登录用户的身份,这有三种方案解决,分别是1、cookie 2、session 3、数据库

      这一点用session就很容易解决,相对COOKIE的解决方案优点是不会因为用户禁用了本机的cookie功能而导致购物车功能作废;session把数据存放在了服务器,安全性也有一定的提高;不过session也不是完全没有缺点,如果并发用户很多的时候,会在服务器生成大量的session文件,占用服务器的资源同时也影响服务器的性能。而且当用户退出浏览器的时候,购物车session就会清空,而cookie则不会清空。