ASP.Net WebForm c#Web服务-字符串的长度超过在maxJsonLength属性上设置的值

时间:2018-07-05 15:03:27

标签: c# asp.net json web-services webforms

我正在使用ASP.Net WebForm和C#Web服务,并且在运行代码时遇到以下错误;

Error during serialization or deserialization using the JSON JavaScriptSerializer. 
The length of the string exceeds the value set on the maxJsonLength property.

我尝试将以下内容放入Web配置中,但尚未解决;

<system.web.extensions>
 <scripting>
  <webServices>
   <jsonSerialization maxJsonLength="2147483644"/>
  </webServices>
 </scripting>
</system.web.extensions>

我的Web服务;

        public class OpenRequisitions
    {
        public string string1 { get; set; }
        public string sstring2 { get; set; }
        public string string3 { get; set; }
        public string string4 { get; set; }
        public string string5 { get; set; }
    }

    [WebMethod]
    [ScriptMethod(ResponseFormat = ResponseFormat.Json)]
    public List<OpenRequisitions> GetOpenReqData(string ReqId, string RequisitionTitle, string City, string Country, string DateCreated)
    { 
        string connectionString = ConfigurationManager.ConnectionStrings["CONN"].ConnectionString;
        string commandTextGetOpenRequisitions = Properties.Queries.commandTextGetOpenRequisitions;
        List<OpenRequisitions> GetOpenRequisitionData = new List<OpenRequisitions>();
        using (SqlConnection con = new SqlConnection(connectionString))
        {
            SqlCommand command = new SqlCommand(commandTextGetOpenRequisitions, con);
            command.CommandType = CommandType.Text;
            con.Open();
            SqlDataReader rdr = command.ExecuteReader();
            while (rdr.Read())
            {
                OpenRequisitions results = new OpenRequisitions();
                results.ReqId = rdr["string1"].ToString();
                results.RequisitionTitle = rdr["string2"].ToString();
                results.City = rdr["string3"].ToString();
                results.Country = rdr["string4"].ToString();
                results.DateCreated = rdr["string5"].ToString();

                GetOpenRequisitionData.Add(results);
            }
        }
        return GetOpenRequisitionData;
    }

1 个答案:

答案 0 :(得分:0)

问题似乎与JavaScriptSerializer有关。您可以直接在其上设置最大值。它不会从web.config继承值。

// Create an instance of your JavaScriptSerializer and set the MaxJsonLength.
var serializer = new JavaScriptSerializer() { MaxJsonLength = 86753090 };

// Perform your serialization
serializer.Serialize("Your JSON Contents"); 

Source