Json allowget ошибка - PullRequest
       3

Json allowget ошибка

51 голосов
/ 06 января 2011

Эта ошибка появляется в нашем приложении MVC случайно. Иногда делать то же самое, чего не будет, иногда будет. Кто-нибудь знает, связано ли это с чем-то, что может быть простым исправлением, или это что-то общее, что многие из вас видели?

System.InvalidOperationException: This request has been blocked because sensitive information could be disclosed to third party web sites when this is used in a GET request. To allow GET requests, set JsonRequestBehavior to AllowGet.
   at System.Web.Mvc.JsonResult.ExecuteResult(ControllerContext context)
   at System.Web.Mvc.ControllerActionInvoker.InvokeActionResult(ControllerContext controllerContext, ActionResult actionResult)
   at System.Web.Mvc.ControllerActionInvoker.<>c__DisplayClass14.b__11()
   at System.Web.Mvc.ControllerActionInvoker.InvokeActionResultFilter(IResultFilter filter, ResultExecutingContext preContext, Func`1 continuation)
   at System.Web.Mvc.ControllerActionInvoker.<>c__DisplayClass14.<>c__DisplayClass16.b__13()
   at System.Web.Mvc.ControllerActionInvoker.InvokeActionResultFilter(IResultFilter filter, ResultExecutingContext preContext, Func`1 continuation)
   at System.Web.Mvc.ControllerActionInvoker.<>c__DisplayClass14.<>c__DisplayClass16.b__13()
   at System.Web.Mvc.ControllerActionInvoker.InvokeActionResultFilter(IResultFilter filter, ResultExecutingContext preContext, Func`1 continuation)
   at System.Web.Mvc.ControllerActionInvoker.<>c__DisplayClass14.<>c__DisplayClass16.b__13()
   at System.Web.Mvc.ControllerActionInvoker.InvokeActionResultWithFilters(ControllerContext controllerContext, IList`1 filters, ActionResult actionResult)
   at System.Web.Mvc.ControllerActionInvoker.InvokeAction(ControllerContext controllerContext, String actionName)
   at System.Web.Mvc.Controller.ExecuteCore()
   at System.Web.Mvc.ControllerBase.Execute(RequestContext requestContext)
   at System.Web.Mvc.ControllerBase.System.Web.Mvc.IController.Execute(RequestContext requestContext)
   at System.Web.Mvc.MvcHandler.<>c__DisplayClass8.b__4()
   at System.Web.Mvc.Async.AsyncResultWrapper.<>c__DisplayClass1.b__0()
   at System.Web.Mvc.Async.AsyncResultWrapper.<>c__DisplayClass8`1.b__7(IAsyncResult _)
   at System.Web.Mvc.Async.AsyncResultWrapper.WrappedAsyncResult`1.End()
   at System.Web.Mvc.MvcHandler.EndProcessRequest(IAsyncResult asyncResult)
   at System.Web.Mvc.MvcHandler.System.Web.IHttpAsyncHandler.EndProcessRequest(IAsyncResult result)
   at System.Web.HttpApplication.CallHandlerExecutionStep.System.Web.HttpApplication.IExecutionStep.Execute()
   at System.Web.HttpApplication.ExecuteStep(IExecutionStep step, Boolean& completedSynchronously)

Ответы [ 4 ]

120 голосов
/ 06 января 2011

Ответ на ваш вопрос был в трассировке стека."JsonRequestBehavior to AllowGet"

Поэтому используйте его в своем контроллере как:

return Json(data, JsonRequestBehavior.AllowGet)
22 голосов
/ 22 июня 2011

Вы должны прочитать http://haacked.com/archive/2009/06/24/json-hijacking.aspx/ перед обходом этих мер безопасности.

Если вы предоставляете свои данные JSON только в ответ на HOSTP POST, то вы не уязвимы для этой атаки.

Вы можете просто аннотировать свое действие JSON с помощью [HttpPost] и в клиенте сделать что-то вроде

$.post('/blag/JSON', function (data) {
       //do something with my json data object here

});
4 голосов
/ 06 января 2011

Кажется, что вы когда-нибудь вызываете действие контроллера для HTTP GET.Чтобы иметь возможность возвращать результаты JSON, вы должны использовать код, подобный

return Json(data, JsonRequestBehavior.AllowGet);
0 голосов
/ 23 июня 2015

return Json(PartialView("index").ToJsonObject(this), JsonRequestBehavior.AllowGet);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...