40

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 を返すにはどうすればよいですか? 例外をスローできますが、これは彼のエラーではなく例外を示しています。

何か案は?

4

10 に答える 10

34

MVC を使用している場合は、次のようにします。

            return new HttpStatusCodeResult(HttpStatusCode.Forbidden);
于 2015-05-01T17:48:15.560 に答える
32

Context.Response.Statusと の両方を設定する必要はありませんContext.Response.StatusCode。簡単設定

Context.Response.StatusCode = (int)System.Net.HttpStatusCode.Forbidden

自動的に設定さResponse.Statusれます。

于 2012-07-11T17:49:11.380 に答える
18

質問に完全に答えるために-これは私が使用したコードです(詳細についてはストライダーに感謝します):

[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;
        }
    }
于 2012-02-24T06:48:55.517 に答える
7

コードをWebServiceコンストラクターに配置することで、すべてのメソッドを保護できます。これにより、WebMethodが呼び出されることさえなくなります。

public Service(): base()
{
    if (!GetUser().LoggedIn)
    {
        Context.Response.StatusCode = (int)System.Net.HttpStatusCode.Forbidden;
        Context.Response.End();
    }
}
于 2011-10-05T09:43:38.793 に答える
6

Asp.Net Web Api 2 では、次を使用します。

return new StatusCodeResult(HttpStatusCode.Forbidden, this);
于 2016-06-03T11:34:33.063 に答える
3
Context.Response.StatusCode = 403;
于 2011-04-13T13:57:44.427 に答える
1

Web サービス要求は、最初に global.asax ファイルに遭遇します。確認して戻ることができます。

于 2011-04-13T20:39:42.880 に答える
0

Forbidden 403 は、Web サイト上の禁止されたコンテンツへのアクセスの結果です。ここで必要なのは、結果の一部として「ユーザーがログオンしていません」というメッセージを返すことだと思います

于 2011-04-13T13:56:30.157 に答える