C#/ asp.netでプログラムされたWebサービスがあります。
[WebService(Namespace = "http://example.com/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[ScriptService]
[System.ComponentModel.ToolboxItem(false)]
public class Service: System.Web.Services.WebService
{
[WebMethod]
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
public Result GetData()
{
User user = GetUser();
if (user.LoggedIn)
{
return GetData();
}
else
{
// raise exception -> return error 403
}
}
このWebサービスからエラー403を返すにはどうすればよいですか?私は例外をスローすることができます-しかし、これは例外を示しており、彼のエラーではありません。
何か案は?
質問に完全に答えるために-これは私が使用したコードです(詳細についてはstriderに感謝します):
[WebService(Namespace = "http://example.com/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[ScriptService]
[System.ComponentModel.ToolboxItem(false)]
public class Service: System.Web.Services.WebService
{
[WebMethod]
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
public Result GetData()
{
User user = GetUser();
if (user.LoggedIn)
{
return GetData();
}
else
{
Context.Response.Status = "403 Forbidden";
//the next line is untested - thanks to strider for this line
Context.Response.StatusCode = 403;
//the next line can result in a ThreadAbortException
//Context.Response.End();
Context.ApplicationInstance.CompleteRequest();
return null;
}
}
両方を設定する必要はありませんContext.Response.Status
およびContext.Response.StatusCode
。設定するだけ
Context.Response.StatusCode = (int)System.Net.HttpStatusCode.Forbidden
自動的に設定されますResponse.Status
あなたのために。
MVCを使用していた場合、次のことを行います。
return new HttpStatusCodeResult(HttpStatusCode.Forbidden);
WebServiceコンストラクターにコードを配置することで、すべてのメソッドを保護できます。これにより、WebMethodが呼び出されることさえ防止されます。
public Service(): base()
{
if (!GetUser().LoggedIn)
{
Context.Response.StatusCode = (int)System.Net.HttpStatusCode.Forbidden;
Context.Response.End();
}
}
Asp.Net Web Api 2では、次を使用します。
return new StatusCodeResult(HttpStatusCode.Forbidden, this);
Context.Response.StatusCode = 403;
Webサービスリクエストは、まずglobal.asaxファイルに遭遇します。確認して、そこに戻ることができます。
Forbidden 403は、Webサイト上の禁止コンテンツへのアクセスの結果です。ここで欲しいのは、「ユーザーはログオンしていません」という結果の一部としてメッセージを返すことです