ホームページ > php教程 > php手册 > 5. PHPのその他の機能

5. PHPのその他の機能

WBOY
リリース: 2016-06-13 12:44:10
オリジナル
846 人が閲覧しました


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 マニュアルの画像処理関数のセクションを参照してください) )

このコードは、次のタグ 5. 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 ):





ファイルをアップロード






ENCTYPE="multipart/form-data" METHOD=POST>


NAME="MAX_FILE_SIZE" VALUE="2000000">


NAME="uploadfile" SIZE="24" MAXLENGTH="80">






NAME="送信"> 


NAME="cancelit">




(ファイルのアップロード中に

わずかな遅延が発生する場合があります。)








下は処理上の文章:

( receiver.php3 ):


関数 do_upload ()

{

global $uploadfile, $uploadfile_size;

global $local_file, $error_msg;

if ( $uploadfile == "none" )

{

$error_msg = 「アップロードするファイルが指定されていません。」;

return;

}

if ( $uploadfile_size > 2000000 )

{

$error_msg = 「申し訳ありませんが、ファイルが大きすぎます。」;

return ;

}

$the_time = time ();

// 你必要对以下目录有書权限

$upload_dir = "/local/アップロード";

$local_file = "$upload_dir/$the_time";

if ( file_exists ( '$local_file' ) )

{

$ seq = 1;

while ( file_exists ( "$upload_dir/$the_time$seq" ) ) { $seq ; }

$local_file = "$upload_dir/$the_time$seq";

};

rename ( $uploadfile, $local_file );

display_page ();

}

function display_page ()

{

// ここは你的页面内容

}





php3 スクリプトの受信






if ( $error_msg ) { echo "$error_msg

"; 
}

if ( $sendit )

{

do_upload ();

}

elseif ( $cancelit )

{

header ( "Location: $some_other_script" );

exit;

}

else

{

some_other_func ();

}

?>







5.5 常用関数



私達はこれらの常用関数を見てみましょう。



Array





array - 配列を生成

count - 配列要素の数

sort - 配列のソート。他にもいくつかのソート関数が利用可能です。

list - 配列要素のリストを表示します。

each - 次のキーと値のペアを返します。

current - 戻り値現在の配列要素

next,prev - 現在の配列要素の前後のポインターを返します







日付と時刻



checkdate - 日付/時刻形式を確認します

date - 日付/時刻形式を生成します

time - 現在の時刻情報

strftime - 日付/時刻の形式



ディレクトリ、ファイル システム



chdir - ディレクトリの変更

dir - ディレクトリ カテゴリ

opendir、readdir、closedir - ディレクトリを開く、読み取る、閉じる

fopen、fclose - ファイルを開く、閉じる

fgets、fgetss - コンテンツを 1 行ずつ読み取る

file - ファイル全体を配列変数に読み込みます



正規表現



ereg - 正規表現と一致します

eregi - 大文字と小文字を区別せずに正規表現と一致します

ereg_replace - 正規表現と一致し、置換します

eregi_replace - 大文字と小文字を区別しない正規表現と一致し、置換します

split - 分割ルールに従って文字列を配列形式で保存します






String



AddSlashes - を使用しますスラッシュを追加した後の文字列

echo - 1 つ以上の文字列を出力します

join、implode - 配列要素を文字列に結合します

htmlentities、htmlspecialchars - HTML 特殊文字を HTML に変換しますタグ形式

split - ルールに従って文字列を分割し、配列形式に格納します

5.6 サンプル ホームページを拡張します



いくつかを使用します上記の機能とアイデアを使用して、サンプル ホームページにさらに動的なコンテンツを追加します。各ページの上部にナビゲーション バーを追加し、同時に現在のページがリンクによって自動的に表示されないようにすることができます。また、音楽、画像、その他のファイルをアップロードしてページを自動的に更新するためのユーザー確認フォームを追加することもできます。
ナビゲーション バー



は、実際には footer.inc ファイルにコードを追加しています。 Web サイト内のサフィックス .php3 を持つすべてのファイルがナビゲーション バーに表示されると仮定すると、次のコードは include/navbar.inc として保存されます:


/* 出力ナビゲーション バーを表示し、現在のページを除くサイト内のすべての .php3 ファイルをリンクします */

# ディレクトリを読み取ります

$d = dir("./");

echo "

| 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 "

n";

?>



写真集



画像ファイルが配置されるディレクトリを維持するために、HTTP ベースの認証、ファイル システム関数、およびファイル アップロード関数を参照します。このディレクトリ内のすべての写真をリストするページを作成する必要があります。



ファイルアップロード


include("include/common.inc");

//ここで別のユーザー検証を実行します。

if(!isset($PHP_AUTH_USER))

{

Header("WWW-Authenticate: Basic realm="$MySiteName"") ;

Header("HTTP/1.0 401 Unauthorized");

echo "申し訳ありませんが、ファイルをアップロードする権限がありませんn";

exit;

}

else

{

if ( !($PHP_AUTH_USER==$MyName && $PHP_AUTH_PW==$MyPassword ) )

{

// ユーザー名とパスワードのペアが間違っている場合は、再認証を強制します

Header("WWW-Authenticate: Basic realm="My Realm"");

Header ( "HTTP/1.0 401 Unauthorized");

echo "エラー : $PHP_AUTH_USER/$PHP_AUTH_PW が無効です。

";

終了;

}

}

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")

{

// 次のフォームを出力します

?>

" ENCTYPE= "multipart/form-data"
METHOD=POST>



MAXLENGTH="80">












(
アップロード中に若干の遅れが生じる場合があります)
< ;/I>


} else {

if ( $error_msg ) { echo " $error_msg


}

if ( $sendit ) {

do_upload ();

}

}

include("include/footer.inc");

?>



フォトギャラリー






include("include/common.inc");

$title = "ギャラリー";

include("include/header. inc");

?>



この PHP スクリプトは、私たちの家族の写真の一部です。複数のページに分割することで、

さらに改善できます。 while($entry = $d->read())

{

if (is_file(" photos/$entry"))

echo "n";

}

$d->close ();

?>


include("include/footer.inc");

?>



また、アップロードされたファイルを説明する入力要素を追加するフォームでファイルをアップロードすることもできます。この要素はファイルに保存され、上記のフォト ギャラリーのコードによって読み取られて表示されます。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のおすすめ
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート