2014-09-13 58 views
-1

我找不到代码中的问题。它只向数据库发送单个订单。当我在我的购物车中订购2件或更多件商品时,它只发送最后的订单。我不知道如何在代码中更改或添加一些语法。MySQLi和PHP只发送数据库中的单个产品

这是我在checkout.php

<?php 
session_start(); 
echo '<h3>Your Order</h3>'; 
$current_url = base64_encode($url='http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI']); 
    if(isset($_SESSION['products'])){ 
    echo '<ol>'; 
    echo '<form action="checkout_with_us.php" method="POST">'; 
    $total = 0; 
    $cart_items = 0; 

     foreach($_SESSION['products'] as $cart_itm){ 
      $product_code = $cart_itm['code']; 
      $results = $mysqli->query("SELECT product_name,product_desc,price FROM products WHERE product_code='$product_code' LIMIT 1"); 
      $obj = $results->fetch_object(); 
       echo '<li>'; 
       echo 'Price: '.$currency.$obj->price; 
       echo '<h4>'.$obj->product_name.'(Code: '.$product_code.')</h4>'; 
       echo 'Qty: '.$cart_itm['qty']; 
       echo '</li>'; 

        $subtotal = ($cart_itm['price'] * $cart_itm['qty']); 
        $total = ($total + $subtotal); 
        $cart_items++; 
         echo '<input type="hidden" name="item_name" value="'.$obj->product_name.'">'; 
         echo '<input type="hidden" name="item_desc" value="'.$obj->product_desc.'">'; 
         echo '<input type="hidden" name="item_qty" value="'.$cart_itm["qty"].'">'; 
         echo '<input type="hidden" name="item_code" value="'.$product_code.'">';  
       } 
        echo '<strong>Sub Total: '.$currency.$total.'</strong>'; 
        echo '<input type="hidden" name="price" value="'.$total.'">'; 
        echo '</ol>'; 
        } 

//Here is the information of the customer 
echo 'Firstname: <input type="text" name="firstname"><br />'; 
echo 'Lastname: <input type="text" name="lastname"><br />'; 
echo 'Email: <input type="text" name="email"><br />'; 
echo '<input type="submit" value="Send Step">'; 

echo '</form>'; 
?> 

这里是我的checkout.with_us.php代码的代码。此代码是将信息发送到数据库的桥梁。

<?php 
session_start(); 
$firstname = $_POST['firstname']; 
$lastname = $_POST['lastname']; 
$email = $_POST['email']; 
$order_name = $_POST['item_name']; 
$order_code = $_POST['item_code']; 
$order_qty = $_POST['item_qty']; 
$sub_total = $_POST['price']; 

$conn = mysqli_connect('localhost','root','','sampsix')or die('Could not connect'); 

$query = "INSERT INTO `sampsix`.`orders`(`firstname`,`lastname`,`email`,`OrderName`,`OrderCode`,`OrderQty`,`SubTotal`) VALUES('$firstname','$lastname','$email','$order_name','$order_code','$order_qty','$sub_total')"; 

mysqli_query($conn,$query); 

mysqli_close($conn); 

header('Location: checkout.php'); 
?> 
+0

您已经发布了这个http://stackoverflow.com/q/25821058/ – 2014-09-13 16:29:23

+0

是的先生。仍然我没有答案来帮助我:( – 2014-09-13 16:32:12

+0

如果你想在一个'$ _POST ['xxx']''中有多个值,你需要将它设置为一个数组:'$ _POST ['xxx'] []' – lexith 2014-09-13 16:34:18

回答

3

删除你的其他问题,好吗?

问题是你循环通过$_SESSION并每次使用相同的name值。您需要创建一个输入数组。这里有一个例子:

<?php 
echo '<h3>Your Order</h3>'; 
$current_url = base64_encode($url='http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI']); 
    if(isset($_SESSION['products'])){ 
    echo '<ol>'; 
    echo '<form action="checkout_with_us.php" method="POST">'; 
    $total = 0; 
    $cart_items = 0; 

     foreach($_SESSION['products'] as $cart_itm){ 
      $product_code = $cart_itm['code']; 
      $results = $mysqli->query("SELECT product_name,product_desc,price FROM products WHERE product_code='$product_code' LIMIT 1"); 
      $obj = $results->fetch_object(); 
       echo '<li>'; 
       echo 'Price: '.$currency.$obj->price; 
       echo '<h4>'.$obj->product_name.'(Code: '.$product_code.')</h4>'; 
       echo 'Qty: '.$cart_itm['qty']; 
       echo '</li>'; 

        $subtotal = ($cart_itm['price'] * $cart_itm['qty']); 
        $total = ($total + $subtotal); 
        $cart_items++; 
         echo '<input type="hidden" name="product['.$product_code.'][item_name]" value="'.$obj->product_name.'">'; 
         echo '<input type="hidden" name="product['.$product_code.'][item_desc]" value="'.$obj->product_desc.'">'; 
         echo '<input type="hidden" name="product['.$product_code.'][item_qty]" value="'.$cart_itm["qty"].'">'; 
         echo '<input type="hidden" name="product['.$product_code.'][item_code]" value="'.$product_code.'">';  
       } 
        echo '<strong>Sub Total: '.$currency.$total.'</strong>'; 
        echo '<input type="hidden" name="product['.$product_code.'][price]" value="'.$total.'">'; 
        echo '</ol>'; 
        } 

//Here is the information of the customer 
echo 'Firstname: <input type="text" name="firstname"><br />'; 
echo 'Lastname: <input type="text" name="lastname"><br />'; 
echo 'Email: <input type="text" name="email"><br />'; 
echo '<input type="submit" value="Send Step">'; 

echo '</form>'; 
?> 

您可以通过在product阵列循环赶上这样的:

<?php 
$firstname = $_POST['firstname']; 
$lastname = $_POST['lastname']; 
$email = $_POST['email']; 

$conn = mysqli_connect('localhost','root','','sampsix')or die('Could not connect'); 

foreach($_POST['product'] as $product) 
{ 
    $order_name = $product['item_name']; 
    $order_code = $product['item_code']; 
    $order_qty = $product['item_qty']; 
    $sub_total = $product['price']; 

    $query = "INSERT INTO `sampsix`.`orders`(`firstname`,`lastname`,`email`,`OrderName`,`OrderCode`,`OrderQty`,`SubTotal`) VALUES('$firstname','$lastname','$email','$order_name','$order_code','$order_qty','$sub_total')"; 
    mysqli_query($conn,$query); 
} 



mysqli_close($conn); 

header('Location: checkout.php'); 
?> 

我不知道目的是表orders的产品,但与我的例子中会出现什么被添加到这个表格中的相同firstname,lastname

+0

哈哈哈感谢上帝!这是做先生!你是一个很棒的老师。多个订单已发送,最后一个订单保存“小计”您是怎么做的? :D – 2014-09-13 18:23:04

+0

终于嘿嘿。你的主要问题是你在哪里使用每个'输入'相同的'name'值。因为它们都具有相同的名称,所以只有最后一个值被传递。当你使用'[]'方括号时,你创建了一个信息数组,你可以在其中存储多行。 – 2014-09-13 18:28:05

+0

啊哈!是的,我看到了我的错误。哈哈只是名字。我想发送每个对象中没有数组。 Ahahaha谢谢你的美妙解释。我还可以问一个问题。因为我很困惑。将订单发送到我的“order.php”后,如何查看多个订单的表格信息同名。我在“order.php”中的代码只能查看单个订单。如果你有时间,你能看到我的代码吗? :) – 2014-09-13 18:34:20