[转]Asp.net Core中选择Session

本文转自:http://www.cnblogs.com/sword-successful/p/6243841.html

前言

      前年就那样悄无声息的开始了,二零一七年对自家的话又是专程重庆大学的一年。

      元日放假在家写了个Asp.net Core验证码登录,
做demo的长河中相见五个小意思,第1是在Asp.net
Core中援引dll,以后我们引用DLL都以平素引用,在Core里这样是那贰个的,必须依据NuGet添加,只怕根据project.json添加,然后保留VS会运维苏醒类库。

其次正是使用Session的题材,Core里使用Session须要添加Session类库。

 

添加Session

     在您的花色上依据NuGet添加:Microsoft.AspNetCore.Session。

 

修改startup.cs

   
在startup.cs找到方法ConfigureServices(IServiceCollection services)
注入Session(这些地点是Asp.net Core pipeline):services.AddSession();

    接下去大家要报告Asp.net
Core使用内部存款和储蓄器存款和储蓄Session数据,在Configure(IApplicationBuilder
app,…)中添加代码:app.UserSession();

 

Session

1、在MVC Controller里使用HttpContext.Session

SQL Server 1😉

using Microsoft.AspNetCore.Http;

public class HomeController:Controller
{
      public IActionResult Index()
      {
              HttpContext.Session.SetString("code","123456");
              return View();  
       }

       public IActionResult About()
       {
              ViewBag.Code=HttpContext.Session.GetString("code");
              return View();
        }
}

SQL Server 2😉

② 、即便不是在Controller里,你能够注入IHttpContextAccessor

SQL Server 3😉

public class SomeOtherClass
{
      private readonly IHttpContextAccessor _httpContextAccessor;
      private ISession _session=> _httpContextAccessor.HttpContext.Session;

      public SomeOtherClass(IHttpContextAccessor httpContextAccessor)
     {
           _httpContextAccessor=httpContextAccessor;              
     }

     public void Set()
     {
          _session.SetString("code","123456");
     }

     public void Get()
    {
         string code = _session.GetString("code");
     }
}

SQL Server 4😉

 

存款和储蓄复杂对象

      存款和储蓄对象时把对象系列化成二个json字符串存款和储蓄。

SQL Server 5😉

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

    public static T GetObjectFromJson<T>(this ISession session, string key)
    {
        var value = session.GetString(key);

        return value == null ? default(T) : JsonConvert.DeserializeObject<T>(value);
    }
}

SQL Server 6😉

var myComplexObject = new MyClass();
HttpContext.Session.SetObjectAsJson("Test", myComplexObject);


var myComplexObject = HttpContext.Session.GetObjectFromJson<MyClass>("Test");

 

SQL Server,使用SQL Server或Redis存储

1、SQL Server

拉长引用  "Microsoft.Extensions.Caching.SqlServer": "1.0.0"

注入:

SQL Server 7😉

// Microsoft SQL Server implementation of IDistributedCache.
// Note that this would require setting up the session state database.
services.AddSqlServerCache(o =>
{
    o.ConnectionString = "Server=.;Database=ASPNET5SessionState;Trusted_Connection=True;";
    o.SchemaName = "dbo";
    o.TableName = "Sessions";
});

SQL Server 8😉

 

2、Redis

加上引用   "Microsoft.Extensions.Caching.Redis": "1.0.0"

注入:

// Redis implementation of IDistributedCache.
// This will override any previously registered IDistributedCache service.
services.AddSingleton<IDistributedCache, RedisCache>();

 

 参考

http://benjii.me/2016/07/using-sessions-and-httpcontext-in-aspnetcore-and-mvc-core/

博客地址: http://www.cnblogs.com/sword-successful/
博客版权: 本文以学习、研究和分享为主,欢迎转载,但必须在文章页面明显位置给出原文连接。 如果文中有不妥或者错误的地方还望高手的你指出,以免误人子弟。如果觉得本文对你有所帮助不如【推荐】一下!如果你有更好的建议,不如留言一起讨论,共同进步! 再次感谢您耐心的读完本篇文章。

 

分类: Asp.net
Core

 

相关文章