使用 JSON JavaScriptSerializer 进行序列化或反序列化时出错。字符串的长度超过了为 maxJsonLength 属性设置的值

问题:使用 JSON JavaScriptSerializer 进行序列化或反序列化时出错。字符串的长度超过了为 maxJsonLength 属性设置的值

分析:

意味着你尝试处理的 JSON 字符串超过了 JavaScriptSerializer 默认的最大长度限制。默认限制,JavaScriptSerializer 类的 MaxJsonLength 属性默认设置为 2097152 字节(即 2MB)。这意味着如果你尝试序列化或反序列化超过这个大小的 JSON 数据,就会抛出异常。

解决方案

1、增加 MaxJsonLength 的值:

csharp 复制代码
using System.Web.Script.Serialization;

var jsonResult="";//你要返回的参数
var seriializer = new JavaScriptSerializer();
seriializer.MaxJsonLength = Int32.MaxValue;// 或者设置为一个合理的更高值
var result = new ContentResult
{
    Content = seriializer.Serialize(jsonResult),
    ContentType = "application/json"
};
   return result;

2、使用Newtonsoft.Json序列化库

csharp 复制代码
using Newtonsoft.Json;

var jsonString = JsonConvert.SerializeObject(yourObject);
// 或者
var Obj = JsonConvert.DeserializeObject<T>(jsonString);

或者自定义

csharp 复制代码
JsonSerializerSettings settings = new JsonSerializerSettings
{
    MaxDepth = 100, // 可以根据需要设置
    MaxJsonLength = int.MaxValue // 或者设置为一个合理的更高值
};

string jsonString = JsonConvert.SerializeObject(yourObject, settings);

3、对返回的参数进行分页返回

csharp 复制代码
int rows = Convert.ToInt32(Request["rows"] ?? "20");//条数
int page = Convert.ToInt32(Request["page"] ?? "1");//页码
 int numF = (page - 1) * rows ;
 int numT = page * rows;

 var data = new PreContainerGoodsBll().GetShipmentEntrustmentList(SED_STARTDATE, SED_ENDDATE, SED_CST_ID, SED_STATUS, SED_NUM, SED_PDI_NAME, SED_EPT_ID, SED_TYPE1, SED_TYPE2,  SED_TYPE,  PER_TRK_TRKNO);//要返回的参数
 var pagedData = data
 .Skip(numF) // 跳过前面的(pageNumber - 1) * pageSize个元素
 .Take(numT) // 取接下来的pageSize个元素
 .ToList(); // 将结果转换为列表
 var jsonResult = new { total = data.Count<SHIPMENT_ENTRUSTMENTModel>(), rows = pagedData };
 return Json(jsonResult, JsonRequestBehavior.AllowGet);
相关推荐
子非衣4 小时前
MySQL修改JSON格式数据示例
android·mysql·json
林的快手2 天前
伪类选择器
android·前端·css·chrome·ajax·html·json
css趣多多3 天前
初步安装和使用vant组件库,使用css变量定制vant主题样式 ,小程序的API Promise化,调用promise化之API
json
Web极客码3 天前
WordPress“更新失败,响应不是有效的JSON响应”问题的修复
json·github·wordpress
gywl5 天前
Spring Web MVC入门
spring·json·mvc·注解·cookie·session
运维小文6 天前
Mongodb数据管理
数据库·mongodb·json·非关系数据库·文档型数据库
玉阳软件yuyangdev_cn6 天前
铁塔电单车协议对接电单车TCP json协议对接成熟充电桩系统搭建低速充电桩TCP 接口规范
网络·tcp/ip·json·铁塔协议
m0_748232927 天前
SpringCloud系列教程:微服务的未来 (五)枚举处理器、JSON处理器、分页插件实现
spring cloud·微服务·json
SendSi7 天前
Unity使用反射进行Protobuf(CS/SC)协议,json格式
unity·json·游戏引擎
CURRY30_HJH7 天前
MYSQL直接在SQL提取json字符串中的内容-----将13位时间戳转换成标准的日期格式【记录SQL常用函数】
数据库·sql·json