예제 #1
0
 public SSOAuthUtil(ObjCacheProvider <UserAuthSession> objCacheProvider
                    , UserManagerApp userManager
                    , AppInfoService infoService)
 {
     _objCacheProvider = objCacheProvider;
     _userManager      = userManager;
     _appInfoService   = infoService;
 }
예제 #2
0
 public LoginParse(AppInfoService infoService, ICacheContext cacheContext, IRepository <User, OpenAuthDBContext> userApp)
 {
     _appInfoService = infoService;
     _cacheContext   = cacheContext;
     _app            = userApp;
 }
예제 #3
0
        public static LoginResult Parse(PassportLoginRequest model)
        {
            var result = new LoginResult();

            try
            {
                model.Trim();
                //获取应用信息
                var appInfo = new AppInfoService().Get(model.AppKey);
                if (appInfo == null)
                {
                    throw  new Exception("应用不存在");
                }
                //获取用户信息
                User userInfo = null;
                if (model.Account == "System")
                {
                    userInfo = new User
                    {
                        Id       = Guid.Empty.ToString(), //TODO:可以根据需要调整
                        Account  = "System",
                        Name     = "超级管理员",
                        Password = Infrastructure.Md5.Encrypt("123456")
                    };
                }
                else
                {
                    var usermanager = (UserManagerApp)DependencyResolver.Current.GetService(typeof(UserManagerApp));
                    userInfo = usermanager.Get(model.Account);
                }
                if (userInfo == null)
                {
                    throw new Exception("用户不存在");
                }
                if (userInfo.Password.ToLower() != model.Password.ToLower())
                {
                    throw new Exception("密码错误");
                }
                var currentSession = new UserAuthSession
                {
                    Account    = model.Account,
                    Name       = userInfo.Name,
                    Token      = Guid.NewGuid().ToString().GetHashCode().ToString("x"),
                    AppKey     = model.AppKey,
                    CreateTime = DateTime.Now,
                    IpAddress  = HttpContext.Current.Request.UserHostAddress
                };
                //创建Session
                new ObjCacheProvider <UserAuthSession>().Create(currentSession.Token, currentSession, DateTime.Now.AddDays(10));

                result.Code      = 200;
                result.ReturnUrl = appInfo.ReturnUrl;
                result.Token     = currentSession.Token;
            }
            catch (Exception ex)
            {
                result.Code    = 500;
                result.Message = ex.Message;
            }

            return(result);
        }
예제 #4
0
 public LoginParse(ObjCacheProvider <UserAuthSession> objCacheProvider
                   , AppInfoService infoService)
 {
     _objCacheProvider = objCacheProvider;
     _appInfoService   = infoService;
 }
예제 #5
0
        public static LoginResult Parse(PassportLoginRequest model)
        {
            var result = new LoginResult();

            try
            {
                model.Trim();
                //获取应用信息
                var appInfo = new AppInfoService().Get(model.AppKey);
                if (appInfo == null)
                {
                    throw  new Exception("应用不存在");
                }
                //获取用户信息
                User userInfo = null;
                if (model.UserName == "System")
                {
                    userInfo = new User
                    {
                        Id       = Guid.Empty,
                        Account  = "System",
                        Name     = "超级管理员",
                        Password = "******"
                    };
                }
                if (model.UserName == "guest")
                {
                    userInfo = new User
                    {
                        Id       = Guid.Empty,
                        Account  = "guest",
                        Name     = "游客",
                        Password = ""
                    };
                }
                else if (model.UserName != "System")
                {
                    var usermanager = (UserManagerApp)DependencyResolver.Current.GetService(typeof(UserManagerApp));
                    userInfo = usermanager.Get(model.UserName);
                }

                if (userInfo == null)
                {
                    throw new Exception("用户不存在");
                }
                if (userInfo.Account != "guest")
                {
                    if (userInfo.Password != model.Password)
                    {
                        throw new Exception("密码错误");
                    }
                }

                var currentSession = new UserAuthSession
                {
                    UserName   = model.UserName,
                    Token      = Guid.NewGuid().ToString().GetHashCode().ToString("x"),
                    AppKey     = model.AppKey,
                    CreateTime = DateTime.Now,
                    IpAddress  = HttpContext.Current.Request.UserHostAddress
                };

                //创建Session
                new ObjCacheProvider <UserAuthSession>().Create(currentSession.Token, currentSession, DateTime.Now.AddDays(10));

                result.Success   = true;
                result.ReturnUrl = appInfo.ReturnUrl;
                result.Token     = currentSession.Token;
            }
            catch (Exception ex)
            {
                result.Success  = false;
                result.ErrorMsg = ex.Message;
            }

            return(result);
        }