注意: CGI 時加上的位置中,會忽略組 Cookie

文章翻譯 文章翻譯
文章編號: 176113 - 檢視此文章適用的產品。
我們強烈建議所有使用者都升級到 Microsoft 網際網路資訊服務 (IIS) 7.0 版 Microsoft Windows Server 2008 上執行。 IIS 7.0 大幅提升網頁基礎結構的安全性。如需有關 IIS 與安全性相關的主題請造訪下列的 Microsoft Web 網站:
http://www.microsoft.com/technet/security/prodtech/IIS.mspx
如需有關 IIS 7.0 的詳細資訊,請造訪下列 Microsoft 網站]:
http://www.iis.net/default.aspx?tabid=1
全部展開 | 全部摺疊

在此頁中

徵狀

當 CGI 應用程式傳送具有"302 物件 Moved 」 回應一個設定 Cookie 標頭和位置標頭時,網際網路資訊伺服器 (IIS) 會忽略 Cookie 標頭。

解決方案

這種行為是在違規的 CGI 規格哪些狀態"不是伺服器指示詞的任何標頭會傳送直接回至用戶端。目前,這項規格定義三種伺服器指示詞..."

為一的解決方法確定的 EXE 檔案名稱以"nph-"開頭並以手動方式在您的程式中建立所有的 HTTP 標頭。"nph-"表示伺服器要 CGI 程式是要在未剖析的標頭模式中執行。CGI 有兩種模式。以標準模式 (剖析標頭),您必須將其中一個 CGI 指示詞傳送至標準輸出 (內容類型、 位置或狀態)。CGI 格式化有效的 HTTP 回應列根據您所傳送的指示詞。它會為您,格式化其他標準的 HTTP 標頭而且應該包含其他任何您所指定的標頭。

其他模式是未剖析的標頭模式。在此模式下 CGI 不會設定任何標頭本身。CGI 程式必須設定完整的 HTTP 回應,包括回應行和所有標頭的格式。伺服器不會新增或修改任何標頭以供您在這個模式。

慣例是在未剖析的標頭模式中執行其名稱以"nph-"開頭的 CGI 程式 ; 如果否則將 CGI 程式執行已剖析的標頭模式。

狀況說明

Microsoft 已確認這是在本篇文章開頭所列的 Microsoft 產品中有錯誤。

其他相關資訊

重製行為的步驟

編譯此 CGI 程式為 Win32 主控台應用程式,並放置在可執行您的 IIS 伺服器上的資料夾:
#include <stdio.h>
int main()
{
  printf("Location: %s\r\n", "http://www.yahoo.com");
  printf("Set-Cookie: Name1=Value1; path=/;
    expires=Fri, 22 May 1998 21:00:00 GMT\r\n\r\n");
  return 0;
}
				

從您的瀏覽器呼叫 CGI 程式,並觀察它的輸出 (透過網路監視器,例如)。它會像這樣:
HTTP/1.0 302 Object moved
Location: http://www.yahoo.com
Server: Microsoft-IIS/2.0
Content-Type: text/html
Content-Length: 145

<head><title>Document moved</title></head>
<body><h1>Object Moved</h1>This document may be found
<a HREF="http://www.yahoo.com">here</a></body>
				

請注意設定 Cookie 標頭由 IIS 尚未送出。如果您在您的瀏覽器中開啟了] 的 Cookie 警告會不出現任何警告。

若要以便在 302 回應中設定 Cookie 使用類似下列和可執行檔名稱的前置詞"nph-"的程式碼:
#include <stdio.h>
int main()
{
  printf("HTTP/1.0 302 Redirect\r\n");
  printf("Location: %s\r\n", "http://www.yahoo.com");
  printf("Set-Cookie: Name=Value; path=/; expires=Fri, 22 May 1998 21:00:00
   GMT\r\n\r\n");
  return 0;
}
				

輸出是類似下面的。請注意現在傳送 Cookie,且無標頭加入的伺服器。
HTTP/1.0 302 Redirect
Location: http://www.yahoo.com
Set-Cookie: Name=Value; path=/; expires=Fri, 22 May 1998 21:00:00 GMT
				

?考

(c) Microsoft Corporation 1997,保留所有的權限。由 Leon Braginski,Microsoft 公司所佔的比重

屬性

文章編號: 176113 - 上次校閱: 2008年7月3日 - 版次: 5.0
這篇文章中的資訊適用於:
  • Microsoft Internet Information Server 3.0
  • Microsoft Internet Information Server 4.0
  • Microsoft Internet Information Services 5.0
關鍵字:?
kbmt kbbug kbnofix KB176113 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:176113
Microsoft及(或)其供應商不就任何在本伺服器上發表的文字資料及其相關圖表資訊的恰當性作任何承諾。所有文字資料及其相關圖表均以「現狀」供應,不負任何擔保責任。Microsoft及(或)其供應商謹此聲明,不負任何對與此資訊有關之擔保責任,包括關於適售性、適用於某一特定用途、權利或不侵權的明示或默示擔保責任。Microsoft及(或)其供應商無論如何不對因或與使用本伺服器上資訊或與資訊的實行有關而引起的契約、過失或其他侵權行為之訴訟中的特別的、間接的、衍生性的損害或任何因使用而喪失所導致的之損害、資料或利潤負任何責任。

提供意見

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com