php cookiesの使い方の勉強メモを共有_PHPチュートリアル
PHP setcookie() 関数は、HTTP Cookie をクライアントに送信します。 Cookie は、サーバーによってブラウザに送信される変数です。 Cookie は通常、サーバーがユーザーのコンピュータに埋め込む小さなテキスト ファイルです。この Cookie は、コンピュータがブラウザを通じてページを要求するたびに送信されます。 Cookie の名前は、同じ名前の変数として指定されます。たとえば、送信される Cookie の名前が「name」の場合、Cookie の値を含む $user という名前の変数が自動的に作成されます。
Cookie は、他の出力が送信される前に割り当てる必要があります。この関数は、成功した場合は true を返し、そうでない場合は false を返します。
1 setcookie(名前、値、有効期限、パス、ドメイン、安全)
•名前は必須です。クッキーの名前を指定します。
•値は必須です。 Cookieの値を指定します。
•expire オプション。 Cookieの有効期間を指定します。
•パスはオプションです。 Cookie のサーバー パスを指定します。
•ドメイン オプション。 Cookieのドメイン名を指定します。
•secure オプション。 Cookie が安全な HTTPS 接続を介して送信されるかどうかを指定します。
「user」という名前の Cookie の値には、$HTTP_COOKIE_VARS["user"] または $_COOKIE["user"] を通じてアクセスできます。 Cookie を送信すると、Cookie の値は自動的に URL エンコードされます。 URL デコードは受信時に行われます。これが必要ない場合は、代わりに setrawcookie() を使用できます。
例、PHPの設定とCookieの取得
setcookie('mycookie','value');
//関数プロトタイプ: int setcookie(文字列名, 文字列値, int 有効期限, 文字列パス, 文字列ドメイン, int secure)
echo($mycookie);
echo($HTTP_COOKIE_VARS['mycookie']);
echo($ _COOKIE['mycookie']);
Cookieを削除する
(1) name パラメータのみを指定して setcookie() を呼び出します。
(2) 有効期限を time() または time-1 に設定します。
setcookie('mycookie') または setcookie('mycookie',''); ; または setcookie( "mycookie",false);
//setcookie('mycookie','',time()-3600);
echo($HTTP_COOKIE_VARS['mycookie']);
print_r($_COOKIE);
表現したい時、分、秒、月、日、年を順番に mktime() に渡すだけで、
mktime() は 1970 年 1 月 1 日からの合計秒数を返します。
Y2K 問題をシミュレーションする必要がある場合:
setcookie('name','value',$y2k) ;
setcookie( 'name', 'value', time+3600);
setcookie('name', 'value', $y2k, '~/myhome', '.domain.com');
setcookie ("var_name", "var_value", $expire); // 名前を設定します var_name の Cookie に有効期限を設定します
setcookie ("var_name_expire", $expire, $expire) // 次に、var_name の有効期限を知ることができるように、有効期限を Cookie に設定します。
Cookie を送信すると、Cookie の値は自動的に URL エンコードされます。 URL デコードは受信時に行われます。
これが必要ない場合は、代わりに setrawcookie() を使用できます。
例、ユーザーのログイン情報を保存するCookie
1. データベース接続設定ページ: connectvars.php
define('DB_HOST', 'localhost');
//ユーザー名
define( 'DB_USER', 'root ');
//パスワード
define('DB_PASSWORD', '19900101');
//データベース名
define('DB_NAME','test') ;
?>
//插入连接数据库的相关信息
require_once 'connectvars.php';
$error_msg = "";
//判断用户是否已经设置cookie,如果未设置$_COOKIE['user_id']时,执行以下代码
if(!isset($_COOKIE['user_id'])){
if(isset($_POST['submit'])){//判断用户是否提交登录表单,如果是则执行如下代码
$dbc = mysqli_connect(DB_HOST,DB_USER,DB_PASSWORD,DB_NAME);
$user_username = mysqli_real_escape_string($dbc,trim($_POST['username']));
$user_password = mysqli_real_escape_string($dbc,trim($_POST['password']));
if(!empty($user_username)&&!empty($user_password)){
//MySql中的SHA()函数用于对字符串进行单向加密
$query = "SELECT user_id, username FROM mismatch_user WHERE username = '$user_username' AND "."password = SHA('$user_password')";
//用用户名和密码进行查询
$data = mysqli_query($dbc,$query);
//若查到的记录正好为一条,则设置COOKIE,同时进行页面重定向
if(mysqli_num_rows($data)==1){
$row = mysqli_fetch_array($data);
setcookie('user_id',$row['user_id']);
setcookie('username',$row['username']);
$home_url = 'loged.php';
header('Location: '.$home_url);
}else{//若查到的记录不对,则设置错误信息
$error_msg = 'Sorry, you must enter a valid username and password to log in.';
}
}else{
$error_msg = 'Sorry, you must enter a valid username and password to log in.';
}
}
}else{//如果用户已经登录,则直接跳转到已经登录页面
$home_url = 'loged.php';
header('Location: '.$home_url);
}
?>
Msimatch - Log In
if(empty($_COOKIE['user_id'])){
echo '
'.$error_msg.'
';?>
/**ログインしたページでは、$_COOKIE['username']、
* $_COOKIE['user_id'] などのユーザーの Cookie を使用してデータベースにクエリを実行したり、さまざまな操作を行うことができます。*/?>
コードは次のとおりです:
/**Cookieのログアウトページ* /
if (isset($_COOKIE['user_id'])){
//システムによって削除できるように、各 Cookie の有効期限を過去の時刻に設定します。時刻は秒単位です
setcookie( 'user_id',' ',time()-3600);
setcookie('username','',time()-3600);
}
header('Location:'.$home_url);
?>
2: setcookie の例
単純: setcookie("mycookie","value_of_mycookie");
有効期限付き: setcookie("withExpire","Expire_in_1_hour",time()+3600);
すべてを含む: setcookie("FullCookie", "Full_cookie_value", time+3600,"/forum","www.jb51.net",1);
3: クッキーのいくつかの特徴
Cookie はパス指向です。デフォルトのパス属性では、WEB サーバー ページは自動的に現在のパスをブラウザーに渡します。
1 つのディレクトリ ページに設定された Cookie が強制的に使用されます。別のディレクトリ ページ内は表示されません。
http://www.bkjia.com/PHPjc/825079.htmlwww.bkjia.com
true
http://www.bkjia.com/PHPjc/825079.html
技術記事
PHP の setcookie() 関数は、HTTP Cookie をクライアントに送信します。 Cookie は、サーバーによってブラウザに送信される変数です。 Cookie は通常、サーバーがユーザーのコンピュータに埋め込む小さなテキスト ファイルです...

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

CakePHP はオープンソースの MVC フレームワークです。これにより、アプリケーションの開発、展開、保守がはるかに簡単になります。 CakePHP には、最も一般的なタスクの過負荷を軽減するためのライブラリが多数あります。

このチュートリアルでは、PHPを使用してXMLドキュメントを効率的に処理する方法を示しています。 XML(拡張可能なマークアップ言語)は、人間の読みやすさとマシン解析の両方に合わせて設計された多用途のテキストベースのマークアップ言語です。一般的にデータストレージに使用されます
