php より転載 中国語ユーザー 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,
他のページでは、次のタグ を通じて呼び出され、上記の 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 "ユーザーがキャンセルボタンを押した場合に送信するテキスト";
終了;
}
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" )
続行;
/* すべての .php3 ファイルを選択したので、$title="something";
と同様に、ファイル内の最初の行 (タイトル) を検索しましょう
そして上記のタイトル コンテンツを分離し、リンク テキストとして使用します*/
$linknm = "";
$fp=fopen($entry,"r");
while($buffer=fgets($fp, 4096))
{
$buffer = trim( $buffer);
// 検索しやすいように、ファイルの最初の行に各ファイルのタイトルを入れています
// ただし、変数名を変更すると *迷惑になる可能性があります
if (ereg( "title *= * "", $buffer))
{
/* タイトルのコンテンツを取得したので、
スペースの削除やそれに基づくその他の処理が可能です
$title = "何とか何とか』のような PHP コードで処理する必要があります" */
eval($buffer);
// 次に、リンクテキストをタイトルテキストとして表示します
$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 "戻る
n";
}
$title = "ファイルをアップロード";
include("include/header.inc");
if (empty($userfile) || $userfile=="none")
{
// 次のフォームを出力します
?>
ここに私たちの家族の写真がいくつかあります。この PHP スクリプトは実際に
作ることができます