検索
ホームページバックエンド開発PHPチュートリアルPHP ショッピング カートの例_PHP チュートリアル
PHP ショッピング カートの例_PHP チュートリアルJul 21, 2016 pm 03:46 PM
phpsessionコード違いに相当ショッピングカート身元

//ショッピングカートセッション生成コード
if(! $session && ! $scid) {
/*
session は各ショッピングカートの ID 番号に相当し、識別するためにのみ使用されます。 one ショッピング カート ID 番号は各カートの名前とみなすことができます
ショッピング カートの ID とセッション値の両方が存在しない場合、新しいショッピング カートが生成されます
*/
$session = md5(uniqid(rand) ()));
/*
一意のショッピング カート セッション番号を生成します
rand() が最初に乱数を生成し、次に uniqid() が乱数に基づいて一意の文字列を生成し、最後に文字列を md5 で実行します
*/
SetCookie(scid, $session, time() + 14400);
/*
ショッピングカートのクッキーを設定する
変数名: scid ($記号が抜けているのかな? =》訂正: scid、「」を追加)
変数値: $session
有効時間: 現在時刻 + 14400 秒 (4 時間以内)
setcookie 関数の詳細な使用方法については、PHP マニュアルを参照してください~
*/
}
class Cart { //ショッピングを開始カートクラス
function check_item( $table, $session, $product) {
/*
チェック項目 (テーブル名、セッション、アイテム)
*/
$query = SELECT * FROM $table WHERE session= ' $session' AND product=' $product' ;
/*
「テーブル」の「ショッピングカート」に「商品」があるかどうかを確認します
つまり、商品がショッピングカートに入れられているかどうかを確認します
*/
$ result = mysql_query( $query);
if(! $result) {
return
}
/*
クエリが失敗しました
*/
$numRows = mysql_num_rows( $result); {
return 0;
/*
見つからない場合は 0 を返す
*/
} else {
$row->quantity;
見つかった場合は returnアイテムの数量
mysql_fetch_object 関数 (以下で使用します) を説明する必要があります:
[mysql_fetch_object() は mysql_fetch_array() に似ていますが、1 つの違いがあります - 配列の代わりにオブジェクトを返します。】
上記の文はPHPマニュアルから引用したものですが、非常にわかりやすいはずです~
簡単に言うと、レコード内の特定のフィールドを取得するには、配列のような添字を使用する代わりに「->」を使用する必要があります
* /
}
}
function add_item( $table, $session, $product, $quantity) {
/*
新しいアイテムを追加 (テーブル名、セッション、アイテム、数量)
*/
$qty = $this-> ;check_item( $table, $session, $product);
/*
上記の関数を呼び出して、まずこのタイプのアイテムが車に置かれているかどうかを確認します
*/
if( $qty == 0) {
$query = INSERT INTO $table (セッション、製品、数量) VALUES ;
$query .= (' $session', ' $product', ' $quantity') ;
mysql_query( $query);車にある場合は、車に商品を追加します*/
} else {
$quantity += $qty //ある場合は、元の基準で数量を増やします
$query = UPDATE $table SETquantity=' $数量' WHERE session =' $session' ;
$query .= product=' $product' ;
/*
そしてデータベースを変更します
*/
}
}
function delete_item( $ table, $session, $product) {
/*
項目 (テーブル名、セッション、項目) を削除します
*/
$query = DELETE FROM $table WHERE session=' $session' AND product=' $product' ; mysql_query( $query) ;
/*
ショッピングカート内のこのタイプのアイテムを削除します
*/
}
functionmodify_quantity($table, $session, $product, $quantity) {
/*
アイテム数量を変更します(テーブル)名前、セッション、品目、数量)
*/
$query = UPDATE $table SETquantity=' $quantity' WHERE session=' $session' ;
$query .= AND product=' $product' ; query);
/*
商品の数量をパラメータの値に変更します
*/
}
function clear_cart( $table, $session) {
/*
ショッピングカートをクリアします (何も言いません)
* /
$query = DELETE FROM $table WHERE session=' $session' ;
mysql_query( $query);
function cart_total( $table, $session) {
/*
カート内の商品の合計金額
* /
$query = SELECT * FROM $table WHERE session =' $session' ;
$result = mysql_query( $query);
/*
まず車内のアイテムをすべて取り出します
*/
if(mysql_num_rows( $ result) > 0) {
while( $row = mysql_fetch_object ( $result)) {
/*
アイテムの数量が > 0 の場合、価格を 1 つずつ判断して計算します
*/
$query = SELECT価格 FROM 在庫 WHERE product=' $row->product' ;
$invResult = mysql_query( $query)
/*
在庫テーブルから商品の価格を検索します
*/
$row_price = mysql_fetch_object( $invResult );
$total += ( $row_price->price * $ row->quantity)
/*
合計価格 += 商品の価格 * 商品の数量
(誰でも理解できるはずです: ) )
*/
}
}
return $total; //合計価格を返す
}
function display_contents( $table, $session) {
/*
車内のすべてのアイテムに関する詳細情報を取得する
*/
$count = 0;
/*
項目の数を数える
この変数は単に項目の数を数えるだけではなく、さらに重要なことに、各項目を区別するために戻り値配列の添字として使用されることに注意してください。
*/
$query = SELECT * FROM $table WHERE session=' $session' ORDER BY id ;
$result = mysql_query( $query)
/*
まず車の中のアイテムをすべて取り出します
*/
while( $ row = mysql_fetch_object( $result)) {
/*
各アイテムの詳細情報を個別に取得します
*/
$query = SELECT * FROM inventory WHERE product=' $row->product' ;
$result_inv = mysql_query ( $query);
/*
在庫テーブルからアイテムに関する関連情報を検索します
*/
$row_inventory = mysql_fetch_object( $result_inv);
$contents[product][ $count] = $row_inventory->product ;
$contents[価格][ $count] = $row_inventory->価格;
$contents[数量][ $count] = $row->数量;
$contents[合計][ $count] = ( $ row_inventory->price * $row->quantity);
$contents[description][ $count] = $row_inventory->description;
アイテムに関するすべての詳細情報を $contents 配列に入れます
$内容は 2 次元配列です
最初の添字セットは、各商品に関するさまざまな情報 (商品名、価格、数量など) を区別します
2 番目の添字セットは、さまざまな商品を区別します (これは前の定義された $count 変数)
*/
$count++; // アイテムの数を 1 つ増やします (つまり、次のアイテム)
}
$total = $this->cart_total( $table, $session); [final] = $total;
同時に上記のcart_total関数を呼び出し、合計金額を計算して$contents配列に入れます
*/
return $contents;
配列を返します。 */
}
function num_items( $table, $session) {
/*
項目タイプの合計数を返します (つまり、2 つの同一の項目を 1 つとして数えるのはナンセンスです - -!)
*/
$query = SELECT * FROM $table WHERE session=' $session' ;
$num_rows = mysql_num_rows( $result);
内のすべての項目を取り出します。 car を実行し、操作の影響を受けるものを取得します。 データベースの行数、つまりアイテムの総数 (何も言う必要はありません)
*/
}
function quant_items( $table, $session) {
/*
を返しますすべての項目の合計数 (つまり、2 つの同一のものは 2 つの項目としてカウントされます - #)
*/
$quant = 0 // 項目の合計数
$query = SELECT * FROM $table WHERE session=' $session; ' ;
$result = mysql_query( $query);
while( $ row = mysql_fetch_object( $result)) {
/*
各項目を 1 つずつ取り出します
*/
$quant += $row->quantity ; // アイテムの数量を合計に加算します
}
return $quant; // 合計金額を返します
}
}



http://www.bkjia.com/PHPjc/320144.html

www.bkjia.com

tru​​e

http://www.bkjia.com/PHPjc/320144.html

技術記事 //ショッピングカートセッション生成コード if(! $session ! $scid) { /* セッションは各ショッピングカートを区別するために使用され、各カートの ID 番号に相当します。 scid はショッピングカートの ID 番号を識別するためにのみ使用されます。できる...
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
php怎么把负数转为正整数php怎么把负数转为正整数Apr 19, 2022 pm 08:59 PM

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

php怎么实现几秒后执行一个函数php怎么实现几秒后执行一个函数Apr 24, 2022 pm 01:12 PM

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php字符串有没有下标php字符串有没有下标Apr 24, 2022 am 11:49 AM

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php怎么除以100保留两位小数php怎么除以100保留两位小数Apr 22, 2022 pm 06:23 PM

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

php怎么读取字符串后几个字符php怎么读取字符串后几个字符Apr 22, 2022 pm 08:31 PM

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

php怎么根据年月日判断是一年的第几天php怎么根据年月日判断是一年的第几天Apr 22, 2022 pm 05:02 PM

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

php怎么查找字符串是第几位php怎么查找字符串是第几位Apr 22, 2022 pm 06:48 PM

查找方法:1、用strpos(),语法“strpos("字符串值","查找子串")+1”;2、用stripos(),语法“strpos("字符串值","查找子串")+1”。因为字符串是从0开始计数的,因此两个函数获取的位置需要进行加1处理。

php怎么替换nbsp空格符php怎么替换nbsp空格符Apr 24, 2022 pm 02:55 PM

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\&nbsp\;||\xc2\xa0)/","其他字符",$str)”语句。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン