Веб-сервис Asp.Net: Я хотел бы вернуть ошибку 403 запрещено - PullRequest
29 голосов
/ 13 апреля 2011

У меня запрограммирован веб-сервис на c # / asp.net.

[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
        }
    }

Как можно вернуть ошибку 403 из этого веб-сервиса?Я могу выбросить исключение - но это показывает исключение, а не его ошибку.

Есть идеи?

Ответы [ 8 ]

27 голосов
/ 11 июля 2012

Вам не нужно устанавливать оба значения Context.Response.Status и Context.Response.StatusCode. Простая настройка

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

автоматически установит для вас Response.Status.

23 голосов
/ 01 мая 2015

Если бы вы использовали MVC, вы бы сделали следующее:

            return new HttpStatusCodeResult(HttpStatusCode.Forbidden);
17 голосов
/ 24 февраля 2012

Чтобы полностью ответить на вопрос - это код, который я использовал (спасибо страйдеру за дополнительную информацию):

[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;
        }
    }
7 голосов
/ 05 октября 2011

Вы можете защитить все свои методы, разместив код в конструкторе WebService.Это предотвращает даже вызов вашего WebMethod:

public Service(): base()
{
    if (!GetUser().LoggedIn)
    {
        Context.Response.StatusCode = (int)System.Net.HttpStatusCode.Forbidden;
        Context.Response.End();
    }
}
6 голосов
/ 03 июня 2016

В Asp.Net Web Api 2 вы будете использовать:

return new StatusCodeResult(HttpStatusCode.Forbidden, this);
3 голосов
/ 13 апреля 2011
Context.Response.StatusCode = 403;
1 голос
/ 14 апреля 2011

Сначала ваши запросы к веб-сервису встретятся с вашим файлом global.asax. Вы можете проверить и вернуться туда.

0 голосов
/ 13 апреля 2011

Forbidden 403 будет результатом доступа к запрещенному контенту на вашем сайте.Я думаю, что вы хотите здесь, чтобы вернуть сообщение как часть вашего результата, который "Пользователь не вошел"

...