Maison développement back-end Problème PHP Comment ajouter un panier en php sans vous connecter

Comment ajouter un panier en php sans vous connecter

Apr 05, 2023 pm 02:38 PM

Dans le commerce électronique moderne, le panier est un outil interactif important, qui peut aider les clients à sélectionner et à acheter des produits plus facilement. De manière générale, les clients doivent se connecter avant d'ajouter des articles à leur panier, mais dans certains cas, nous devrons peut-être fournir une fonction qui leur permet d'ajouter des articles à leur panier sans se connecter. Cet article expliquera comment utiliser PHP pour réaliser cette fonctionnalité.

Utilisez des cookies pour stocker les données de votre panier

Si les clients peuvent ajouter des articles à leur panier sans se connecter, nous devons alors utiliser un moyen de distinguer les différents clients et les données de leur panier. Une méthode courante consiste à utiliser des cookies pour stocker les données du panier. Un cookie est un petit élément de données stocké sur le client qui peut être transmis entre le client et le serveur. En stockant les données du panier dans des cookies, nous pouvons restaurer les données lors de la prochaine visite d'un client sur notre site Web, garantissant ainsi la cohérence des données du panier.

Afin de réaliser cette fonction, nous pouvons créer un fichier add_to_cart.php Lorsque le client clique sur le bouton "Ajouter au panier", le fichier stockera les informations sur le produit dans le cookie en arrière-plan. La méthode spécifique est la suivante :

  1. Dans le fichier add_to_cart.php, obtenez d'abord l'ID du produit et la quantité à ajouter au panier via la méthode GET ou POST.
  2. Ensuite, obtenez les données actuelles du panier via la variable $_SESSION de PHP. Dans certaines circonstances, la variable $_SESSION peut devenir invalide, une détection et une gestion de celle-ci sont donc nécessaires.
  3. Créez un tableau pour stocker les données du panier (par exemple : $cart = array()).
  4. Si les données du panier existent déjà dans $_SESSION, copiez-les dans le tableau $cart.
  5. Vérifiez si l'article actuel est déjà dans le panier. Si oui, augmentez la quantité de cet article dans le panier ; sinon, ajoutez le nouvel article au panier.
  6. Stockez les données du panier dans un cookie pour la prochaine fois que vous récupérerez les données du panier de l'utilisateur.
  7. Enregistrez les données telles que la quantité totale et le prix du panier dans $_SESSION pour une utilisation ultérieure.

Exemple de code :

<?php
session_start();
$product_id = $_GET[&#39;product_id&#39;];
$quantity = $_GET[&#39;quantity&#39;];

$cart = array();
if (isset($_SESSION[&#39;cart&#39;])) {
    $cart = $_SESSION[&#39;cart&#39;];
}

if (isset($cart[$product_id])) {
    $cart[$product_id][&#39;quantity&#39;] += $quantity;
} else {
    $cart[$product_id] = array(
        &#39;id&#39; => $product_id,
        'quantity' => $quantity,
        'price' => $price // 商品单价等其他信息可以根据需求添加
    );
}

$_SESSION['cart'] = $cart;
$total_items = count($cart);
$total_price = 0;
foreach ($cart as $item) {
    $total_price += $item['quantity'] * $item['price'];
}
$_SESSION['total_items'] = $total_items;
$_SESSION['total_price'] = $total_price;

setcookie('cart', serialize($cart), time() + 3600 * 24 * 30, '/');
header('Location: cart.php');
?>
Copier après la connexion

Utilisez JavaScript pour implémenter l'interface utilisateur du panier

Dans le code ci-dessus, nous utilisons PHP pour exploiter les données du panier et stocker les données dans Cookie et $_SESSION. Mais nous devons également présenter ces données aux utilisateurs sous une forme visuelle. Pour ce faire, nous pouvons utiliser JavaScript pour créer l'interface utilisateur du panier.

Plus précisément, nous pouvons créer un nœud DOM dans la page du panier pour afficher la quantité, le prix total et d'autres informations du panier actuel. Les données du panier sont ensuite récupérées du cookie ou du serveur via le code JavaScript et présentées à l'utilisateur. Dans la page du panier, nous pouvons également fournir certaines fonctions, telles que l'augmentation ou la diminution du nombre d'articles dans le panier, la suppression d'un article et la mise à jour des données du panier dans Cookie et $_SESSION.

Exemple de code :

function update_cart() {
    var cart = {};
    if (getCookie('cart') != "") {
        cart = JSON.parse(getCookie('cart'));
    }
    var total_items = 0;
    var total_price = 0;
    for (var id in cart) {
        total_items += cart[id]['quantity'];
        total_price += cart[id]['quantity'] * cart[id]['price'];
    }
    document.getElementById('cart-total-items').innerHTML = total_items;
    document.getElementById('cart-total-price').innerHTML = total_price;
}
Copier après la connexion

Dans le code ci-dessus, nous passons l'objet getCookie() 函数从 Cookie 中获取购物车数据。然后,使用一个 for 循环来遍历 cart et calculons la quantité totale et le prix total de tous les articles du panier. Enfin, mettez à jour ces informations dans la page HTML.

Résumé

Cet article présente brièvement comment utiliser PHP et JavaScript pour implémenter la fonction d'ajout d'articles au panier sans vous connecter. Cette fonctionnalité est obtenue en stockant les données du panier dans un cookie, tout en utilisant JavaScript pour créer l'interface utilisateur du panier et gérer l'interaction de l'utilisateur. La mise en œuvre de cette fonction nécessite un certain degré de maîtrise à la fois de PHP et de JavaScript, et il faut également faire attention à certains problèmes de sécurité, comme l'injection XSS et CSRF.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

OWASP Top 10 PHP: Décrivez et atténue les vulnérabilités communes. OWASP Top 10 PHP: Décrivez et atténue les vulnérabilités communes. Mar 26, 2025 pm 04:13 PM

L'article traite des 10 meilleures vulnérabilités de l'OWASP dans les stratégies PHP et d'atténuation. Les problèmes clés incluent l'injection, l'authentification brisée et les XS, avec des outils recommandés pour surveiller et sécuriser les applications PHP.

PHP 8 JIT (juste à temps) Compilation: comment cela améliore les performances. PHP 8 JIT (juste à temps) Compilation: comment cela améliore les performances. Mar 25, 2025 am 10:37 AM

La compilation JIT de PHP 8 améliore les performances en compilant le code fréquemment exécuté en code machine, bénéficiant aux applications avec des calculs lourds et en réduisant les temps d'exécution.

Téléchargements de fichiers sécurisés PHP: prévention des vulnérabilités liées au fichier. Téléchargements de fichiers sécurisés PHP: prévention des vulnérabilités liées au fichier. Mar 26, 2025 pm 04:18 PM

L'article traite de la sécurisation des téléchargements de fichiers PHP pour éviter les vulnérabilités comme l'injection de code. Il se concentre sur la validation du type de fichier, le stockage sécurisé et la gestion des erreurs pour améliorer la sécurité de l'application.

Encryption PHP: cryptage symétrique vs asymétrique. Encryption PHP: cryptage symétrique vs asymétrique. Mar 25, 2025 pm 03:12 PM

L'article traite du cryptage symétrique et asymétrique en PHP, en comparant leur aptitude, leurs performances et leurs différences de sécurité. Le chiffrement symétrique est plus rapide et adapté aux données en vrac, tandis que l'asymétrique est utilisé pour l'échange de clés sécurisé.

Authentification PHP & amp; Autorisation: mise en œuvre sécurisée. Authentification PHP & amp; Autorisation: mise en œuvre sécurisée. Mar 25, 2025 pm 03:06 PM

L'article examine la mise en œuvre d'authentification et d'autorisation robustes dans PHP pour empêcher un accès non autorisé, détaillant les meilleures pratiques et recommandant des outils d'amélioration de la sécurité.

Limitation du taux de l'API PHP: stratégies de mise en œuvre. Limitation du taux de l'API PHP: stratégies de mise en œuvre. Mar 26, 2025 pm 04:16 PM

L'article traite des stratégies de mise en œuvre de la limitation du taux d'API en PHP, y compris des algorithmes comme un godet de jeton et un seau qui fuit, et en utilisant des bibliothèques comme Symfony / Rate-Limiter. Il couvre également la surveillance, l'ajustement dynamiquement des limites de taux et la main

Validation d'entrée PHP: meilleures pratiques. Validation d'entrée PHP: meilleures pratiques. Mar 26, 2025 pm 04:17 PM

L'article traite des meilleures pratiques pour la validation des entrées PHP pour améliorer la sécurité, en se concentrant sur des techniques telles que l'utilisation de fonctions intégrées, une approche de liste blanche et une validation côté serveur.

Protection PHP CSRF: comment empêcher les attaques du CSRF. Protection PHP CSRF: comment empêcher les attaques du CSRF. Mar 25, 2025 pm 03:05 PM

L'article traite des stratégies pour prévenir les attaques du CSRF dans PHP, notamment en utilisant des jetons CSRF, des cookies de même site et une bonne gestion de session.

See all articles