問題簡介:前段時間做項目時,將取到的entity往Redis cache里存放時報多重引用的錯誤。
Self referencing loop detected for property 'CheckItemCategory' with type。
一、問題詳情
1、chectItemCategory與CheckItem實體介紹
2、我們用ef取了List<CheckItemCategory>,以Json的形式存放到redis中。但在JsonConvert.SerializeObject時報多重引用錯誤。
3、細追原因,NewtonSoft.Json 對Entity(CheckItemCategory)序列化時,會遍歷CheckItemCategory中的所有屬性進行轉換。當遇到導航屬性CheckItems時,會向數據庫繼續請求checkItems數據(ef延遲加載)。而在轉換checkItem實體時,checkItem實體里面又有CheckItemCategory導航屬性。CheckItemCategory與checkItem互相引用,多重引用死循環問題。
二、解決方案
1、方法1。推薦用這個。
在entity的checkItems導航屬性上加[JsonIgnore]特性來忽略該屬性。
關於newtonsoft.json高級用法參見 http://www.cnblogs.com/yanweidie/p/4605212.html
2、方法2。刪除CheckItemCategory類中的checkItems屬性。但是此方法治標不治本,(1)本來ef配置兩者外鍵關系時需要用
(2)在具體應用時可能已經在用他們的關系延遲加載,進行業務操作。
(3)在取checkItem轉json時也會將CheckItemCategory取出一並轉到json中去,比較坑。
三、思維延伸
在用webapi返回結果時,千萬不要直接返回entity,因為也會把導航屬性全部取出。暴露了其他數據信息。