ホームページ バックエンド開発 PHPチュートリアル PHP ショッピング カートの例_PHP チュートリアル

PHP ショッピング カートの例_PHP チュートリアル

Jul 21, 2016 pm 03:46 PM
php session コード 違い に相当 ショッピングカート 身元

//ショッピングカートセッション生成コード
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 までご連絡ください。

ホット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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

PHPとPython:2つの一般的なプログラミング言語を比較します PHPとPython:2つの一般的なプログラミング言語を比較します Apr 14, 2025 am 12:13 AM

PHPとPythonにはそれぞれ独自の利点があり、プロジェクトの要件に従って選択します。 1.PHPは、特にWebサイトの迅速な開発とメンテナンスに適しています。 2。Pythonは、データサイエンス、機械学習、人工知能に適しており、簡潔な構文を備えており、初心者に適しています。

PHPの未来:適応と革新 PHPの未来:適応と革新 Apr 11, 2025 am 12:01 AM

PHPの将来は、新しいテクノロジーの傾向に適応し、革新的な機能を導入することで達成されます。1)クラウドコンピューティング、コンテナ化、マイクロサービスアーキテクチャに適応し、DockerとKubernetesをサポートします。 2)パフォーマンスとデータ処理の効率を改善するために、JITコンパイラと列挙タイプを導入します。 3)パフォーマンスを継続的に最適化し、ベストプラクティスを促進します。

PHP対Python:違いを理解します PHP対Python:違いを理解します Apr 11, 2025 am 12:15 AM

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHPは、シンプルな構文と高い実行効率を備えたWeb開発に適しています。 2。Pythonは、簡潔な構文とリッチライブラリを備えたデータサイエンスと機械学習に適しています。

PHP:Web開発の重要な言語 PHP:Web開発の重要な言語 Apr 13, 2025 am 12:08 AM

PHPは、サーバー側で広く使用されているスクリプト言語で、特にWeb開発に適しています。 1.PHPは、HTMLを埋め込み、HTTP要求と応答を処理し、さまざまなデータベースをサポートできます。 2.PHPは、ダイナミックWebコンテンツ、プロセスフォームデータ、アクセスデータベースなどを生成するために使用され、強力なコミュニティサポートとオープンソースリソースを備えています。 3。PHPは解釈された言語であり、実行プロセスには語彙分析、文法分析、編集、実行が含まれます。 4.PHPは、ユーザー登録システムなどの高度なアプリケーションについてMySQLと組み合わせることができます。 5。PHPをデバッグするときは、error_reporting()やvar_dump()などの関数を使用できます。 6. PHPコードを最適化して、キャッシュメカニズムを使用し、データベースクエリを最適化し、組み込み関数を使用します。 7

PHPの現在のステータス:Web開発動向を見てください PHPの現在のステータス:Web開発動向を見てください Apr 13, 2025 am 12:20 AM

PHPは、現代のWeb開発、特にコンテンツ管理とeコマースプラットフォームで依然として重要です。 1)PHPには、LaravelやSymfonyなどの豊富なエコシステムと強力なフレームワークサポートがあります。 2)パフォーマンスの最適化は、Opcacheとnginxを通じて達成できます。 3)PHP8.0は、パフォーマンスを改善するためにJITコンパイラを導入します。 4)クラウドネイティブアプリケーションは、DockerおよびKubernetesを介して展開され、柔軟性とスケーラビリティを向上させます。

PHP対その他の言語:比較 PHP対その他の言語:比較 Apr 13, 2025 am 12:19 AM

PHPは、特に迅速な開発や動的なコンテンツの処理に適していますが、データサイエンスとエンタープライズレベルのアプリケーションには良くありません。 Pythonと比較して、PHPはWeb開発においてより多くの利点がありますが、データサイエンスの分野ではPythonほど良くありません。 Javaと比較して、PHPはエンタープライズレベルのアプリケーションでより悪化しますが、Web開発により柔軟性があります。 JavaScriptと比較して、PHPはバックエンド開発により簡潔ですが、フロントエンド開発のJavaScriptほど良くありません。

PHPの永続的な関連性:それはまだ生きていますか? PHPの永続的な関連性:それはまだ生きていますか? Apr 14, 2025 am 12:12 AM

PHPは依然として動的であり、現代のプログラミングの分野で重要な位置を占めています。 1)PHPのシンプルさと強力なコミュニティサポートにより、Web開発で広く使用されています。 2)その柔軟性と安定性により、Webフォーム、データベース操作、ファイル処理の処理において顕著になります。 3)PHPは、初心者や経験豊富な開発者に適した、常に進化し、最適化しています。

PHPの目的:動的なWebサイトの構築 PHPの目的:動的なWebサイトの構築 Apr 15, 2025 am 12:18 AM

PHPは動的なWebサイトを構築するために使用され、そのコア関数には次のものが含まれます。1。データベースに接続することにより、動的コンテンツを生成し、リアルタイムでWebページを生成します。 2。ユーザーのインタラクションを処理し、提出をフォームし、入力を確認し、操作に応答します。 3.セッションとユーザー認証を管理して、パーソナライズされたエクスペリエンスを提供します。 4.パフォーマンスを最適化し、ベストプラクティスに従って、ウェブサイトの効率とセキュリティを改善します。

See all articles