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 ):
| n";
while( $entry = $d->read())
{
// ファイルがない場合は無視します
if ( !is_file($entry) )
continue;
/* ファイル名とファイル名を区切ります。拡大。 . は正規表現の特殊文字であるため、導入する必要があります */
list($filenm, $fileext) = split(".",$entry, 2);
// .php3 以外のファイルを無視します
if ( $fileext != "php3" )
continue;
/* すべての .php3 ファイルを選択したので、ファイルの最初の行 (タイトル) を検索しましょう
$title= と同様something";
上記のタイトル内容を分離してリンクテキストとして使用します */
$linknm = "";
$fp=fopen($entry,"r");
while($buffer=fgets( $fp, 4096 ))
{
$buffer = trim($buffer);
// 検索しやすいように、ファイルの最初の行に各ファイルのタイトルを入れています
// しかし、それが起こる可能性があります変数名を変更すると *トラブルが発生します
if (ereg("title *= *"", $buffer))
{
/* タイトルの内容を取得したので、スペースやその他の処理に基づいて
削除できますこれについては、
$title = "blah blah" */
eval($buffer);
// のように、PHP コードで処理する必要があります。すると、リンク テキストがタイトル テキストとして表示されます
$linknm = $title;
break;
}
}
fclose($fp);
if ( $entry ==basename($PHP_SELF) )
echo "$linknm";
else
echo "$linknm";
echo " " ";
}
$d->close();
echo "
exit;
}
}
if ( $cancelit )
{
// 訪問者が「キャンセル」ボタンを押すと、ホームページにリダイレクトされます
header ( "Location:front_2 .php3 " );
exit;
}
function do_upload () {
global $userfile, $userfile_size, $userfile_name, $userfile_type;
global $local_file, $error_msg;
global $HTTP_REFERER;
if ( $userfile == "none" ) {
$error_msg = "アップロードするファイルが指定されていません。";
return;
}
if ( $userfile_size > 2000000 )
{
$ error_msg = "申し訳ありませんが、ファイルが大きすぎます。";
return;
}
// 以下の書き込み権限がある場所ならどこでも...
$upload_dir = "写真";
$local_file = " $upload_dir /$userfile_name";
if ( file_exists ( $local_file ) ) {
$error_msg = "申し訳ありませんが、その名前のファイルは既に存在します";
return;
};
//ファイル名とタイプのチェックを使用して、ファイルの種類を判断します: gif、jpg、mp3...
rename($userfile, $local_file);
echo "ファイルはアップロードされました
n";
echo "< A HREF="$HTTP_REFERER">戻る
n";
}
$title = "ファイルをアップロード";
include("include/header. inc");
if (empty($userfile)
$userfile=="none")
{
// 次のフォームを出力します
?>
この PHP スクリプトは、複数のページに分割することでさらに改善できます
。