Beste Allemaal,

Ik ben bezig met het maken van een eigen webshop voor school. Ik loop echter op dit moment tegen twee problemen aan:

Probleem 1:

Na een hoop gepiel is het me gelukt om het aantal van een product in de cart aan te passen en dit aantal door te voeren in de cart_array session. Maar er treedt een probleem op als ik de aantallen van verschillende producten tegelijk wil aanpassen, want dan pakt hij het nieuwe ingevulde aantal en voert die door op alle producten. Dus als ik bijv. product 1 aantal aanpas naar 5, past hij het aantal in de session van product 2,3,4 etc. ook aan naar 5. Ik weet dat de fout in het pakken van het nieuwe ingevulde aantal zit, want hij pakt dus maar één aantal en voert die door voor alle producten, maar ik weet niet hoe ik het kan oplossen.

Probleem 2:
Mijn tweede probleem komt bij het verwijderen van de verschillende producten uit de winkelwagen. Het verwijderen gaat goed, het lukt om er één te verwijderen, maar ook meerdere tegelijk. Echter als je bijv. het eerste product verwijdert uit de $_SESSION['cart_array'] en je hebt bijv. nog 3 andere producten erin staan, worden de indexen: 1-2-3, terwijl het eerst 0-1-2-3 was. En dan kloppen mijn checkboxen niet meer, want als je dan weer het eerste product wil verwijderen, wil hij de 0-index pakken, maar die is er dus niet meer. Ik heb de regel sort($_SESSION['cart_array']; onder de regel unset($_SESSION['cart_array'][''.$remove_id.'']); proberen te plakken, maar dan verwijdert hij gewoon alle indexen. Hoe kan dit?

Dit is de code:

<?php
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//       Section 1 (if user attempts to add something to the cart from the product page)
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
if(isset($_POST['pid']))
{
    $pid = $_POST['pid'];
    $wasFound = false;
    $i = 0;
    // If the cart session variable is not set or cart array is empty
   	if (!isset($_SESSION['cart_array']) || count($_SESSION['cart_array']) < 1) { 
    // RUN IF THE CART IS EMPTY OR NOT SET
    $_SESSION['cart_array'] = array(0 => array('product_id' => $pid, 'qty' => 1));
	} else {
		// RUN IF THE CART HAS AT LEAST ONE ITEM IN IT
		foreach ($_SESSION['cart_array'] as $each_item) { 
            $i++;
		      while (list($key, $value) = each($each_item)) {
				  if ($key == "product_id" && $value == $pid) {
					  // That item is in cart already so let's adjust its quantity using array_splice()
					  array_splice($_SESSION["cart_array"], $i-1, 1, array(array("product_id" => $pid, "qty" => $each_item['qty'] + 1)));
					  $wasFound = true;
				  } // close if condition
		      } // close while loop
	       } // close foreach loop
   		       if ($wasFound == false) {
			   array_push($_SESSION["cart_array"], array("product_id" => $pid, "qty" => 1));
                }
        
    }
   	header("location: cart.php"); 
    exit();
}
?>

<form action="" method="post" enctype="multipart/formdata">
                        
<table align="center" width="700" bgcolor="skyblue">
                                
<tr align="center">
    <th>Remove</th> 
    <th>Product(s)</th> 
    <th>Quantity</th> 
    <th>Total Price</th>   
</tr>
<?php

/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//       Section 4 (render the cart for the user to view)
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
$cartOutput = '';
$cartTotal = '';
if (!isset($_SESSION['cart_array']) || count($_SESSION['cart_array']) < 1) { 
    echo $cartOutput = "<h2 align='center'>Your shopping cart is empty</h2>";
    } else {
        $i = 0;
        foreach ($_SESSION['cart_array'] as $each_item) { 
                                                
        $product_id = $each_item['product_id'];
                                                
        $sql = $db->prepare("SELECT * FROM products WHERE product_id = '$product_id' LIMIT 1");
        $sql->execute();
                                                
        while ($row = $sql->fetch()) {
        $product_price = $row['product_price'];
        $product_title = $row['product_title'];
        $product_image = $row['product_image'];

        }
                                                
        $price_total = $product_price * $each_item['qty'];
        $cartTotal = $price_total + $cartTotal;
        $i++;
        
// Items verwijderen
if(isset($_POST["remove_cart"]))
    {    
                                    
    // Access the array and run code to remove that array index
    foreach($_POST['remove_item'] as $remove_id)
        {
            unset($_SESSION['cart_array'][''.$remove_id.'']);
        } 
            header('location: cart.php');
    }
                                    
// Itemaantallen aanpassen                           
if (isset($_POST['item_to_adjust']) && $_POST['item_to_adjust'] != "") {
$item_to_adjust = $_POST['item_to_adjust'];
$quantity = $_POST['qty'];
$i = 0;
foreach($_POST['item_to_adjust'] as $adjust_id)
    {
        $i++;
        array_splice($_SESSION["cart_array"], $i-1, 1, array(array("product_id" => $adjust_id, "qty" => $quantity)));                         
    } 
 }                                   
?>
<tr align="center">
    <td>
    <td><input type="checkbox" name="remove_item[]" value="<?php echo $i - 1;?>" /></td>
    <td><?php echo $product_title; ?><br /> 
    <img src="admin_area/product_images/<?php echo $product_image;?>" width="60" height="60" /> </td>
    <input name="item_to_adjust[]" type="hidden" value="<?php echo $each_item['product_id'];?>" />
    <td><input type="text" size="4" name="qty" value="<?php echo $each_item['qty'];?>" maxlength="1" /></td>
    <td><?php echo '&euro;'.$price_total; ?></td>                               
</tr>

<?php       
                            
            }
                } 
                                    
?>

<tr align="right">
<td colspan="4"><b>Sub Total:</b></td>
<td colspan="4"><?php echo '&euro;'.$cartTotal; ?></td>
</tr>
                            
<tr align="center">
    <td colspan="2"><input type="submit" name="remove_cart" value="Remove Item(s)" /></td>
    <td></td><input name="adjustBtn" type="submit" value="Update" /></td>
    <td><input type="submit" name="continue" value="Continue shopping" /></td>
    <td><a href="checkout.php"><button>Checkout</button></a></td>
    <td><a href="cart.php?cmd=emptycart">Empty Cart!</a></td>
                            
</tr>
                            
</table>
                        
</form>


Ik kom er maar niet uit!

Alvast bedankt, Mike
Thomas van den Heuvel op 18/03/2016 14:15:35

Omdat ik daarvoor gekozen heb.

Dit is geen onderbouwing.

(aangezien niet alle klanten een account nemen/willen)

Ik weet niet helemaal zeker of die mensen het dan ook kunnen waarderen indien jij dan allerlei informatie op hun PC dumpt, waar ze een volgend bezoek mee geconfronteerd worden... Zal hun gemoedsrust ook niet helpen als je het mij vraagt.

Overigens krijg je een popup als je cookies niet aan hebt staan :)

Behalve als JavaScript (ook) uit staat?


Dan moeten ze mn popup niet accepteren en forward ik ze gewoon terug waar ze vandaan komen

Dan krijg je een popup dat je javascript uitstaat..
Jij bent wel de leukste thuis he
wat als je css uitschakel
dan krijg je niks alleen tekst :) geen css popups helemaal niks

Volgens mij is t best wel standaard hoor dat n webshop cookies gebruikt en dat die cookie x aantal dagen op je browser blijft
Ik waardeer het in ieder geval wel als mijn 'wishlist' en/of winkelwagen gewoon nog blijft

bedenk eens wat n impact t op je database en snelheid van je webshop heeft als je van alle bezoekers op basis van ipadres,browser fingerprint of gebruikersid ALLE aanpassingen opslaat in een tijdelijk cart en wishlist tabel
en ik heb het niet over tientallen maar bedenk eens in 10duizenden

Mijn klanten hebben de mogelijkheid om hun bestelling te doen, zonder een gebruikersnaam en/of wachtwoord nodig te hebben
en als ze op t moment geen geld of toegang tot hun betaalpas of creditcard kunnen ze binnen 30 dagen nog steeds hun gewenste aankoop bekijken en afrekenen zonder de producten of diensten nogmaals uit te zoeken
"Over of ik de winkelwagen in een sessie wil opslaan, ik dacht van wel, want ik wil sowieso niet de producten meteen in de database opslaan. "
--> Alles netjes de database in, gebruikersgemak :-)

"Want als een klant uiteindelijk niet besteld, staan er overbodige producten in de database en daarom heb ik ervoor gekozen om het op te slaan in iets tijdelijks"
--> Totdat de gebruiker bezig is met een winkelmandje, even lekker de donald duck uitgebreid gaat lezen om zijn of haar behoefte te doen, vervolgens terug komt en merkt dat zijn/haar winkelmandje verloren is gegaan omdat de sessie het niet heeft overleeft... klant heeft geen zin om opnieuw te beginnen.. en shopt rustig verder.|
--> Desnoods ruim je je database weer op na 30 dagen.. hou je het ook schoon ;-)

Waarom moeilijk doen over een database als de inhoud minimaal is?
--> vind je 1000 records al veel? dat is 0,00000001 % van wat een database aan kan ( bij wijze van ).
@elmar ik weet nog niet heel veel over databases, maar zoals je het zegt maakt het dus niet zoveel uit. Ik dacht: hoe minder hoe beter.
Toen ik een winkelwagensysteem wou maken (begrijpen) heb ik eerst van github eentje gehaald. Misschien dat het voor jou ook kan helpen om een compleet en veilig voorbeeld te zien.

Ik heb een jaar geleden een zip ervan gehaald genaamd 'php-shopping-cart-master.zip' en heb daar heel veel aan gehad om te begrijpen hoe het werkt en erna aan te passen.

Ik noem het toch maar even

Reageren