395 lines
12 KiB
C#
395 lines
12 KiB
C#
/*******************************************************************************
|
||
* Copyright © 2016 HT.Cloud.Framework 版权所有
|
||
* Author: HT.Cloud
|
||
* Description: WaterCloud快速开发平台
|
||
* Website:
|
||
*********************************************************************************/
|
||
|
||
using System;
|
||
using System.Collections.Generic;
|
||
using System.Threading.Tasks;
|
||
|
||
namespace HT.Cloud.Code
|
||
{
|
||
public class OperatorProvider
|
||
{
|
||
//是否允许一个账户在多处登录
|
||
private static bool LoginMultiple = GlobalContext.SystemConfig.LoginMultiple;
|
||
|
||
//缓存过期时间
|
||
private static int LoginExpire = GlobalContext.SystemConfig.LoginExpire;
|
||
|
||
private static string projectPrefix = GlobalContext.SystemConfig.ProjectPrefix;
|
||
|
||
public static OperatorProvider Provider
|
||
{
|
||
get { return new OperatorProvider(); }
|
||
}
|
||
|
||
//watercloud_operator_pc_ PC端登录
|
||
//watercloud_operator_info_ 登录次数
|
||
//
|
||
/// <summary>
|
||
/// 缓存操作类
|
||
/// </summary>
|
||
private string cacheKeyOperator = projectPrefix + "_operator_";// +登录者token
|
||
|
||
private string cacheKeyToken = projectPrefix + "_token_";// +登录者token
|
||
private string cacheKeyError = projectPrefix + "_error_";// + Mark
|
||
|
||
/// <summary>
|
||
/// 秘钥
|
||
/// </summary>
|
||
private string LoginUserToken = projectPrefix + "_Token";
|
||
|
||
/// <summary>
|
||
/// 标记登录的浏览器
|
||
/// </summary>
|
||
private string LoginUserMarkKey = projectPrefix + "_Mark";
|
||
|
||
public string GetProvider(string key)
|
||
{
|
||
var token = GetToken();
|
||
if (!string.IsNullOrEmpty(token))
|
||
return token;
|
||
token = WebHelper.GetCookie(key).ToString();
|
||
if (!string.IsNullOrEmpty(token))
|
||
return token;
|
||
return WebHelper.GetSession(key).ToString();
|
||
}
|
||
|
||
public void SetProvider(string key, string value)
|
||
{
|
||
WebHelper.WriteCookie(key, value);
|
||
WebHelper.WriteSession(key, value);
|
||
}
|
||
|
||
public string GetToken()
|
||
{
|
||
try
|
||
{
|
||
if (GlobalContext.HttpContext == null)
|
||
{
|
||
return null;
|
||
}
|
||
//查请求头
|
||
string token = GlobalContext.HttpContext.Request.Headers[GlobalContext.SystemConfig.TokenName].ParseToString();
|
||
if (!String.IsNullOrEmpty(token)) return token;
|
||
|
||
//查参数
|
||
token = GlobalContext.HttpContext.Request.Query[GlobalContext.SystemConfig.TokenName];
|
||
if (!String.IsNullOrEmpty(token)) return token;
|
||
|
||
//查cookies
|
||
string cookie = GlobalContext.HttpContext.Request.Cookies[GlobalContext.SystemConfig.TokenName];
|
||
return cookie == null ? string.Empty : cookie;
|
||
}
|
||
catch (Exception)
|
||
{
|
||
return null;
|
||
}
|
||
}
|
||
|
||
public void RemoveProvider(string key)
|
||
{
|
||
WebHelper.RemoveCookie(key);
|
||
WebHelper.RemoveSession(key);
|
||
}
|
||
|
||
public OperatorModel GetCurrent()
|
||
{
|
||
OperatorModel operatorModel = new OperatorModel();
|
||
try
|
||
{
|
||
string loginMark = GetProvider(LoginUserMarkKey);
|
||
operatorModel = CacheHelper.Get<OperatorModel>(cacheKeyOperator + loginMark);
|
||
}
|
||
catch
|
||
{
|
||
operatorModel = null;
|
||
}
|
||
return operatorModel;
|
||
}
|
||
|
||
/// <summary>
|
||
/// 获取浏览器设配号
|
||
/// </summary>
|
||
/// <returns></returns>
|
||
public string GetMark()
|
||
{
|
||
string cookieMark = GetProvider(LoginUserMarkKey);
|
||
if (string.IsNullOrEmpty(cookieMark))
|
||
{
|
||
cookieMark = Guid.NewGuid().ToString();
|
||
SetProvider(LoginUserMarkKey, cookieMark);
|
||
}
|
||
return cookieMark;
|
||
}
|
||
|
||
/// <summary>
|
||
/// 登录者信息添加到缓存中
|
||
/// </summary>
|
||
/// <param name="userEntity">用户</param>
|
||
/// <param name="loginMark">设备标识uid</param>
|
||
/// <param name="facilityMark">设备类型</param>
|
||
/// <param name="cookie">是否保存cookie,默认是</param>
|
||
/// <returns></returns>
|
||
public async Task<string> AddLoginUser(OperatorModel operatorModel, string loginMark, string facilityMark)
|
||
{
|
||
string token = Guid.NewGuid().ToString();
|
||
try
|
||
{
|
||
// 填写登录信息
|
||
operatorModel.LoginToken = token;
|
||
//登录信息更新
|
||
if (string.IsNullOrEmpty(loginMark))
|
||
{
|
||
string cookieMark = GetProvider(LoginUserMarkKey);
|
||
if (string.IsNullOrEmpty(cookieMark))
|
||
{
|
||
operatorModel.loginMark = Guid.NewGuid().ToString();
|
||
SetProvider(LoginUserMarkKey, operatorModel.loginMark);
|
||
}
|
||
else
|
||
{
|
||
operatorModel.loginMark = cookieMark;
|
||
}
|
||
SetProvider(LoginUserToken, token);
|
||
}
|
||
else
|
||
{
|
||
operatorModel.loginMark = loginMark;
|
||
RemoveProvider(LoginUserMarkKey);
|
||
}
|
||
//redis 登录token列表更新
|
||
Dictionary<string, string> tokenMarkList = await CacheHelper.GetAsync<Dictionary<string, string>>(cacheKeyToken + operatorModel.UserId);
|
||
if (tokenMarkList == null)// 此账号第一次登录
|
||
{
|
||
tokenMarkList = new Dictionary<string, string>();
|
||
tokenMarkList.Add(operatorModel.loginMark, token);
|
||
}
|
||
else
|
||
{
|
||
if (tokenMarkList.ContainsKey(operatorModel.loginMark))
|
||
{
|
||
tokenMarkList[operatorModel.loginMark] = token;
|
||
}
|
||
else
|
||
{
|
||
tokenMarkList.Add(operatorModel.loginMark, token);
|
||
}
|
||
}
|
||
|
||
await CacheHelper.SetAsync(cacheKeyToken + operatorModel.UserId, tokenMarkList);
|
||
await CacheHelper.SetAsync(cacheKeyOperator + operatorModel.loginMark, operatorModel, LoginExpire);
|
||
await CacheHelper.RemoveAsync(cacheKeyOperator + facilityMark + operatorModel.UserId);
|
||
await CacheHelper.SetAsync(cacheKeyOperator + facilityMark + operatorModel.UserId, token, LoginExpire);
|
||
return token;
|
||
}
|
||
catch (Exception)
|
||
{
|
||
throw;
|
||
}
|
||
}
|
||
|
||
/// <summary>
|
||
/// 清空当前登录信息
|
||
/// </summary>
|
||
/// <param name="apitoken">apitoken</param>
|
||
/// <param name="facilityMark">设备类型</param>
|
||
public async Task EmptyCurrent(string facilityMark)
|
||
{
|
||
try
|
||
{
|
||
string token = GetProvider(LoginUserToken);
|
||
string loginMark = GetProvider(LoginUserMarkKey);
|
||
await EmptyCurrent(token, facilityMark, loginMark);
|
||
RemoveProvider(LoginUserMarkKey.Trim());
|
||
RemoveProvider(LoginUserToken.Trim());
|
||
}
|
||
catch (Exception)
|
||
{
|
||
}
|
||
}
|
||
|
||
/// <summary>
|
||
/// 清空当前登录信息
|
||
/// </summary>
|
||
/// <param name="token">登录票据</param>
|
||
/// <param name="facilityMark">登录设备</param>
|
||
/// <param name="loginMark">登录设备标识</param>
|
||
public async Task EmptyCurrent(string token, string facilityMark, string loginMark)
|
||
{
|
||
try
|
||
{
|
||
OperatorModel operatorInfo = await CacheHelper.GetAsync<OperatorModel>(cacheKeyOperator + loginMark);
|
||
if (operatorInfo != null)
|
||
{
|
||
Dictionary<string, string> tokenMarkList = await CacheHelper.GetAsync<Dictionary<string, string>>(cacheKeyToken + operatorInfo.UserId);
|
||
tokenMarkList.Remove(loginMark);
|
||
await CacheHelper.RemoveAsync(cacheKeyOperator + loginMark);
|
||
if (operatorInfo.LoginToken == token || facilityMark == "api_")
|
||
{
|
||
await CacheHelper.RemoveAsync(cacheKeyOperator + facilityMark + operatorInfo.UserId);
|
||
}
|
||
await CacheHelper.SetAsync(cacheKeyToken + operatorInfo.UserId, tokenMarkList);
|
||
await CacheHelper.RemoveAsync(facilityMark + GlobalContext.SystemConfig.TokenName + "_" + operatorInfo.UserId + "_" + operatorInfo.LoginTime);
|
||
}
|
||
}
|
||
catch (Exception)
|
||
{
|
||
}
|
||
}
|
||
|
||
/// <summary>
|
||
/// 判断登录状态
|
||
/// </summary>
|
||
/// <param name="facilityMark">登录设备</param>
|
||
/// <param name="apitoken">apitoken</param>
|
||
/// <returns>-1未登录,1登录成功,0登录过期,-2账号被顶</returns>
|
||
public async Task<OperatorResult> IsOnLine(string facilityMark)
|
||
{
|
||
try
|
||
{
|
||
string token = GetProvider(LoginUserToken);
|
||
string loginMark = GetProvider(LoginUserMarkKey);
|
||
return await IsOnLine(token, facilityMark, loginMark);
|
||
}
|
||
catch (Exception)
|
||
{
|
||
return new OperatorResult { stateCode = -1 };
|
||
}
|
||
}
|
||
|
||
/// <summary>
|
||
/// 判断登录状态
|
||
/// </summary>
|
||
/// <param name="token">登录票据</param>
|
||
/// <param name="facilityMark">登录设备</param>
|
||
/// <param name="loginMark">登录设备标识</param>
|
||
/// <returns>-1未登录,1登录成功,0登录过期,-2账号被顶</returns>
|
||
public async Task<OperatorResult> IsOnLine(string token, string facilityMark, string loginMark)
|
||
{
|
||
OperatorResult operatorResult = new OperatorResult();
|
||
operatorResult.stateCode = -1; // -1未登录,1登录成功,0登录过期
|
||
try
|
||
{
|
||
if (string.IsNullOrEmpty(token) || string.IsNullOrEmpty(loginMark))
|
||
{
|
||
return operatorResult;
|
||
}
|
||
OperatorModel operatorInfo = await CacheHelper.GetAsync<OperatorModel>(cacheKeyOperator + loginMark);
|
||
if (operatorInfo != null)
|
||
{
|
||
Dictionary<string, string> tokenMarkList = await CacheHelper.GetAsync<Dictionary<string, string>>(cacheKeyToken + operatorInfo.UserId);
|
||
if ((token == operatorInfo.LoginToken || facilityMark == "api_") && tokenMarkList.ContainsKey(operatorInfo.loginMark) && tokenMarkList[operatorInfo.loginMark] == operatorInfo.LoginToken)
|
||
{
|
||
////账号被顶(排除admin)
|
||
if (!LoginMultiple && !operatorInfo.IsSuperAdmin && operatorInfo.LoginToken != await CacheHelper.GetAsync<string>(cacheKeyOperator + facilityMark + operatorInfo.UserId))
|
||
{
|
||
operatorResult.stateCode = -2;
|
||
tokenMarkList = await CacheHelper.GetAsync<Dictionary<string, string>>(cacheKeyToken + operatorInfo.UserId);
|
||
tokenMarkList.Remove(loginMark);
|
||
await CacheHelper.SetAsync(cacheKeyToken + operatorInfo.UserId, tokenMarkList);
|
||
await CacheHelper.RemoveAsync(cacheKeyOperator + loginMark);
|
||
}
|
||
else
|
||
{
|
||
operatorResult.userInfo = operatorInfo;
|
||
operatorResult.stateCode = 1;
|
||
await CacheHelper.ExpireAsync(cacheKeyOperator + loginMark, LoginExpire);
|
||
await CacheHelper.ExpireAsync(cacheKeyOperator + facilityMark + operatorInfo.UserId, LoginExpire);
|
||
await CacheHelper.ExpireAsync(facilityMark + GlobalContext.SystemConfig.TokenName + "_" + operatorInfo.UserId + "_" + operatorInfo.LoginTime, LoginExpire);
|
||
}
|
||
}
|
||
}
|
||
return operatorResult;
|
||
}
|
||
catch (Exception)
|
||
{
|
||
return operatorResult;
|
||
}
|
||
}
|
||
|
||
#region 登录错误次数记录
|
||
|
||
/// <summary>
|
||
/// 获取当前登录错误次数
|
||
/// </summary>
|
||
/// <returns></returns>
|
||
public async Task<int> GetCurrentErrorNum()
|
||
{
|
||
int res = 0;
|
||
try
|
||
{
|
||
string cookieMark = GetProvider(LoginUserMarkKey);
|
||
if (string.IsNullOrEmpty(cookieMark))
|
||
{
|
||
cookieMark = Guid.NewGuid().ToString();
|
||
SetProvider(LoginUserMarkKey, cookieMark);
|
||
}
|
||
string num = await CacheHelper.GetAsync<string>(cacheKeyError + cookieMark);
|
||
if (!string.IsNullOrEmpty(num))
|
||
{
|
||
res = Convert.ToInt32(num);
|
||
}
|
||
}
|
||
catch (Exception)
|
||
{
|
||
}
|
||
return res;
|
||
}
|
||
|
||
/// <summary>
|
||
/// 增加错误次数
|
||
/// </summary>
|
||
/// <returns></returns>
|
||
public async Task<int> AddCurrentErrorNum()
|
||
{
|
||
int res = 0;
|
||
try
|
||
{
|
||
string cookieMark = GetProvider(LoginUserMarkKey);
|
||
if (string.IsNullOrEmpty(cookieMark))
|
||
{
|
||
cookieMark = Guid.NewGuid().ToString();
|
||
SetProvider(LoginUserMarkKey, cookieMark);
|
||
}
|
||
string num = await CacheHelper.GetAsync<string>(cacheKeyError + cookieMark);
|
||
if (!string.IsNullOrEmpty(num))
|
||
{
|
||
res = Convert.ToInt32(num);
|
||
}
|
||
res++;
|
||
num = res + "";
|
||
await CacheHelper.SetAsync(cacheKeyError + cookieMark, num, 24);
|
||
}
|
||
catch (Exception)
|
||
{
|
||
}
|
||
return res;
|
||
}
|
||
|
||
/// <summary>
|
||
/// 清除当前登录错误次数
|
||
/// </summary>
|
||
public async Task ClearCurrentErrorNum()
|
||
{
|
||
try
|
||
{
|
||
string cookieMark = GetProvider(LoginUserMarkKey);
|
||
if (string.IsNullOrEmpty(cookieMark))
|
||
{
|
||
cookieMark = Guid.NewGuid().ToString();
|
||
SetProvider(LoginUserMarkKey, cookieMark);
|
||
}
|
||
await CacheHelper.RemoveAsync(cacheKeyError + cookieMark);
|
||
}
|
||
catch (Exception)
|
||
{
|
||
}
|
||
}
|
||
|
||
#endregion 登录错误次数记录
|
||
}
|
||
} |