gpt4 book ai didi

asp.net-core - 将复杂对象保存到 session ASP .NET CORE 2.0

转载 作者:行者123 更新时间:2023-12-03 18:40:58 26 4
gpt4 key购买 nike

我对 ASP .NET 核心很陌生,所以请帮忙。我想避免 ASP .NET 核心应用程序的数据库往返。我有在数据网格中动态添加列的功能。列设置(可见性、启用、宽度、标题)存储在 DB 中。

所以我想在服务器 上存储 List<,PersonColumns> 仅用于实际 session 。但我无法做到这一点。我已经使用 JsonConvert 方法对 session 中的对象进行序列化和反序列化。这适用于 List<,Int32> 或具有简单属性的对象,但不适用于具有嵌套属性的复杂对象。

我想存储到 session 的对象如下所示:

[Serializable]
public class PersonColumns
{
public Int64 PersonId { get; set; }
List<ViewPersonColumns> PersonCols { get; set; }

public PersonColumns(Int64 personId)
{
this.PersonId = personId;
}

public void LoadPersonColumns(dbContext dbContext)
{
LoadPersonColumns(dbContext, null);
}

public void LoadPersonColumns(dbContext dbContext, string code)
{
PersonCols = ViewPersonColumns.GetPersonColumns(dbContext, code, PersonId);
}

public static List<ViewPersonColumns> GetFormViewColumns(SatisDbContext dbContext, string code, Int64 formId, string viewName, Int64 personId)
{
var columns = ViewPersonColumns.GetPersonColumns(dbContext, code, personId);

return columns.Where(p => p.FormId == formId && p.ObjectName == viewName).ToList();
}


}

我还想问一下,我的方法是将 600 条记录的列表保存到 session 中是否不错?每次用户想要显示网格时访问数据库和加载列是否更好?

任何建议表示赞赏

谢谢

编辑 :我已经测试在 session 中存储 List<,ViewPersonColumns> 并且它被正确保存。当我保存 List<,ViewPersonColumns> 是属性的对象时,只保存 内置类型 ,List 属性为空。

我想在 session 中保存的对象
[Serializable]
public class UserManagement
{
public String PersonUserName { get; set; }
public Int64 PersonId { get; set; }
public List<ViewPersonColumns> PersonColumns { get; set; } //not saved to session??

public UserManagement() { }

public UserManagement(DbContext dbContext, string userName)
{
var person = dbContext.Person.Single(p => p.UserName == userName);

PersonUserName = person.UserName;
PersonId = person.Id;
}

/*public void PrepareUserData(DbContext dbContext)
{
LoadPersonColumns(dbContext);
}*/

public void LoadPersonColumns(DbContext dbContext)
{
LoadPersonColumns(dbContext, null);
}

public void LoadPersonColumns(DbContext dbContext, string code)
{
PersonColumns = ViewPersonColumns.GetPersonColumns(dbContext, code, PersonId);
}

public List<ViewPersonColumns> GetFormViewColumns(Int64 formId, string viewName)
{
if (PersonColumns == null)
return null;

return PersonColumns.Where(p => p.FormId == formId && p.ObjectName == viewName).ToList();
}

}

将列保存到 session
UserManagement userManagement = new UserManagement(_context, user.UserName);
userManagement.LoadPersonColumns(_context);
HttpContext.Session.SetObject("ActualPersonContext", userManagement);
HttpContext.Session.SetObject("ActualPersonColumns", userManagement.PersonColumns);

从 session 中加载列
//userManagement build-in types are set. The PersonColumns is null - not correct
UserManagement userManagement = session.GetObject<UserManagement>("ActualPersonContext");
//The cols is filled from session with 600 records - correct
List<ViewPersonColumns> cols = session.GetObject<List<ViewPersonColumns>>("ActualPersonColumns");

最佳答案

每列使用列表比使用数据库更好。
您不能像 .net framework 4.0 那样在 .net core 中创建和存储 session

试试这样

Startup.cs

 public void ConfigureServices(IServiceCollection services)
{
//services.AddDbContext<GeneralDBContext>(options => options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")));

services.AddMvc().AddSessionStateTempDataProvider();
services.AddSession();
}


Common/SessionExtensions.cs

sing Microsoft.AspNetCore.Http;
using Newtonsoft.Json;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;

namespace IMAPApplication.Common
{
public static class SessionExtensions
{
public static T GetComplexData<T>(this ISession session, string key)
{
var data = session.GetString(key);
if (data == null)
{
return default(T);
}
return JsonConvert.DeserializeObject<T>(data);
}

public static void SetComplexData(this ISession session, string key, object value)
{
session.SetString(key, JsonConvert.SerializeObject(value));
}
}
}


用法
  • ==> 创建 session *


  • public IActionResult Login([FromBody]LoginViewModel model)
    {
    LoggedUserVM user = GetUserDataById(model.userId);

    //Create Session with complex object
    HttpContext.Session.SetComplexData("loggerUser", user);

    return Json(new { status = result.Status, message = result.Message });

    }


  • ==> 获取 session 数据*


  •  public IActionResult Index()
    {
    //Get Session data
    LoggedUserVM loggedUser = HttpContext.Session.GetComplexData<LoggedUserVM>("loggerUser");
    }


    希望这是有帮助的。祝你好运。

    关于asp.net-core - 将复杂对象保存到 session ASP .NET CORE 2.0,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52330197/

    26 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com