Пользовательская ошибка C # WCF при сбое авторизации через настраиваемый AuthorizationManager

В настоящее время я работаю над реализацией настраиваемого WCF OpenAuth AuthenticationManager, и я успешно это сделал. Однако сейчас моя проблема - это страницы ответов, когда пользователь не может пройти аутентификацию. Я хочу, чтобы пользователь получил сообщение в формате JSON с кодом состояния ответа 401 (Неавторизованный). Однако я получаю общий ответ с 400 ошибками как таковой:

HTTP/1.1 400 Bad Request
Server: ASP.NET Development Server/10.0.0.0
Date: Mon, 20 Jun 2011 17:29:31 GMT
X-AspNet-Version: 4.0.30319
Content-Length: 1765
Cache-Control: private
Content-Type: text/html
Connection: Close

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
  <head>
    <title>Request Error</title>
    <style>BODY { color: #000000; background-color: white; font-family: Verdana; margin-left: 0px; margin-top: 0px; } #content { margin-left: 30px; font-size: .70em; padding-bottom: 2em; } A:link { color: #336699; font-weight: bold; text-decoration: underline; } A:visited { color: #6699cc; font-weight: bold; text-decoration: underline; } A:active { color: #336699; font-weight: bold; text-decoration: underline; } .heading1 { background-color: #003366; border-bottom: #336699 6px solid; color: #ffffff; font-family: Tahoma; font-size: 26px; font-weight: normal;margin: 0em 0em 10px -20px; padding-bottom: 8px; padding-left: 30px;padding-top: 16px;} pre { font-size:small; background-color: #e5e5cc; padding: 5px; font-family: Courier New; margin-top: 0px; border: 1px #f0f0e0 solid; white-space: pre-wrap; white-space: -pre-wrap; word-wrap: break-word; } table { border-collapse: collapse; border-spacing: 0px; font-family: Verdana;} table th { border-right: 2px white solid; border-bottom: 2px white solid; font-weight: bold; background-color: #cecf9c;} table td { border-right: 2px white solid; border-bottom: 2px white solid; background-color: #e5e5cc;}</style>
  </head>
  <body>
    <div id="content">
      <p class="heading1">Request Error</p>
      <p xmlns="">The server encountered an error processing the request. Please see the <a rel="help-page" href="http://localhost:2947/user/help">service help page</a> for constructing valid requests to the service.</p>
    </div>
  </body>
</html>

Мне бы очень хотелось получить что-то более похожее на следующее:

HTTP/1.1 200 OK
Server: ASP.NET Development Server/10.0.0.0
Date: Mon, 20 Jun 2011 15:35:12 GMT
X-AspNet-Version: 4.0.30319
Content-Length: 265
Cache-Control: private
Content-Type: application/json; charset=utf-8
Connection: Close

{"result":{"error":"Unable to authenticate using provided OAuth credentials"}}

Я реализую свою службу аутентификации, расширяя ServiceAuthorizationManager и создавая настраиваемую фабрику WebServiceHostFactory, которая вводит мой диспетчер аутентификации.

Любая помощь приветствуется!


person Community    schedule 20.06.2011    source источник
comment
Вы думали об использовании http-модуля для перехвата запроса и проверки OAuth? Если это сделано таким образом, когда проверка не удалась, вы можете настроить формат ответа.   -  person Andrew Church    schedule 21.06.2011
comment
@Andrew Church - я не изучал это, но я прочитал, что лучше всего выполнять авторизацию всего сайта в AuthorizationManager. Однако мне удалось изменить код состояния ответа с помощью вызова WebOperationContext.Current.OutgoingResponse.StatusCode = HttpStatusCode.Unauthorized;   -  person    schedule 21.06.2011
comment
Правильно, просто не уверен, будет ли вызываться AuthorizationManager, если бы вы реализовали правила кеширования (AspNet или IIS), но я почти уверен, что модуль будет.   -  person Andrew Church    schedule 14.09.2011


Ответы (1)


Так что я разобрался сам. Я следил за руководством на MSDN . Он довольно прост и проведет вас через необходимые шаги по добавлению службы расширения IErrorHandler в службу WCF. Я также сослался на еще одно сообщение о переполнении стека о том, как возвращать мои ошибки, в частности, в формате JSON. Если у кого-то есть какие-либо вопросы по этому поводу, я буду рад помочь, потому что это было еще одно болезненное напоминание о том, что вы МОЖЕТЕ слишком много абстрагироваться. :п

person Community    schedule 24.06.2011
comment
Удалось ли вам заставить это работать с настраиваемым объектом json при возврате кода состояния http 401? Кажется, у меня все работает правильно со всеми другими кодами состояния, но с 401 он меняет мое тело ответа на другой тип объекта. - person John Meyer; 06.07.2016
comment
Хотел бы я вспомнить. Проработав чуть более 5 лет, я не использовал .NET примерно в 4 из них. - person ; 06.07.2016