解決MVC返回Json中日期格式問題


問題:MVC中使用控制器返回JsonResult,如果帶有日期字段的對象,瀏覽器接收到的json中會變成形如/Date('123123123')/格式。如何在easyui等中直接使用是個麻煩事。

解決方法:從源頭開始。既然Controller控制器的Json()方法會自動轉化,那我們就給它擴展一下,把格式化日期的功能替換成我們自己寫的格式:

首先,我們繼承JsonResult寫一個類,重載他的ExcuteResult:

    /// <summary>
    /// 提供自定義日期格式 Json
    /// </summary>
    public class CustomJsonResult : JsonResult
    {
        public override void ExecuteResult(ControllerContext context)
        {
            if (context == null)
            {
                throw new ArgumentNullException("context");
            }
            
            HttpResponseBase response = context.HttpContext.Response;

            if (Data != null)
            {
                var timeConverter = new IsoDateTimeConverter {DateTimeFormat = "yyyy-MM-dd HH:mm:ss"};//這里使用自定義日期格式,默認是ISO8601格式        
                response.Write(JsonConvert.SerializeObject(Data,Formatting.Indented,timeConverter));
            }
        }
    }


然后,繼承Controller,實現一個BaseController

    /// <summary>
    /// 本項目所有控制器的基類,提供Json方法,用來自定義格式化日期
    /// </summary>public class BaseController : Controller
    {
        protected override JsonResult Json(object data, string contentType, Encoding contentEncoding)
        {
            return new CustomJsonResult {Data = data, ContentType = contentType, ContentEncoding = contentEncoding};
        }

        public new JsonResult Json(object data, JsonRequestBehavior jsonRequest)
        {
            return new CustomJsonResult {Data = data, JsonRequestBehavior = jsonRequest};
        }

        public new JsonResult Json(object data)
        {
            return new CustomJsonResult {Data = data, JsonRequestBehavior = JsonRequestBehavior.AllowGet};
        }
    }


使用時,首先保證你的控制器是繼承自BaseController,而不是Controller,舉個栗子:

        public JsonResult UserSrc()
        {
            var q = from u in db.T_User.Where(p=>!p.DelFlag)
                    select
                        new
                        {
                            UserID = u.UserID,
                            UserName = u.UserName,
                            RealName = u.RealName,
                            Date=u.Date
};
return Json(q); }

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM