Response.Redirectで、別ASPに飛びません。
じゅん
1999/12/08(水) 11:24:33
ログイン画面で入力した、社員コード、パスワードを、別ASPでチェックしています。
ログインチェックASPで、ADOのエラー時に、ログイン画面へResponse.Redirectで
飛ばしたいのですが、そのまま処理が流れてしまいます。
以下、ログインチェック.aspのプログラム
<%
・
・
On Error Resume Next
Err.Clear 'Errオブジェクトのクリア
Set LcObjConn = server.CreateObject("ADODB.Connection")
LcObjConn.Open("ODBC")
If Err.Number <> 0 Then
'エラー情報をSessionオブジェクトに設定(ログイン画面に表示する)
LcObjConn.Close
Set LcObjConn = Nothing
Call SbErrorProc("エラーです")
End If
・
・
・
Sub SbErrorProc(LcStrMsg)
'エラー情報をSessionオブジェクトに設定(ログイン画面に表示する)
Session("SeMsg") = LcStrMsg
Session("SeErrMsg") = "詳細情報:" & Err.description & "(" & Err.number & ")"
Response.Redirect "ログイン.asp"
End Sub
%>
具体的な現象は、ODBCのオープンエラーが発生した場合、Err.Numberが0以外になるので、
SbErrorProcを呼びます。
SbErrorProcの中では、Sessionオブジェクトにエラー情報を設定します。
本来ならば、ログイン.aspにリダイレクトして、エラー情報を表示すると思ったのですが、ログイン.aspに
リダイレクトせず、ログインチェック.aspの処理を続行しています。
Response.Redirectの後に、Response.Endを追加してみましたが、ダメでした。
記述に間違いがあるのでしょうか?
また、Response.Redirectを使用する場合、注意点はありますか?
開発環境は、NT4.0SP4 + IIS4.0 + VBScript です。
よろしくお願いします。
うぐいす
1999/12/08(水) 12:07:14
特に間違っているように感じませんので確認です。
>If Err.Number <> 0 Then
Err.Numberには、ちゃんと0以外の値が入ってますか?
Err.Raiseを使えば、強制的にエラーを発生させることが出来ます。
>Response.Redirect "ログイン.asp"
ファイル名は半角英数字のほうが良いと思います。
説明のために2バイト文字にされているのでしたら、すみません。
>NT4.0SP4 + IIS4.0 + VBScript
私の開発環境も同じですが、Response.Redirectは実行されています。
通りすがりの若輩もの
1999/12/08(水) 12:36:30
こんちわ。
サブルーチンをコールして、サブルーチン内でRedirectしているのが、
キモかもしれません。
サブールーチンを止めて直接記述してみてどうなるか、試してみては
いかがでしょうか。
ちなみに、ただ単にRedirectすることは出来ているのですよね。
一般によくやるミスは、すでに何らかの情報をクライアントを渡した後
でRedirectしようとしてエラーが出る事ですが、この点に関しては、
大丈夫でしょうか。
あの、ちなみに後学のために教えて欲しいのですが、
>Set LcObjConn = server.CreateObject("ADODB.Connection")
>LcObjConn.Open("ODBC")
この部分のエラーをトラップする目的とは、何なのでしょう?
どういう要因でエラーが発生すると想定されているのですか?
じゅん
1999/12/08(水) 13:53:53
うぐいすさん、通りすがりの若輩ものさん、早速のレスありがとうございました。
頂いたアドバイスを試してみました。
>Err.Numberには、ちゃんと0以外の値が入ってますか?
Err.Numberは、0以外が入っていました。
>ファイル名は半角英数字のほうが良いと思います。
半角英数字にしてみましたが、ダメでした。
>サブールーチンを止めて直接記述してみてどうなるか、試してみては
>いかがでしょうか。
お~、動きました。
そうすると、サブルーチン内でのResponse.Redirectが原因なんでしょうか?
エラー処理を共通化したかったので、サブルーチンにしたのですが、直接、記述することにします。
これって、VBScriptの仕様ですかね。(^^;
それとも、スクリプトエンジンのバージョンをアップすると直るとか。
忘れましたが、NT WorkStationのPWSで、IE4.0sp1の環境です。
あの、うぐいすさんにお願いしたことがあります。
うぐいすさんの環境で、サブルーチンをコールして、サブルーチン内でのResponse.Redirectは動くか確認できますか?
通りすがりの若輩ものさんに、お聞きしたことがあります。
>一般によくやるミスは、すでに何らかの情報をクライアントを渡した後
>でRedirectしようとしてエラーが出る事ですが、この点に関しては、
>大丈夫でしょうか。
というのは、具体的にどのような処理のことですか?
再質問して申し訳ありませんが、よろしくお願いします。
>この部分のエラーをトラップする目的とは、何なのでしょう?
>どういう要因でエラーが発生すると想定されているのですか?
の件ですが、ODBCのデータソース名の変更し忘れや、ODBCを間違って削除した場合を想定して付けました。
実際の運用では、皆無に等しいエラーかもしれません。
一応、念のために付けてみました。(^^;
でも、良く考えると、ここに、エラートラップがなくてもコネクションが無いので、
それ以降のADO関連の処理でエラーとなるため、必要ないかもしれませんね。
うぐいす
1999/12/08(水) 15:13:46
>うぐいすさんの環境で、サブルーチンをコールして、サブルーチン内でのResponse.Redirectは動くか確認できますか?
すでにあるソースを使いましたので、CreateObjectは使用していないのですが、
<%
if errflg <> 0 then
call aaa()
end if
sub aaa()
response.redirect "input.html"
end sub
%>
としてみたところ、正常に動いております。
サブルーチン化してもresponse.redirectには影響がないようです。
通りすがりの若輩もの
1999/12/08(水) 16:44:25
私も気になって試しましたが、うぐいすさんのおっしゃる通り、
サブルーチン内でResponse.Redirectしても何ら問題無く動作してしま
いました。
サブルーチン内でも、Redirect先が無いとか、後述のヘッダー情報書き
込み後のRedirectも試しましたが、ブラウザで正しくエラーが表示され
ているので、もっと根本的なところで勘違いされているのかも知れま
せん。ロジック処理フローでの勘違いとか。^^;
環境についてですが、
>NT4.0SP4 + IIS4.0 + VBScript
ではなかったの?
うちは、NT4.0SP4 + IIS4.0 + VBScript3.1です。
うぐいすさんご指摘の日本語ファイル名の件は、本件とは直接関係しな
いが、一般論として、URL部分に日本語が含まれているのはいかがな
ものか、と言う事だと思います。
理由は分かりませんが、今後の為にも使わないほうが無難では?
>一般によくやるミスは、すでに何らかの情報をクライアントを渡した後
>でRedirectしようとしてエラーが出る事ですが、この点に関しては、
>大丈夫でしょうか。
具体的にソースで示します。
次に示すa.aspはRedirectされますが、b.aspはエラーとなってしまい
ます。<HTML>タグの前で処理するか、Response.buffer=trueとして
aspの最後の処理が終るまで、クライアントに何も返さないようにして
あげることが必要です。
実際に試してみるとよく分かると思います。
----- a.asp -----
<%@ LANGUAGE = VBScript %>
<%
if Request.form("B1")="記憶させちゃう" then
Session("PRA_UID") = Request.form("PRA_UID")
else
Session("PRA_UID") = ""
Response.Redirect "test.asp"
end if
%>
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML//EN">
<html>
<head>
<title>おまけ</title>
<meta http-equiv="Content-Type" content="text/html; charset=x-sjis">
</head>
<body>
ほげほげ<br>
</body>
</html>
----- a.asp 以上 -----
----- b.asp -----
<%@ LANGUAGE = VBScript %>
<%
Response.buffer=true
'この1行があればb.aspもエラーにならない
if Request.form("B1")="記憶させちゃう" then
Session("PRA_UID") = Request.form("PRA_UID")
else
Session("PRA_UID") = ""
end if
%>
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML//EN">
<html>
<head>
<title>おまけ</title>
<meta http-equiv="Content-Type" content="text/html; charset=x-sjis">
</head>
<body>
<%
if Session("PRA_UID") = "" then
Response.Redirect "test.asp"
end if
%>
ほげほげ<br>
</body>
</html>
----- b.asp 以上 -----
あっ、それから今気がつきましたが、IISの設定でクライアントに
エラーメッセージを表示させないという設定(デフォルトではない)
になっていると何もエラーが表示されないかも知れません。
これはこちらでは運用上設定変更できないのでご容赦を。
それでは。
うぐいす
1999/12/08(水) 16:58:37
>通りすがりの若輩もの
>うぐいすさんご指摘の日本語ファイル名の件は、本件とは直接関係しないが、
>一般論として、URL部分に日本語が含まれているのはいかがなものか、と言う事だと思います。
そのとおりです。(^^;)
言葉足らずですみません。
通りすがりの若輩ものさん、フォロー有難うございました。m(__)m
うぐいす
1999/12/08(水) 17:00:12
すみません。
なんか慌てて書込みしたので、敬称が抜けてしまいました。
通りすがりの若輩ものさん、本当に申し訳ありません。
通りすがりの若輩もの
1999/12/08(水) 17:39:02
とんでもないですぅ。>うぐいすさん
前述のb.aspですが、そのままではRedirectされてしまいます。
Response.buffer=true
をコメントアウトするとエラーになります。
#慌てて書き込みしたもので。^^;
#ペンネームが長くて一覧表示のテーブルがぶざまになってしまい、
恐れ入りますです。>みなさま
じゅん
1999/12/08(水) 18:05:03
うぐいすさん、通りすがりの若輩ものさん、ご丁寧な回答ありがとうございます。
とても参考になりました。
あれから、色々と調べました。
通りすがりの若輩ものさんのご指摘の通り、私のプログラムミスでした。
申し訳有りませんでした。m(__)m
以下のようにスクリプトを修正したら、正常に動作ました。
修正したログインチェック.aspのプログラム
<%
・
・
On Error Resume Next
Err.Clear 'Errオブジェクトのクリア
Set LcObjConn = server.CreateObject("ADODB.Connection")
LcObjConn.Open("ODBC")
If Err.Number <> 0 Then
'エラー情報をSessionオブジェクトに設定(ログイン画面に表示する)
'コネクションのCloseをコメント
' LcObjConn.Close
Set LcObjConn = Nothing
Call SbErrorProc("エラーです")
End If
・
・
・
Sub SbErrorProc(LcStrMsg)
'エラー情報をSessionオブジェクトに設定(ログイン画面に表示する)
Session("SeMsg") = LcStrMsg
Session("SeErrMsg") = "詳細情報:" & Err.description & "(" & Err.number & ")"
Response.Redirect "ログイン.asp"
End Sub
%>
何が原因だったかと言いますと、LcObjConn.Close が悪さしていました。
LcObjConn.Openが成功していないのに、クローズしたためです。
おそらく、On Error Resume Nextを指定しているので、リダイレクトせず、ログインチェック.aspの処理を続行
していると思われます。
試しに、レコードセットのオープンに失敗して、エラートラップ処理で、レコードセットのクローズを
実行した場合もリダイレクトしませんでした。
度々、質問して申し訳有りません。
コネクション、レコードセットは、Closeしなくても良いものでしょうか?
NothingをセットするだけでOKですか?