PHP-Operation zur Implementierung einer multifunktionalen Shopping-Website
1. Zu implementierende Seiten:
Index.aspx:浏览商品页面,显示商品列表,用户可以点击“加入购物车“。 ViewCart.aspx:查看购物车页面,显示已购买的商品信息,可以点击“删除“和“提交添加订单购买”商品 ViewAccount.aspx:查看个人账户余额 Login.aspx:登录页面
Wenn die „Kaufmenge“ eines Produkts 1 beträgt, klicken Sie auf „Löschen“, um das Produkt direkt aus dem Warenkorb zu löschen.
Wenn die „Kaufmenge“ eines Produkts größer als 1 ist, klicken Sie auf „Löschen“. Reduzieren Sie einmal die Kaufmenge um 1. Bis die Kaufmenge des Produkts 1 erreicht, klicken Sie erneut auf Löschen, um das Produkt zu löschen
5. Nachdem Sie den Warenkorb angezeigt haben, können Sie auch auf „Produkte durchsuchen“ klicken, um mit dem Einkauf fortzufahren. Darüber hinaus werden die Menge der gekauften Waren und der Gesamtpreis angezeigt.
Beim Absenden einer Bestellung müssen jedoch die folgenden Funktionen ausgeführt werden:
(a) Überprüfen Sie, ob der Benutzer angemeldet ist. Wenn er nicht angemeldet ist, gehen Sie zur Seite Login.aspx
Der Vorgangscode lautet wie folgt:
1. Erstellen Sie zunächst eine Anmeldeseite: loginpage.php
Der Effekt ist wie gezeigt:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <script src="bootstrap/js/jquery-1.11.2.min.js"></script> <script src="bootstrap/js/bootstrap.min.js"></script> <link href="bootstrap/css/bootstrap.min.css" rel="stylesheet" type="text/css"/> </head> <style> .title{ margin-left: 750px; margin-top: 150px; } .quanju{ margin-left: 650px; margin-top: -460px; } .name,.pwd{ max-width: 120px; } .yangshi1{ margin-top: 200px; } .header{ width: 100%; height: 80px; background: #e0e0e0; } .ps{ margin-left: 100px; margin-top: -100px; } </style> <body> <form class="form-horizontal" role="form" action="dengluchuli.php" method="post"> <p class="header"> <img src="img/logo.png" width="200" height="50" style="margin-top: 10px; margin-left: 100px;" /> <p style="height: 50px; width: 300px; color: green;float: right; font-size: 50px; margin-right: 350px">果 蔬 网</p> </p> <h3 class="title">用户登录</h3> <img src="./img/果蔬专场.jpg" width="500" height="400" class="ps" /> <p class="quanju"> <p class="form-group yangshi1"> <label for="firstname" class="col-sm-2 control-label">用户名:</label> <p class="col-sm-10"> <input type="text" class="form-control name" name="uid" placeholder="请输入用户名"> </p> </p> <p class="form-group yangshi2"> <label for="lastname" class="col-sm-2 control-label">密码:</label> <p class="col-sm-10"> <input type="text" class="form-control pwd" name="pwd" placeholder="请输入密码"> </p> </p> <p class="form-group"> <p class="col-sm-offset-2 col-sm-10"> <p class="checkbox"> <label> <input type="checkbox"> 保存密码 </label> <label> <input type="checkbox"> 下次自动登录 </label> </p> </p> </p> <p class="form-group"> <p class="col-sm-offset-2 col-sm-10"> <button type="submit" class="btn btn-warning" value="登录" onclick="return login()" > 登录 </button> </p> </p> </p> </form> </body> <script> function login(){ var uid = document.getElementsByTagName("input")[0].value; if(uid==""){ alert("请输入用户名!"); return false; } var pwd = document.getElementsByTagName("input")[1].value; if(pwd==""){ alert("请输入密码!"); return false; } } </script> </html>
2. Erstellen Sie eine Anmeldung Verarbeitungsseite: dengluchuli.php
Auf diese Weise können Sie das Anmeldekonto und das Passwort der Datenbank überprüfen und dann zur Startseite springen .php
<?php session_start(); $uid = $_POST["uid"]; $pwd = $_POST["pwd"]; require_once "./DBDA.class.php"; $db = new DBDA(); $sql = "select * from login where username='{$uid}'"; $arr = $db->query($sql,0); if($arr[0][2]==$pwd && !empty($pwd)){ $_SESSION["uid"]=$uid; header("location:shopping_list.php"); }else{ echo "登陆失败!"; }
3. Erstellen Sie nun die Startseite: shopping_list.php//
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <script src="bootstrap/js/jquery-1.11.2.min.js"></script> <script src="bootstrap/js/bootstrap.min.js"></script> <link href="bootstrap/css/bootstrap.min.css" rel="stylesheet" type="text/css"/> </head> <body> <h2 style="margin-left: 550px; margin-top: 80px;">水果列表</h2> <?php session_start();
$uid = $_SESSION["uid"]; if(empty($_SESSION["uid"])){ header("location:loginpage.php"); exit; } require_once "./DBDA.class.php"; $db = new DBDA();
4. Führen Sie dann die Verarbeitungsseite der Homepage aus: shoppingchuli.php
if(!empty($_SESSION["gwd"])){ $arr = $_SESSION["gwd"]; $sum = 0; $numbers = count($arr); foreach($arr as $k=>$v){ //$v[0];//水果名称 //$v[1];//购买数量 $sql = "select * from fruit where ids='{$v[0]}'"; $attr = $db->query($sql,0); $dj = $attr[0][2]; //单价 $sum = $sum+$dj*$v[1]; //总价=单价*数量 } } echo @"<p style='margin-left: 250px'>购物车中商品总数为{$numbers}个,商品总价为:{$sum}元</p>"; ?> <a href="loginpage.php" style="float: right; margin-top: -25px; margin-right: 330px; color: blueviolet; font-size: 20px;"> 登录 </a> <table class="table table-bordered" style="max-width: 800px; margin-left: 250px;"> <thead> <tr> <th>代号</th> <th>名称</th> <th>价格</th> <th>产地</th> <th>库存</th> <th>操作</th> </tr> </thead> <tbody> <?php $sql = "select * from fruit"; $arr = $db->query($sql,0); 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='shoppingchuli.php?ids={$v[0]}'>加入购物车</a></td> </tr>"; } ?> </tbody> </table> <a href="add_list.php" style="margin-left: 250px;">查看购物车</a> </body> </html>
Der Effekt ist wie folgt angezeigt:
<?php session_start(); //取到传过来的主键值,并且添加到购物车的SESSION里面 $ids = $_GET["ids"]; //如果是第一次添加购物车,造一个二维数组存到SESSION里面 //如果不是第一次添加,有两种情况 //1.如果该商品购物车里面不存在,造一个一维数组扔到二维里面 //2.如果该商品在购物车存在,让数量加1 if(empty($_SESSION["gwd"])){ //如果是第一次添加购物车,造一个二维数组存到SESSION里面 $arr = array( array($ids,1)); $_SESSION["gwd"]=$arr; }else{ $arr=$_SESSION["gwd"]; if(deep_in_array($ids,$arr)){ //如果该商品在购物车存在,让数量加1 foreach($arr as $k=>$v){ if($v[0]==$ids){ $arr[$k][1]++; } } $_SESSION["gwd"]=$arr; }else{ //如果该商品购物车里面不存在,造一个一维数组扔到二维里面 $arr=$_SESSION["gwd"]; $attr=array($ids,1); $arr[]=$attr; $_SESSION["gwd"]=$arr; } } header("location:shopping_list.php"); function deep_in_array($value, $array) { foreach($array as $item) { if(!is_array($item)) { if ($item == $value) { return true; } else { continue; } } if(in_array($value, $item)) { return true; } else if(deep_in_array($value, $item)) { return true; } } return false; }
5. Gehen Sie dann auf die Seite „Warenkorb anzeigen“ und Sie können die Produkte, den Einzelpreis und den Gesamtpreis im Warenkorb sehen: gouwuche.php
Die Der Effekt ist wie in der Abbildung dargestellt:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <script src="bootstrap/js/jquery-1.11.2.min.js"></script> <script src="bootstrap/js/bootstrap.min.js"></script> <link href="bootstrap/css/bootstrap.min.css" rel="stylesheet" type="text/css"/> </head> <?php session_start(); $uid = $_SESSION["uid"]; if(empty($_SESSION["uid"])){ header("location:loginpage.php"); exit; } ?> <body> <h2 style="margin-left: 550px; margin-top: 100px;">购物车清单</h2> <table class="table table-bordered" style="max-width: 800px; margin-left: 250px;"> <thead> <tr> <th>代号</th> <th>名称</th> <th>价格</th> <th>产地</th> <th>购买数量</th> <th>操作</th> </tr> </thead> <tbody> <?php require_once "./DBDA.class.php"; $db = new DBDA(); if(!empty($_SESSION["gwd"])){ $arr = $_SESSION["gwd"]; $sum = 0; $numbers = count($arr); foreach($arr as $k=>$v){ //$v[0];$v[1]; $sql = "select * from fruit where ids='{$v[0]}'"; $a = $db->query($sql,0); //var_dump($v[1]); echo "<tr> <td>{$v[0]}</td> <td>{$a[0][1]}</td> <td>{$a[0][2]}</td> <td>{$a[0][3]}</td> <td>{$v[1]}</td> <td><a href='goodsdel.php?zj={$k}'>删除</a></td> </tr>"; $dj = $a[0][2]; $sum = $sum+$dj*$v[1]; } } //echo "<p style='margin-left: 250px;'>购物车中商品总数为{$numbers}个,商品总价为:{$sum}元</p>"; ?> </tbody> </table> <a href="submit_order.php?ids={$v[0]}" style="margin-left: 250px;">提交订单</a> </body> </html>
6. Löschen Sie dann die Verarbeitungsseite „goodsdel.php“
Der Kontostand des Benutzers wurde reduziert:
<?phpsession_start(); $zj = $_GET["zj"]; //如果该水果数量大于1,减1//如果该水果数量等于1 移除$arr = $_SESSION["gwd"]; if($arr[$zj][1]>1) { $arr[$zj][1]=$arr[$zj][1]-1; } else { unset($arr[$zj]); //清除数组 $arr=array_values($arr); //重新索引数组 } $_SESSION["gwd"] = $arr; header("location:add_list.php"); 7..然后做提交页面 :tijiao.php <?phpsession_start(); $ids = $_GET["ids"]; //查看余额$uid = $_SESSION["uid"]; require_once "./DBDA.class.php"; $db = new DBDA(); $sql = "select account from login where username=' { $uid } '"; $arr = $db->query($sql,0); $aye = $arr[0][0]; //余额//var_dump($aye); if(!empty($_SESSION["gwd"])) { $arr = $_SESSION["gwd"]; $sum = 0; //$numbers = count($arr); foreach($arr as $v) { $sql = "select * from fruit where ids=' { $v[0] } '"; $price = $db->query($sql,0); $dj = $price[0][2]; $sum = $sum+$dj*$v[1]; } }else { echo "您还未购买商品!"; //header("shopping_list.php"); exit; } //判断余额是否满足购买if($aye>=$sum) { //判断库存 foreach($arr as $v) { $skc = "select name,numbers from fruit where ids=' { $v[0] } '"; $akc = $db->query($sql,0); var_dump($akc); $kc = $akc[0][4]; //库存 //var_dump($kc); if($kc<$v[1]) { echo "库存不足!"; exit; } } //提交订单 //账户扣除余额 $skye = "update login set account=account- { $sum } where username=' { $uid } '"; $zhye = $db->query($skye); //扣除库存 foreach($arr as $v) { $skckc = "update fruit set numbers=numbers- { $v[1] } where ids=' { $v[0] } '"; $sykc = $db->query($skckc); } //添加订单 $ddh = date("Y-m-d H:i:s"); $time = time(); $stjd = "insert into orders values(' { $time } ',' { $uid } ',' { $ddh } ')"; $wcdh = $db->query($stjd); //添加订单详情 foreach($arr as $v) { $ddxq = "insert into orderdetails values('',' { $ddh } ',' { $v[0] } ',' { $v[1] } ')"; $axq = $db->query($ddxq); } }else { echo "余额不足,请充值!"; exit; } header("location:shopping_list.php");
Das obige ist der detaillierte Inhalt vonPHP-Operation zur Implementierung einer multifunktionalen Shopping-Website. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!