Мой красивый веб-сервис REST отлично работает. За исключением случаев, когда я посещаю такие страницы, как ~/
, который возвращает запретную страницу IIS 403 по умолчанию (даже используя Fiddler и указывая только Accept: application/json
). Я не хочу ничего, кроме ошибок JSON или XML. Есть ли способ переопределить ВСЕ исключения с помощью специального обработчика исключений? или контроллер по умолчанию для обработки всех неизвестных запросов? Какой самый простой и самый правильный (если он отличается) способ справиться с этим, так что клиентам нужно просто анализировать REST API-дружественные XML-дейтаграммы или JOSON-капли?
Пример запроса:
GET http://localhost:7414/ HTTP/1.1
User-Agent: Fiddler
Host: localhost:7414
Accept: application/json, text/json, text/xml
Ответ: (что мне не нравится, обратите внимание, что text/html
не был одним из принятых типов ответов)
HTTP/1.1 403 Forbidden
Cache-Control: private
Content-Type: text/html; charset=utf-8
Server: Microsoft-IIS/8.0
X-SourceFiles: =?UTF-8?B?QzpcaWNhcm9sXENoYXJpdHlMb2dpYy5pQ2Fyb2wuQXBp?=
X-Powered-By: ASP.NET
Date: Fri, 25 Jan 2013 21:06:21 GMT
Content-Length: 5396
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>IIS 8.0 Detailed Error - 403.14 - Forbidden</title>
<style type="text/css">
<!--
...
Ответ (который я бы предпочел):
HTTP/1.1 403 Forbidden
Cache-Control: private
Content-Type: application/json; charset=utf-8
Date: ...
Content-Length: ....
{
"error":"forbidden",
"status":403,
"error_description":"Directory listing not allowed."
}