5. その他雑多な項目
5.1 画像の生成
PHP では画像の操作や加工が可能です。 GD ライブラリがインストールされている場合は、PHP を使用してイメージを生成することもできます。
Header("Content-type: image/gif");
$string=implode($argv," ");
$im = imagecreatefromgif("images/button1.gif");
$orange = ImageColorAllocate($im, 220, 210, 60);
$px = (imagesx($im)-7.5*strlen($string))/2;
ImageString($im,3,$ px,9,$string,$orange);
ImageGif($im);
ImageDestroy($im);
?>
(翻訳者注: 上記のコード スニペットにはコメントがありません。PHP を参照してください。手動画像処理機能部分)
このコードは以下のタグを通して他のページで呼び出され、上記のbutton.php3コードでテキスト値を取得し、この値を画像ファイルに追加します (上記のコードでは、画像ファイルはimages/button1.gifです)。最後にブラウザに出力します。フォーム フィールドでイメージ ボタンを使用したいが、ボタン上のテキストが変更されるたびに新しいイメージを再生成する必要がない場合は、この簡単な方法を使用してイメージ ファイルを動的に生成できます。
5.2 Cookie
PHP は HTTP ベースの Cookie をサポートしています。必要に応じて、通常の変数と同じように簡単に Cookie を使用できます。 Cookie はブラウザがクライアントに保存する情報であり、特定の PC 上の誰かがサイトを訪問したかどうか、訪問者のサイト上での軌跡などを知ることができます。 Cookie の使用の典型的な例は、ブラウザの設定のスクリーニングです。 Cookie は関数 setcookie() によって設定されます。 HTTP ヘッダーを出力する関数 header() と同様に、実際のコンテンツがブラウザーに出力される前に setcookie() を呼び出す必要があります。以下は簡単な例です:
if (empty($VisitedBefore))
{
// Cookie が設定されていない場合は、現在の時刻の値を Cookie に割り当てます
// 最後関数内の 1 つ パラメータは Cookie が保存された時間を宣言します
// この例では 1 年です
// time() 関数は 1970 年 1 月 1 日からの時間を秒単位で返します
SetCookie("VisitedBefore" ,time(), time()+(60*60*24*365));
}
else
{
// 視聴者の皆様、またお越しください
echo "こんにちは、おかえり
// Cookie を読み取り、
if ( (time() - $VisitedBefore) >= "(60*60*24*7)" )
echo "なぜ 1 週間もかかったのか戻ってきてください。もっと頻繁にここに来るべきですか?
";
}
?>
5.3 HTTP 認証に基づく
PHP が CGI モードで実行されている場合、HTTP 認証に基づくことはできません。関数 header() を使用して HTTP ヘッダーを送信して認証を強制すると、クライアント ブラウザーにユーザー名とパスワードを入力するためのダイアログ ボックスが表示されます。これら 2 つの変数は $PHP_AUTH_USER と $PHP_AUTH_PW に保存されており、これらの 2 つの変数を使用して正当性を検証し、エントリを許可できます。次の例では、ユーザー名とパスワードのペアを使用して tnc/nature へのユーザーのログインを認証します。
if(!isset($PHP_AUTH_USER))
{
Header("WWW-Authenticate: Basic realm=" My Realm"");
Header("HTTP/1.0 401 Unauthorized");
echo "ユーザーがキャンセルボタンを押した場合に送信するテキスト";
exit;
}
else
{
if ( !($PHP_AUTH_USER=="tnc" && $PHP_AUTH_PW=="nature")
)
{
// ユーザー名とパスワードのペアが間違っている場合は、再検証を強制します
Header("WWW- Authenticate : Basic realm="My Realm");
Header("HTTP/1.0 401 Unauthorized");
echo "エラー: $PHP_AUTH_USER/$PHP_AUTH_PW が無効です。";
exit;
}
else
{
echo "Welcome tnc!";
}
?>
実際、実際のリファレンスでは、上記のコード スニペットで明らかなユーザー名とパスワードのペアを使用することはほとんどありませんが、データベースまたは暗号化されたパスワード ファイルにアクセスします。
5.4 ファイルアップロード
ファイル機能を実装するには、PHP を使用できます。クライアントのブラウザは Netscape3 以降または IE3 以降である必要があることに注意してください。以下はこの機能の説明です:
( upload.html ):