![]()
|
NAME="GENERATOR"
CONTENT="Modular DocBook HTML Stylesheet Version 1.7">
第 16 ç« PHP ã«ã‚ˆã‚‹ HTTP èªè¨¼PHPã«ã‚ˆã‚‹HTTPèªè¨¼ã®ãƒ•ックã¯ã€Apacheモジュールã¨ã—ã¦å®Ÿè¡Œã—ãŸæ™‚ã®ã¿ 有効ã§ã€CGI版ã§ã¯åˆ©ç”¨ã§ãã¾ã›ã‚“。Apache モジュールPHPスクリプトã«ãŠ ã„ã¦ã€header() 関数を使用ã—㦠"Authentication Required" メッセージをクライアントブラウザã«é€ã‚‹ã“ã¨ãŒå¯èƒ½ã§ã™ã€‚ ã“れã«ã‚ˆã‚Šã€ã‚¯ãƒ©ã‚¤ã‚¢ãƒ³ãƒˆãƒ–ラウザã«ãƒ¦ãƒ¼ã‚¶ãƒ¼åã¨ãƒ‘スワードを入力ã™ã‚‹ ウインドウãŒãƒãƒƒãƒ—アップ表示ã•れã¾ã™ã€‚一度ã€ãƒ¦ãƒ¼ã‚¶ãƒ¼ãŒãƒ¦ãƒ¼ã‚¶ãƒ¼å㨠パスワードを入力ã™ã‚‹ã¨ã€PHP スクリプトをå«ã‚€ãã® URL ã¯ã€æ¬¡å›žä»¥é™ã€ 定義済ã¿ã®å¤‰æ•° PHP_AUTH_USER, PHP_AUTH_PW, and PHP_AUTH_TYPEã«ãれãžã‚Œãƒ¦ãƒ¼ã‚¶ãƒ¼å〠パスワードã€èªè¨¼åž‹ã‚’入力ã—ã¦ã‚³ãƒ¼ãƒ«ã•れã¾ã™ã€‚ 定義済ã¿ã®å¤‰æ•°ã¯ã€é…列 $_SERVER ãŠã‚ˆã³ $HTTP_SERVER_VARS ã§ã‚¢ã‚¯ã‚»ã‚¹å¯èƒ½ã§ã™ã€‚ "Basic" èªè¨¼ã®ã¿ãŒã‚µãƒãƒ¼ãƒˆã•れã¦ã„ã¾ã™ã€‚詳細ã¯ã€ header()ã‚’å‚照下ã•ã„。
ページ上ã§ã‚¯ãƒ©ã‚¤ã‚¢ãƒ³ãƒˆèªè¨¼ã‚’強制ã™ã‚‹ã‚¹ã‚¯ãƒªãƒ—トã®ä¾‹ã‚’以下ã«ç¤ºã—ã¾ã™ã€‚
å˜ã« PHP_AUTH_USERãŠã‚ˆã³PHP_AUTH_PW を出力ã™ã‚‹ã®ã§ã¯ãªãã€ãƒ¦ãƒ¼ã‚¶ãƒ¼åã¨ãƒ‘ã‚¹ãƒ¯ãƒ¼ãƒ‰ã®æœ‰åŠ¹æ€§ã‚’ãƒã‚§ãƒƒã‚¯ã—ãŸã„㨠æ€ã†ã‹ã‚‚ã—れã¾ã›ã‚“。 ãã®å ´åˆã€ã‚¯ã‚¨ãƒªãƒ¼ã‚’データベースã«é€ã‚‹ã‹ã€ã‚ã‚‹ dbm ファイルä¸ã® ユーザーを調ã¹ã‚‹ã¨ã„ã£ãŸã“ã¨ã‚’ã™ã‚‹ã“ã¨ã«ãªã‚‹ã§ã—ょã†ã€‚ ãƒã‚°ã®ã‚ã‚‹ Internet Explorer ブラウザã«ã¯æ³¨æ„ã—ã¦ãã ã•ã„。ã“ã®ãƒ–ラ ウザã¯ã€ãƒ˜ãƒƒãƒ€ã®é †åºã«é–¢ã—ã¦ã¨ã¦ã‚‚ã†ã‚‹ã•ã„よã†ã§ã™ã€‚今ã®ã¨ã“ã‚〠HTTP/1.0 401 ヘッダã®å‰ã« WWW-Authenticate ヘッダをé€ã‚‹ã®ãŒåŠ¹æžœãŒã‚るよ ã†ã§ã™ã€‚ 誰ã‹ãŒå¾“æ¥ã®å¤–部機構ã«ã‚ˆã‚‹èªè¨¼ã‚’行ã£ã¦ããŸãƒšãƒ¼ã‚¸ã®ãƒ‘スワードを暴ã よã†ãªã‚¹ã‚¯ãƒªãƒ—トを書ãã“ã¨ã‚’防ããŸã‚ã«ã€ç‰¹å®šã®ãƒšãƒ¼ã‚¸ã«é–¢ã—ã¦å¤–éƒ¨èª è¨¼ãŒå¯èƒ½ã§ã‚ã‚‹å ´åˆã€PHP_AUTH 変数ã¯ã‚»ãƒƒãƒˆã•れã¾ã›ã‚“。ã“ã®å ´åˆã€å¤–部 èªè¨¼ã•れãŸãƒ¦ãƒ¼ã‚¶ãƒ¼ã‹ã©ã†ã‹ã‚’確èªã™ã‚‹ãŸã‚ã« REMOTE_USER変数ã€ã™ãªã‚ã¡ã€ $_SERVER['REMOTE_USER']を使用ã™ã‚‹ã“ã¨ãŒã§ãã¾ã™ã€‚
ã—ã‹ã—ã€ä¸Šè¨˜ã®æ©Ÿèƒ½ã‚‚ã€èªè¨¼ã‚’è¦æ±‚ã•れãªã„URLを管ç†ã™ã‚‹äººãŒåŒã˜ã‚µãƒ¼ãƒãƒ¼ ã«ã‚ã‚‹èªè¨¼ã‚’è¦ã™ã‚‹URLã‹ã‚‰ãƒ‘スワードを盗むã“ã¨ã‚’防ãã‚ã‘ã§ã¯ã‚りã¾ã› ん。 サーãƒãƒ¼ã‹ã‚‰ãƒªã‚¿ãƒ¼ãƒ³ã‚³ãƒ¼ãƒ‰401ã‚’å—ã‘ãŸéš›ã«ã€Netscape NavigatorãŠã‚ˆã³ Internet Explorerã¯å…±ã«ãƒãƒ¼ã‚«ãƒ«ãƒ–ラウザã®ã‚¦ã‚¤ãƒ³ãƒ‰ã‚¦ä¸Šã®èªè¨¼ã‚ャッシュ を消去ã—ã¾ã™ã€‚ã“ã®æ©Ÿèƒ½ã«ã‚ˆã‚Šã€ç°¡å˜ã«ãƒ¦ãƒ¼ã‚¶ãƒ¼ã‚’"ãƒã‚°ã‚¢ã‚¦ãƒˆ"ã•ã›ã€å¼· 制的ã«ãƒ¦ãƒ¼ã‚¶ãƒ¼åã¨ãƒ‘スワードをå†å…¥åŠ›ã•ã›ã‚‹ã“ã¨ãŒã§ãã¾ã™ã€‚ã“ã®æ©Ÿèƒ½ ã¯ã€"タイムアウト"付ãã®ãƒã‚°ã‚¤ãƒ³ã‚„ã€"ãƒã‚°ã‚¢ã‚¦ãƒˆ"ボタンã«é©ç”¨ã•れ㦠ã„ã¾ã™ã€‚
ã“ã®å‹•作ã¯ã€HTTP Basicèªè¨¼ã®æ¨™æº–ã«åŸºã¥ã„ã¦ã„ã¾ã›ã‚“。よã£ã¦ã€ã“ã®æ©Ÿ 能ã«ä¾å˜ã—ãªã„よã†ã«æ³¨æ„ã™ã‚‹å¿…è¦ãŒã‚りã¾ã™ã€‚Lynx ã«ã‚ˆã‚‹ãƒ†ã‚¹ãƒˆã®çµæžœã€ Lynx ã¯ã€èªè¨¼è¨¼æ˜Žæ›¸ã‚’ 401 サーãƒãƒ¼å¿œç”ã«ã‚ˆã‚Šã‚¯ãƒªã‚¢ã—ãªã„ã“ã¨ãŒæ˜Žã‚‰ ã‹ã«ãªã£ã¦ã„ã¾ã™ã€‚ã“ã®ãŸã‚ã€back を押ã—ã¦ã‹ã‚‰ foward ã‚’å†åº¦æŠ¼ã™ã“㨠ã«ã‚ˆã‚Šè¨¼æ˜Žæ›¸ã®è¦ä»¶ãŒå¤‰æ›´ã•れãªã„é™ã‚Šãƒªã‚½ãƒ¼ã‚¹ã‚’オープンã™ã‚‹ã“ã¨ãŒã§ ãã¾ã™ã€‚ã—ã‹ã—ã€ãƒ¦ãƒ¼ã‚¶ã¯'_'ã‚ーを押ã™ã“ã¨ã«ã‚ˆã‚Šèªè¨¼æƒ…å ±ã‚’ã‚¯ãƒªã‚¢ã™ã‚‹ ã“ã¨ãŒå¯èƒ½ã§ã™ã€‚ Microsoftã®IISサーãƒãƒ¼ã¨CGI版ã®PHPã®çµ„ã¿åˆã‚ã›ã§ã¯ã€ã“ã®æ©Ÿèƒ½ã¯ã€IIS ã®åˆ¶ç´„ã«ã‚ˆã‚Šä½¿ç”¨ã™ã‚‹ã“ã¨ãŒã§ããªã„ã¨ã„ã†ã“ã¨ã«ã‚‚注æ„ã—ã¦ä¸‹ã•ã„。
|