Heim >Backend-Entwicklung >PHP-Problem >So implementieren Sie die Warenkorbfunktion in PHP

So implementieren Sie die Warenkorbfunktion in PHP

藏色散人
藏色散人Original
2020-07-23 09:25:274701Durchsuche

So implementieren Sie die Warenkorbfunktion in PHP: Melden Sie sich zuerst auf der Website an, um die Produkte zu durchsuchen, kaufen Sie dann die angegebenen Produkte, rufen Sie die Warenkorbseite auf, ändern Sie die Menge der Produkte und löschen Sie die Produkte , den Warenkorb leeren, mit dem Einkaufen fortfahren usw. Schließlich können Sie eine Bestellung erstellen, eine Bestellung aufgeben und andere Vorgänge ausführen.

So implementieren Sie die Warenkorbfunktion in PHP

Dieser Artikel stellt einen in PHP implementierten Warenkorbcode vor. Die Funktion ist vollständig und hat einen bestimmten Referenzwert

Hier stellen wir Ihnen einen einfachen PHP-Warenkorbcode zur Verfügung, vom Hinzufügen von Einkaufsprodukten bis zum Tätigen von Einkäufen. Bei der Entwicklung von Einkaufszentren ist diese Funktion unverzichtbar

Die spezifische Analyse lautet wie folgt:

Die Vorgänge für Artikel im Warenkorb umfassen im Allgemeinen Folgendes: Artikel hinzufügen, Artikel löschen und Bestellungen absenden

Das Wesentliche von die Methode Ja: Speichern Sie die Sitzung im Array, fügen Sie das Array hinzu, löschen Sie es und ändern Sie es. Jeder Satz von Datensätzen im Array enthält Informationen zu einer Ware (Anzahl, Preis usw.). Die Idee zur Lösung des Warenkorbs besteht darin, mithilfe einer Sitzung ein zweidimensionales Array aufzuzeichnen. Eine Dimension repräsentiert jedes Produkt und zwei Dimensionen umfassen die Produkt-ID, die Menge des Produkts usw. Sie können es selbst hinzufügen. Es ist jedoch zweidimensional. Sie können so viele Produktattribute hinzufügen, wie Sie möchten.

Der Vorgang des Warenkorbs: Melden Sie sich zunächst auf der Website an, um die Produkte zu durchsuchen. Kaufen Sie dann das angegebene Produkt und rufen Sie die Warenkorbseite auf, auf der Sie die Produkte ändern können Menge des Produkts, Löschen von Produkten, Leeren des Warenkorbs, Weitereinkaufen usw.; schließlich Generieren von Bestellungen, Senden von Bestellungen und andere Vorgänge.

Bitte sehen Sie sich die aussagekräftigen Kommentare an.

Loggen Sie sich zuerst ein.

<body>
<h1>登入页面</h1>
<form action="dengrucl.php" method="post">
    <p>帐号:<input type="text" name="zhang"/></p>
    <p>密码:<input type="text" name="mi"/></p>
    <input type="submit" value="登入"/>
</form>

</body>
Bild :

Login-Verarbeitung:

<?php
session_start();
include ("db.class.php");
$db = new db();
$zhang = $_POST["zhang"];
$mi = $_POST["mi"];
$sql = "select mi from yonghu WHERE zhang = &#39;{$zhang}&#39;";
$arr = $db->Query($sql);
if(!empty($zhang)&&!empty($mi)&&$mi = $arr){
    $_SESSION["zhang"] = $zhang;
    header("location:zym.php");
}
else
{
    echo "登入失败";
}

?>
Es ist ein einfaches Login, nichts viel Was er gesagt hat;

Nachdem er sich eingeloggt hatte, ging er direkt zur Hauptseite:

<body>
<h1>长腿璇购物商城</h1>
<table border="1" cellpadding="0" cellspacing="0" width="100%" >
    <tr>
        <td>代号</td>
        <td>水果名称</td>
        <td>水果价格</td>
        <td>水果产地</td>
        <td>水果库存</td>
        <td>操作</td>
    </tr>
   <?php
    session_start();
$_SESSION["zhang"] = "xiaoming";//不做登入的情况下,直接存sessiion
    include ("db.class.php");
    $db = new db();
    $sql = "select * from sgbiao";
    $arr = $db->Query($sql);
    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=&#39;zymcl.php?ids={$v[0]}&#39;>加入购物车</a>
        
</td>
    </tr>";
    }

    ?>
    <?php
    //这里显示的是 购物车有多少产品,和产品的总价格
    $ann=array();
    if(!empty($_SESSION["gwc"]))
    {
        $ann=$_SESSION["gwc"];

    }
    $zhonglei = count($ann);

    $aa=0;
    foreach($ann as $k)
    {

        $k[0];//水果代号
        $k[1];//水果数量
        $sql1="select jiage from sgbiao where ids=&#39;{$k[0]}&#39;";

        $danjia=$db->Query($sql1);

        foreach($danjia as $n)
        {

            $aa=$aa + $n[0]*$k[1];
        }


    }
    echo"数量:{$zhonglei}<br/>
价格:<mark>{$aa}元";
    ?>
</table>

<a href="tijiao.php">查看账户</a>
<a href="ckgwc.php">查看购物车</a>

</body>
Foto:

Wenn ich auf „Zum Warenkorb hinzufügen“ klicke:

Die oben genannte Menge und der Preis haben sich geändert, was darauf hinweist, dass sie dem Warenkorb hinzugefügt wurden

Sehen wir uns an, wie damit umgegangen wird (starke Kommentare):

<?php
session_start();
//
$ids = $_GET["ids"];
if(empty($_SESSION["gwc"]))
{
    //如果点击的购物车是空的(第一次添加)

    //如果购物车里是空的,造二维数组,
    $arr = array(
        array($ids,1)
        //一维数组,取ids,第一次点击增加一个
    );
    $_SESSION["gwc"]=$arr;
    //扔到session里面
}
else
    //这里不是第一次点击
{
    //先判断购物车里是否已经有了该商品,用$ids
    $arr = $_SESSION["gwc"];
    //把购物车的状态取出来

    $chuxian = false;
//定义一个变量;用来表示是否出现,默认是未出现
    foreach ($arr as $v) {
        //便利他
        //如果这里面有这件商品
        if ($v[0] == $ids) //如果取过来的$v[0](商品的代号)等于$ids那么就证明购物车中已经有了这一件商品
        {
            $chuxian = true;
            //如果出现,直接把chuxian改成true

        }
    }
    if($chuxian)
    {
        //购物车中有此商品
        for($i=0;$i<count($arr);$i++)
        {
            if($arr[$i][0] == $ids)
            {
                //把点到的商品编号加1
                $arr[$i][1] += 1;
            }
        }
        $_SESSION["gwc"] = $arr;

    }
        else
            {
                //这里就只剩下:购物车里有东西,但是并没有这件商品
                $asg = array($ids,1);
                //设一个小数组
                $arr[] = $asg;
                $_SESSION["gwc"]=$arr;
            }

}
header("location:zym.php")


?>

Als nächstes erstellen Sie die Warenkorbseite:

<body>
<h1>查看购物车</h1>
<table width="100%" border="1"cellspacing="0" cellpadding="0">
    <tr>
        <td>商品名称</td>
        <td>商品单价</td>
        <td>商品数量</td>
        <td>操作</td>
    </tr>
   <?php
    session_start();
    if(!empty($_SESSION["gwc"]))
    {
        $arr = array();
        $arr = $_SESSION["gwc"];
        //造数组
    }
    include (&#39;db.class.php&#39;);
    $db = new db();
    foreach ($arr as $v)
    {
        global $db;
        $sql = "select * from sgbiao WHERE ids = &#39;{$v[0]}&#39;";
        $att = $db->query($sql);
        foreach ($att as $a)
        {
            echo "<tr>
        <td>{$a[1]}</td>
        <td>{$a[2]}</td>
        <td>{$v[1]}</td>
        <td><a href=&#39;shanchu.php?ids={$a[0]}&#39;>删除</a> </td>
    </tr> ";
//            蔬果的名称
//            单价
//            取int数量
//        这个地方也可以加索引shanchu.php?sy={$v}
        }
    }
    ?>
</table>

<a href="tijiao.php">提交订单</a>
</body>

Bild oben:

Sie können sehen, dass die Anzahl der großen Äpfel 4 beträgt. Wenn ich auf „Löschen“ klicke, ist die Bedingung, dass es große Äpfel gibt und die Anzahl größer als eins ist. Klicken Sie auf „Löschen“, um die Zahl zu verringern Zahl um eins:

Die Anzahl der weißen Trauben ist 1. Wenn ich auf Löschen klicke, ist die Bedingung, dass die Zahl nicht größer als eins ist, damit sie aus dem Array entfernt werden kann ;

Nachdem wir das gesagt haben, werfen wir einen Blick auf die Seite:

<?php
session_start();
$ids = $_GET["ids"];
$arr = $_SESSION["gwc"];
//var_dump($arr);
//取索引2(数量)
foreach ($arr as $key=>$v)
{
    if($v[0]==$ids)
    {
        if($v[1]>1){
            //要删除的数据
           $arr[$key][1]-=1;
        }
        else{
            //数量为1的情况下,移除该数组
            unset($arr[$key]);
        }
    }

}

$_SESSION["gwc"] = $arr;
//记得扔到session里面
header("location:ckgwc.php");
//删除完跳转回去

Hohe Energie! !

Bestellseite absenden, ich komme nur zu einer Bearbeitungsseite, bei Bedarf können Sie den Link selbst ausfüllen:

<?php
session_start();
include ("db.class.php");
$db = new db();

//判断用余额是否满足
$zhang = $_SESSION["zhang"];
//获取到用户名
$sye = "select zhanghu from yonghu WHERE zhang = &#39;{$zhang}&#39;";
$ye = $db->query($sye);
$ye[0][0];//这是余额

$ann=array();
if(!empty($_SESSION["gwc"]))
{
    $ann=$_SESSION["gwc"];

}
$zhonglei = count($ann);

$aa=0;//总价格
foreach($ann as $k)
{

    $k[0];//水果代号
    $k[1];//水果数量
    $sql1="select jiage from sgbiao where ids=&#39;{$k[0]}&#39;";

    $danjia=$db->Query($sql1);

    foreach($danjia as $n)
    {

        $aa=$aa + $n[0]*$k[1];
    }


}
//判断余额是否满足
if($ye[0][0]>=$aa)
{
    //钱够,判断库存

    foreach($ann as $v)
    {
        $skc = "select sgname,kucun from sgbiao WHERE ids=&#39;{$v[0]}&#39;";
        //水果代号$v[0]
        $akc = $db->query($skc);
        $akc[0][1];//库存
        //比较是否满足库存
        if($akc[0][1]<$v[1])
        {
            echo "{$akc[0][0]}库存不足";
            //退出
            exit;
        }

    }
//提交订单:
//i.    从用户账户中扣除本次购买的总价格
//ii.    从商品库存中扣除本次每种商品的购买数量
//iii.    向订单表和订单内容表中加入本次购买的商品信息
    //扣除账户余额
$skcye = "update yonghu set zhanghu = zhanghu-{$aa} WHERE zhang = &#39;{$zhang}&#39;";
    $db->query($skcye,0);
    //扣除库存
    foreach($ann as $v)
    {
        $skckc = "update sgbiao set kucun = kucun-{$v[1]} WHERE ids=&#39;{$v[0]}&#39;";
        //水果代号$v[0]
        $db->query($skckc,0);
    }
    //添加订单信息
    //取当前时间
    $time = time();
    //自动生成订单号
    $ddh = date("YmdHis");
    $sdd = "insert into dingdan VALUES (&#39;{$ddh}&#39;,&#39;$zhang&#39;,&#39;$time&#39;)";
    $db->query($sdd,0);
    //添加订单内容
    foreach ($ann as $v)
    {
        $sddxq = "insert into ddneirong VALUES (&#39;&#39;,&#39;$ddh&#39;,&#39;{$v[0]}&#39;,&#39;{$v[1]}&#39;)";
        $db->query($sddxq,0);
    }


}
else
{
    echo "钱不够";
    exit;
}

So. Komm schon, die meisten Funktionen des Warenkorbs wurden implementiert.

Sehen wir uns den Effekt an, nachdem wir zum Absenden der Bestellung geklickt haben:

1. Obstbestand reduzieren:

2. Bestellung hinzufügen:

3. Bestellinhalt hinzufügen:

4. Den Kontostand des Käufers abziehen:

Das Obige ist der Inhalt des Warenkorbs

Das obige ist der detaillierte Inhalt vonSo implementieren Sie die Warenkorbfunktion in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn