Maison > développement back-end > tutoriel php > Exemple complet de classe de panier d'achat implémentée par php+pdo

Exemple complet de classe de panier d'achat implémentée par php+pdo

coldplay.xixi
Libérer: 2023-04-09 10:38:02
avant
3068 Les gens l'ont consulté

Exemple complet de classe de panier d'achat implémentée par php+pdo

L'exemple de cet article décrit la classe de panier d'achat implémentée par php+pdo. Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

<?php

session_start();

class Cart

{

  public $pdo = null;

  public function __construct($config)

  {

    $host = $config[&#39;host&#39;];

    $user = $config[&#39;user&#39;];

    $db = $config[&#39;db&#39;];

    $pwd = $config[&#39;pwd&#39;];

    if (empty($_SESSION[&#39;user_id&#39;])) {

      return show(0, &#39;请先登录&#39;);

    }

    try {

      $this->pdo = new PDO("mysql:host=$host;dbname=$db", "$user", "$pwd", array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION));

      $this->pdo->query("set names utf8");

    } catch (PDOException $e) {

      echo $e->getMessage();

    }

  }

  //添加商品到购物车

  public function add_cart($productid, $num)

  {

    $sql = "select price from shop_product where id=?";

    $stmt = $this->pdo->prepare($sql);

    $stmt->execute(array($productid));

    $data = $stmt->fetch(PDO::FETCH_ASSOC);

    $price = $data[&#39;price&#39;];

    $createtime = time();

    $sql = "select * from shop_cart where productid=? and userid=?";

    $stmt = $this->pdo->prepare($sql);

    $stmt->execute(array($productid, $_SESSION[&#39;user_id&#39;]));

    $data = $stmt->fetch(PDO::FETCH_ASSOC);

    if ($data) {

      $sql = "update shop_cart set num=num+? where userid=? and productid=?";

      $params = array($num, $_SESSION[&#39;user_id&#39;], $productid);

    } else {

      $sql = "insert into shop_cart(productid,num,userid,price,createtime) values(?,?,?,?,?)";

      $params = array($productid, $num, $_SESSION[&#39;user_id&#39;], $price, $createtime);

    }

    $stmt = $this->pdo->prepare($sql);

    $stmt->execute($params);

    $rows = $stmt->rowCount();

    return $rows ?

      show(1, &#39;ok&#39;, $rows) :

      show(0, &#39;fail&#39;);

  }

  //修改购买数量

  public function change_num($productid, $num)

  {

    $sql = "update shop_cart set num=? where userid=? and productid=?";

    $stmt = $this->pdo->prepare($sql);

    $stmt->execute(array($num, $_SESSION[&#39;user_id&#39;], $productid));

    $rows = $stmt->rowCount();

    return $rows ?

      show(1, &#39;ok&#39;, $rows) :

      show(0, &#39;fail&#39;);

  }

  //清空购物车

  public function clear_cart()

  {

    $sql = "delete from shop_cart where userid=?";

    $stmt = $this->pdo->prepare($sql);

    $this->pdo->execute(array($this->user_id));

    $rows = $stmt->rowCount();

    return $rows ?

      show(1, &#39;ok&#39;, $rows) :

      show(0, &#39;fail&#39;);

  }

  //从购物车中删除商品

  public function remove_cart($productid)

  {

    $sql = "delete from shop_cart where productid=? and userid=?";

    $stmt = $this->pdo->prepare($sql);

    $stmt->execute(array($productid, $_SESSION[&#39;user_id&#39;]));

    $rows = $stmt->rowCount();

    return $rows ?

      show(1, &#39;ok&#39;, $rows) :

      show(0, &#39;fail&#39;);

  }

}

//处理数据

function show($status, $message, $data = array())

{

  $result = array(

    &#39;status&#39; => $status,

    &#39;message&#39; => $message,

    &#39;data&#39; => $data

  );

  exit(json_encode($result));

}

//简单使用

$user = [

  &#39;host&#39; => &#39;&#39;,

  &#39;user&#39; => &#39;root&#39;,

  &#39;pwd&#39; => &#39;root&#39;,

  &#39;db&#39; => &#39;shop&#39;,

];

$productid = intval($_POST[&#39;productid&#39;]);

$num = intval($_POST[&#39;num&#39;]);

$cart = new Cart($user);

//添加到购物车

$cart->add_cart($productid, $num);

//删除指定的商品

$cart->remove_cart($productid);

//清空

$cart->clear_cart();

?>

Copier après la connexion

Recommandations d'apprentissage associées : Programmation PHP de l'entrée à la maîtrise

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!

Étiquettes associées:
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
Derniers numéros
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal