• asp.net mvc 4 json大数据异常 提示JSON字符长度超出限制的异常[转载]


    今天客户突然过来找我说在后台添加了一篇超长的文章后,所有后台的文章都显示不出来了。后台的前端显示是用easyui的,返回的数据全是用json。根据客户的描述进行了同样的操作后,在firebug下发现ajax返回的异常 “序列化或JSON的JavaScriptSerializer过程中出现错误。字符串的长度超过上maxJsonLength属性设置的值”

    这个异常是在执行MVC中的JsonResult的时抛出的,根据异常 的Message得知是序列化的字符串超出了maxJsonLength的限制。并得知这个属性是由JavaScriptSerializer提供的,因 为MVC内置的JsonResult是用JavaScriptSerializer进行序列化的。在网上快速搜索了一下,碰到这个问题的不少,大部分 推荐的解决的方法都是在web.config中加入以下配置,设置maxJsonLength的长度即

    复制代码
    1 <system.web.extensions>
    2        <scripting>
    3            <webServices>
    4                <jsonSerialization maxJsonLength="102400"/>
    5            </webServices>
    6        </scripting>
    7 </system.web.extensions>
    复制代码

    然后根据需要改变maxJsonLength的大小

    运行正常,但是问题依旧还在,而且不管maxJsonLength设置成多大都无效

    没办法,只能继续搜索查找资料了。

    原来MVC框架内置的JsonResult代码中,在使用JavaScriptSerializer时,都是采用的默认值,没有从maxJsonLength读取值,即忽略了这个配置。

    最后在stackoverflow上找到了答案

    在控制器中添加两个JsonResult,然后在需要返回大数据json的action调用,即用return LargeJson()代替return Json()

    复制代码
    public JsonResult LargeJson(object data)
    {
         return new System.Web.Mvc.JsonResult()
          {
                    Data = data,
                    MaxJsonLength = Int32.MaxValue,
            };
    }
    public JsonResult LargeJson(object data,JsonRequestBehavior behavior)
    {
                return new System.Web.Mvc.JsonResult()
                {
                    Data = data,
                    JsonRequestBehavior = behavior,
                    MaxJsonLength = Int32.MaxValue
                };
    }
    复制代码

    具体网址:http://stackoverflow.com/questions/4155014/json-asp-net-mvc-maxjsonlength-exception

    说道这里不得不感叹一下

    很多技术问题,百度出来的结果实在没有人家国外的牛,以后遇到的技术问题还是google点

  • 相关阅读:
    关于jquery尺寸的总结
    PhotoshopCC 如何使用动作文件ATN
    改变radio默认样式
    html中如何修改选中 用input做的搜索框 的边框颜色
    option触发事件两种方法总结
    用 CSS 隐藏页面元素的 5 种方法
    bootstrap模态框总结
    stop总结
    如何解决在chrome中自动完成表单后input出现黄色背景
    jquery实现显示和隐藏toggle()方法的使用
  • 原文地址:https://www.cnblogs.com/cybolg/p/8204912.html
Copyright © 2020-2023  润新知