HttpResponse.Redirect メソッド

定義

クライアントを新しい URL にリダイレクトします。

オーバーロード

名前 説明
Redirect(String)

要求を新しい URL にリダイレクトし、新しい URL を指定します。

Redirect(String, Boolean)

クライアントを新しい URL にリダイレクトします。 新しい URL と、現在のページの実行を終了するかどうかを指定します。

Redirect(String)

要求を新しい URL にリダイレクトし、新しい URL を指定します。

public:
 void Redirect(System::String ^ url);
public void Redirect(string url);
member this.Redirect : string -> unit
Public Sub Redirect (url As String)

パラメーター

url
String

ターゲットの場所。 これは、アプリケーション相対仮想パスである可能性があります。

例外

HTTP ヘッダーが送信された後、リダイレクトが試行されます。

次の例では、別の Web サイトへの無条件リダイレクトを強制します。

Response.Redirect("http://www.microsoft.com/gohere/look.htm");

Response.Redirect("http://www.microsoft.com/gohere/look.htm")
   

注釈

Redirectの呼び出しは、2 番目のパラメーターを true に設定してRedirectを呼び出すことと同じです。

Redirectは、完了時にThreadAbortException例外をスローするEndを呼び出します。 この例外は、Web アプリケーションのパフォーマンスに悪影響を与えます。 そのため、このオーバーロードの代わりに、HttpResponse.Redirect(String, Boolean)オーバーロードを使用し、endResponse パラメーターにfalseを渡してから、CompleteRequest メソッドを呼び出することをお勧めします。 詳細については、 End メソッドを参照してください。

モバイル ページの場合のみ、アプリケーションが Cookie レス セッションに依存している場合、または Cookie レス セッションを必要とするモバイル デバイスから要求を受信する可能性がある場合は、パスでチルダ (~) を使用すると、新しいセッションが作成され、セッション データが失われる可能性があります。 "~/path" などのパスを持つモバイル コントロールにプロパティを設定するには、プロパティに割り当てる前に、 ResolveUrl "~/path" を使用してパスを解決します。

ASP.NET は、302 HTTP 状態コードを返すことによってリダイレクトを実行します。 別のページに制御を転送する別の方法は、 Transfer メソッドです。 Transferメソッドは通常、クライアントへのラウンド トリップを引き起こさないため、より効率的です。 詳細については、「 方法: ユーザーを別のページにリダイレクトする」を参照してください。

適用対象

Redirect(String, Boolean)

クライアントを新しい URL にリダイレクトします。 新しい URL と、現在のページの実行を終了するかどうかを指定します。

public:
 void Redirect(System::String ^ url, bool endResponse);
public void Redirect(string url, bool endResponse);
member this.Redirect : string * bool -> unit
Public Sub Redirect (url As String, endResponse As Boolean)

パラメーター

url
String

ターゲットの場所。

endResponse
Boolean

現在のページの実行を終了するかどうかを示します。

例外

urlnullです。

url には改行文字が含まれています。

HTTP ヘッダーが送信された後、リダイレクトが試行されます。

ページ要求はコールバックの結果です。

次の例では、 IsClientConnected プロパティを使用して、ページを要求しているクライアントがサーバーに接続されたままかどうかを確認します。 IsClientConnectedが true の場合、コードは Redirect メソッドを呼び出し、クライアントは別のページを表示します。 IsClientConnectedが false の場合、コードは End メソッドを呼び出し、すべてのページ処理が終了します。

<%@ Page Language="C#" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<script runat="server">

    private void Page_Load(object sender, EventArgs e)
    {
        // Check whether the browser remains
        // connected to the server.
        if (Response.IsClientConnected)
        {
            // If still connected, redirect
            // to another page. 
            Response.Redirect("Page2CS.aspx", false);
        }
        else
        {
            // If the browser is not connected
            // stop all response processing.
            Response.End();
        }
    }

</script>
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>ASP.NET Example</title>
</head>
<body>
    <form id="form1" runat="server">
    </form>
</body>
</html>
<%@ Page Language="VB" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<script runat="server">
    Private Sub Page_Load(sender As Object, e As EventArgs)

        ' Check whether the browser remains
        ' connected to the server.
        If (Response.IsClientConnected) Then

            ' If still connected, redirect
            ' to another page.             
            Response.Redirect("Page2VB.aspx", false)
        Else
            ' If the browser is not connected
            ' stop all response processing.
            Response.End()
        End If
    End Sub
</script>
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>ASP.NET Example</title>
</head>
<body>
    <form id="form1" runat="server">
    </form>
</body>
</html>

注釈

ターゲットの場所には絶対 URL ( http://www.contoso.com/default.aspx など) または相対 URL (Default.aspx など) を指定できますが、一部のブラウザーでは相対 URL が拒否される場合があります。

ページ ハンドラーでこのメソッドを使用して 1 つのページの要求を終了し、別のページの新しい要求を開始する場合は、 endResponsefalse に設定し、 CompleteRequest メソッドを呼び出します。 endResponse パラメーターにtrueを指定した場合、このメソッドは元の要求に対して End メソッドを呼び出します。これにより、完了時にThreadAbortException例外がスローされます。 この例外は Web アプリケーションのパフォーマンスに悪影響を及ぼすため、endResponse パラメーターにfalseを渡すことをお勧めします。 詳細については、 End メソッドを参照してください。

モバイル ページの場合、アプリケーションが Cookie レス セッションに依存している場合、または Cookie レス セッションを必要とするモバイル デバイスから要求を受信する可能性がある場合は、パスでチルダ (~) を使用すると、新しいセッションが作成され、セッション データが失われる可能性があります。 "~/path" などのパスを持つモバイル コントロールにプロパティを設定するには、プロパティに割り当てる前に、 ResolveUrl "~/path" を使用してパスを解決します。

ASP.NET は、302 HTTP 状態コードを返すことによってリダイレクトを実行します。 別のページに制御を転送する別の方法は、 Transfer メソッドです。 Transferメソッドは通常、クライアントへのラウンド トリップを引き起こさないため、より効率的です。 詳細については、「 方法: ユーザーを別のページにリダイレクトする」を参照してください。

適用対象