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 に割り当てます
// 関数の最後のパラメーターは、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 " 送信するテキストユーザーがキャンセルボタンを押した場合n";
終了;
}
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 "ようこそ 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 コンテンツは、
に基づいて削除できます。
は、$title = "blah blah" */
などの PHP コードで処理する必要があります。 ;
// 次に、リンク テキストをタイトル テキストとして表示します
$linknm = $title;
break;
}
}
fclose($fp);
if ( $entry ==basename($PHP_SELF) )
echo "$linknm";
else
echo "$linknm";
echo " | ";
}
$d->close();
echo "
";
終了;
}
}
if ( $cancelit )
{
// 訪問者が「キャンセル」ボタンを押すと、ホームページにリダイレクトされます
header ( "Location:front_2.php3" );
exit;
}
function do_upload () {
global $ userfile, $userfile_size, $userfile_name, $userfile_type;
グローバル $local_file, $error_msg;
グローバル $HTTP_REFERER;
if ( $userfile == "none" ) {
$error_msg = "アップロードするファイルが指定されていません。";
return;
}
if ( $userfile_size > 2000000 )
{
$error_msg = "申し訳ありませんが、ファイルが大きすぎます。";
return;
}
/ / 以下の書き込み権限がある場所ならどこでも...
$upload_dir = "photos";
$local_file = "$upload_dir/$userfile_name";
if ( file_exists ( $local_file ) ) {
$error_msg = "申し訳ありませんが、その名前のファイルはすでに存在します";
return;
};
//このファイル名とタイプのチェックのペアを使用して、ファイルの種類を判断することもできます: gif、jpg、mp3...
rename($userfile, $local_file);
echo "ファイルはアップロードされました
n ";
echo "戻る
n";
}
$title = "ファイルのアップロード";
include("include/header.inc");
if (empty($userfile)
$userfile= ="none")
{
// 次のフォームを出力します
?>
この PHP スクリプトは、私たちの家族の写真の一部です。複数のページに分割することで、
さらに改善できます。 while($entry = $d->read())
{
if (is_file(" photos/$entry"))
echo "n";
}
$d->close ();
?>
include("include/footer.inc");
?>
また、アップロードされたファイルを説明する入力要素を追加するフォームでファイルをアップロードすることもできます。この要素はファイルに保存され、上記のフォト ギャラリーのコードによって読み取られて表示されます。