采用Microsoft.AspNetCore.Session
HttpContext.Session.SetString("CurrentUser", “A用户名称”);
我怎么在前端判断Session CurrentUser不是空的呢,然后显示出来
采用Microsoft.AspNetCore.Session
HttpContext.Session.SetString("CurrentUser", “A用户名称”);
我怎么在前端判断Session CurrentUser不是空的呢,然后显示出来
可以用控制器拦截,每一个请求都会判断是否登陆,未登陆则返回首页这样
一个最基本的控制器拦截,就是当我们直接通过在地址栏输入访问路由地址时,首先应该判断用户是否已经登录,如果没有登录应该实现跳转到登录页面。大致思路是通过重写Controller的OnActionExecuting方法,在OnActionExecuting方法中判断用户是否登录并实现跳转。
3.1 新建控制器基类
在Fonour.MVC中右键Controllers文件夹,添加一个名称为FonourControllerBase的控制器基类,内容如下。
复制代码
public abstract class FonourControllerBase : Controller
{
public override void OnActionExecuting(ActionExecutingContext filterContext)
{
byte[] result;
filterContext.HttpContext.Session.TryGetValue("CurrentUser",out result);
if (result == null)
{
filterContext.Result = new RedirectResult("/Login/Index");
return;
}
base.OnActionExecuting(filterContext);
}
}
复制代码
需要进行登陆验证的控制器,修改为从FonourControllerBase继承,这里我们修改HomeController
public class HomeController : FonourControllerBase
启动程序,在未登录情况下,通过地址栏直接访问/Home/Index,会发现已经自动跳转到系统登录界面。