ホームページ >バックエンド開発 >PHPチュートリアル >PHPとMySQLの基本チュートリアル(3)_PHPチュートリアル
Cookie を使用してユーザーを追跡し、識別します
ブラウザに保存されたコンテンツを見てみましょう。 IE5 を使用している場合は、Windows ディレクトリに Cookie ディレクトリがあり、ファイル名は wudong@15秒[1].txt のようになります。これらはブラウザが値を保存するために使用する Cookie です。 。以前のバージョンの IE では Cookie の内容を表示できましたが、現在は内容がエンコードされています。ブラウザは Web ページを取得する前に、まずそのページのドメイン名が Cookie に存在するかどうかを確認し、一致するものがあれば、ブラウザはまず一致する Cookie をサーバーに送信し、次に送信された Cookie を受け入れて処理します。サーバーページによって。
Cookie アプリケーションの例を見てみましょう。Amazon.com に接続すると、ブラウザは最初のページを受け入れる前に、以前に設定した Cookie の内容を Amazon に送信します。次に、Amazon.com は送信されたコンテンツをチェックして、データベースに関連する情報があるかどうかを確認した後、カスタマイズされたページを作成して送信します。
Cookieに値を割り当てる
著者:ヤンメイコンピレーション この記事のクリック数:127
サーバーがクライアントのブラウザにコンテンツを送信する前に、Cookieに値を割り当てる必要があります。これを行うには、Cookie 設定を < HEAD>
setcookie("CookieID", $USERID)> に配置する必要があります。関数には、カンマで区切られた合計 6 つのパラメーターがあります。
Cookie の名前は文字列です (例: "CookieID" )。コロン、カンマ、スペースを間に入れることはできません。このパラメータは必須ですが、他のパラメータはすべてオプションです。このパラメータのみを指定した場合、Cookie は削除されます。
Cookie の値は通常、$USERID などの文字列変数です。 ?? を割り当てて値の設定をスキップすることもできます。
クッキーの有効期限が近づいてきました。省略した場合 (または値 0 を割り当てた場合)、Cookie はこのセッションの終了時に期限切れになります。このパラメータには、「24-Nov-99 08:26:00」のように、DD-Mon-YY HH:MM:SS で表される絶対時刻を指定できます。より一般的に使用されるのは、相対時間を設定することです。これは、time() 関数または mktime 関数を通じて実現されます。たとえば、time()+3600 を指定すると、Cookie は 1 時間後に期限切れになります。
Cookie を照合するために使用されるパス。サーバー上に同じ名前の Cookie 設定が複数ある場合、このパラメータは混乱を避けるために使用されます。 「/」パスを使用すると、このパラメータを省略した場合と同じ効果があります。 Netscape の Cookie 定義ではパスの前にドメイン名が置かれますが、PHP ではその逆であることに注意してください。
サーバーのドメイン名は、Cookie の照合にも使用されます。サーバーのドメイン名の前にドット (.) を置く必要があることに注意してください。例: ".friendshipcenter.com" 。 3 つ以上の点が存在しない限り、このパラメータは受け入れられないためです。
Cookieのセキュリティレベルは整数です。 1 は、この Cookie が「安全な」ネットワーク経由でのみ送信できることを意味します。 0 または省略された場合は、どのタイプのネットワークでも受け入れられることを意味します。
Cookieと変数
Author: Yangmei Compilation この記事のクリック数: 127
PHPスクリプトがクライアントのブラウザからCookieを抽出すると、自動的に変数に変換されます。例: CookieID という名前の Cookie は変数 $CookieID になります。
Cookie の内容は HTTP_COOKIE_VARS 配列で報告されます。また、この配列と Cookie の名前を通じて指定された Cookie 値にアクセスすることもできます:
print $HTTP_COOKIE_VARS。 [CookieID];
すべてのユーザーを覚えてください
著者: Yangmei がこの記事を編集しました クリック数: 127
上記の submitform.php3 ファイルを見てください。その機能は、顧客の名前をデータベースに追加することです。それに何かを加えたい。各ユーザーに一意のユーザー ID を割り当て、この ID を Cookie に入れて、ユーザーが Web サイトにアクセスするたびに、Cookie とその中のユーザー ID を通じてそのユーザーが誰であるかを知ることができるようにしたいと考えています。
MySQL は、各新しいレコードに自動的に番号を割り当てるように設定できます。この番号は 1 から始まり、その後は毎回自動的に 1 ずつ増加します。 1 行の SQL ステートメントで、このようなフィールドをデータ テーブルに簡単に追加できます。これを USERID と呼びます:
ALTER TABLE dbname
ADD COLUMN
USERID INT(11) NOT NULL
PRIMARY KEY AUTO_INCREMENT;このフィールドにはいくつかの特別な設定を行いました。まず、「INT(11)」によってその型を 11 ビット整数として定義し、次に「NOT NULL」キーワードを使用してこのフィールドの値が NULL にならないようにし、次に「PRIMARY KEY」を使用してインデックスとして設定します。フィールドなので、検索が高速になります。最後に、「AUTO_INCREMENT」により、自動的にインクリメントされるフィールドとして定義されます。
ユーザーの名前がデータベースに挿入されたら、ブラウザーに Cookie を設定します。このときに使用されるのは、先ほど説明した USERID フィールドの値です:
< ?php
mysql_connect (localhost, username, password); INTO テーブル名 (" first_name, last_name)
VALUES ('$first_name', '$last_name')
");
setcookie("CookieID",
mysql_insert_id(),
time()+94608000,
"/" ); /* Cookie は 3 年後に期限切れになります*/
?>
PHP 関数 mysql_insert_id() は、最後の INSERT クエリが実行された後に AUTO_INCREMENT で定義されたフィールドの値を返します。このように、ブラウザの Cookie をクリアしない限り、ウェブサイトは永久にあなたを「記憶」します
Cookie を読む
Author: Yangmei Compilation この記事のクリック数: 127
Amazon のようなものを書きましょう。 com がスクリプトを実行しました。まず、PHP スクリプトはクライアントのブラウザが Cookie を送信したかどうかを確認し、送信されている場合はユーザーの名前が表示されます。 Cookieが見つからない場合は、顧客に名前の登録を求めるフォームを表示し、データベースに追加して、顧客の閲覧中にCookieを設定します。
まず、Cookie の内容を表示します:
< ?php
print $CookieID;>
次に、名前を表示します:
< php
mysql_connect (パスワード);
mysql_select_db (データベース名);
$selectresult = mysql_query ("SELECT * FROM テーブル名
WHERE USERID = '$CookieID'
"); ql_fetch_array ($selectresult) ;
echo "ようこそ", $row[first_name], "!";
以上です。私には判断力がありませんので、完成させるのはあなたにお任せください
http://www.bkjia.com/PHPjc/315410.html
www.bkjia.com
true
http://www.bkjia.com/PHPjc/315410.html
技術記事
Cookie を使用してユーザーを追跡および識別する ブラウザーに保存されたコンテンツを見てみましょう。 IE5 を使用している場合、Windows ディレクトリに大量のテキストを含む Cookie ディレクトリがあります...