/// <summary>
        /// 获取所有的成语
        /// </summary>
        /// <returns></returns>
        public IList <cy_dict> GetAllcy_dict()
        {
            string key = GetAllKey();

            if (RedisBase.ContainsKey(key))
            {
                IList <cy_dict> cylist = RedisBase.List_GetList <cy_dict>(key);
                if (cylist != null && cylist.Count > 0)
                {
                    return(cylist);
                }
            }
            IList <cy_dict> cys = cy_dictDal.Ins.GetAllcy_dict();

            if (cys != null && cys.Count > 0)
            {
                foreach (var cy in cys)
                {
                    if (cy != null)
                    {
                        RedisBase.List_Add(key, cy);
                    }
                }
            }
            return(cys);
        }
        void ClearQC()
        {
            ClassLoger.Info("ClearQCPicJob.ClearQC", "定时清理图片文件任务启动");

            string key = CacheKey.GetQrCodeKey(DateTime.Now.AddDays(-1));

            if (RedisBase.ContainsKey(key))
            {
                int i = 0;
                while (IsWork)
                {
                    List <string> qcimageList = RedisBase.List_GetList <string>(key, i, 1000);
                    foreach (string pathStr in qcimageList)
                    {
                        try
                        {
                            if (File.Exists(pathStr))
                            {
                                File.Delete(pathStr);
                            }
                        }
                        catch (Exception ex) { }
                    }
                    i++;
                    if (qcimageList == null || qcimageList.Count == 0)
                    {
                        break;
                    }
                }

                RedisBase.List_RemoveAll <string>(key);
            }

            ClassLoger.Info("ClearQCPicJob.ClearQC", "图片文件清理完毕");
        }
        /// <summary>
        /// 用户是否已经登录
        /// </summary>
        /// <returns></returns>
        public bool ExistsLogin()
        {
            string base64Code = string.Empty;

            if (actionContext.Request.Headers.Contains("Authorization"))
            {
                base64Code = actionContext.Request.Headers.GetValues("Authorization").FirstOrDefault();
            }
            if (base64Code.IsNull())
            {
                return(false);
            }
            //code结构为:userid-UserAgent.MD5()-随机数-时间戳
            string code = EncryptUtil.UnBase64(base64Code);

            string[] para = code.Split(new[] { "-" }, StringSplitOptions.RemoveEmptyEntries);
            if (para.Length != 4)
            {
                return(false);
            }
            string key = (para[0] + para[1] + para[3]).MD5();

            if (!RedisBase.ContainsKey(key))
            {
                return(false);
            }
            return(true);
        }
示例#4
0
        /// <summary>
        /// 获取微信公共号的Access_token
        /// </summary>
        /// <returns></returns>
        public static string GetWeChatAccess_token()
        {
            string access_token = string.Empty;
            string key          = getaccess_tokenKey();

            if (RedisBase.ContainsKey(key))
            {
                access_token = RedisBase.Item_Get <string>(key);
            }
            else
            {
                string url        = string.Format("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={0}&secret={1}", SystemSet.Serviceappid, SystemSet.Serviceappsecret);
                string resultJson = HttpUtils.Ins.GET(url);
                if (!resultJson.IsNull())
                {
                    if (resultJson.Contains("errcode"))
                    {
                        //WeChatErrorResult errorResult = JsonHelper.DeserializeObject<WeChatErrorResult>(resultJson);
                        ClassLoger.Fail("WeChatAPIHelper.GetWeChatAccess_token", url);
                        ClassLoger.Fail("WeChatAPIHelper.GetWeChatAccess_token", resultJson);
                    }
                    else
                    {
                        Dictionary <string, object> resDic = JsonHelper.DeserializeObject(resultJson);
                        access_token = resDic["access_token"].TryToString();
                        int expires_in = resDic["expires_in"].TryToInt(100);
                        RedisBase.Item_Set <string>(key, access_token);
                        RedisBase.ExpireEntryAt(key, DateTime.Now.AddSeconds(expires_in));
                    }
                }
            }
            return(access_token);
        }
        /// <summary>
        /// 刷新当前用户信息【修改用户信息后刷新用户信息到缓存中】
        /// </summary>
        public void RefreshUser()
        {
            string key = GetKey();

            if (RedisBase.ContainsKey(key))
            {
                RedisBase.Item_Set(key, User);
            }
        }
示例#6
0
        public void UpdateWeChatUser(WeChatUser user)
        {
            WeChatUserDal.Ins.UpdateWeChatUser(user);
            string key = getGetWeChatUserByUnionIDKey(user.UnionID);

            if (RedisBase.ContainsKey(key))
            {
                RedisBase.Item_Remove(key);
            }
            RedisBase.Item_Set(key, user);
        }
示例#7
0
 public override void OnActionExecuting(ActionExecutingContext filterContext)
 {
     Models.RedisSession <UserInfo> redisSession = new Models.RedisSession <UserInfo>(filterContext.HttpContext, true, 120);
     if (!redisSession.IsExistKey("UserCode"))
     {
         string Key = filterContext.HttpContext.Request.RawUrl.MD5();
         if (!RedisBase.ContainsKey(Key))
         {
             RedisBase.Item_Set(Key, filterContext.HttpContext.Request.RawUrl);
         }
         filterContext.Result = new RedirectResult(WeChateSiteHelper.getOauthURL(Key));
     }
 }
        public UserInfo GetUser(string token)
        {
            //code结构为:userid-UserAgent.MD5()-随机数-时间戳
            string code = EncryptUtil.UnBase64(token);

            string[] para = code.Split(new[] { "-" }, StringSplitOptions.RemoveEmptyEntries);
            string   key  = (para[0] + para[1] + para[3]).MD5();

            if (!string.IsNullOrEmpty(key) && RedisBase.ContainsKey(key))
            {
                return(RedisBase.Item_Get <UserInfo>(key));
            }
            return(null);
        }
示例#9
0
        public UserInfo GetUserinfoByID(string userid)
        {
            string key = getuserkey(userid);

            if (RedisBase.ContainsKey(key))
            {
                return(RedisBase.Item_Get <UserInfo>(key));
            }
            else
            {
                UserInfo uinfo = UserInfoDal.Ins.GetUserinfoByID(userid);
                if (uinfo != null)
                {
                    RedisBase.Item_Set(key, uinfo);
                }
                return(uinfo);
            }
        }
示例#10
0
        public void DelUserinfo(UserInfo _userinfo)
        {
            UserInfoDal.Ins.DelUserinfo(_userinfo);
            if (!_userinfo.Openid.IsNull())
            {
                string openkey = getuseropenkey(_userinfo.Openid);
                if (RedisBase.ContainsKey(openkey))
                {
                    RedisBase.Item_Remove(openkey);
                }
            }
            string key = getuserkey(_userinfo.ID);

            if (RedisBase.ContainsKey(key))
            {
                RedisBase.Item_Remove(key);
            }
        }
示例#11
0
        public WeChatUser GetWeChatUserByUnionID(string UnionID)
        {
            string key = getGetWeChatUserByUnionIDKey(UnionID);

            if (RedisBase.ContainsKey(key))
            {
                return(RedisBase.Item_Get <WeChatUser>(key));
            }
            else
            {
                WeChatUser wuser = WeChatUserDal.Ins.GetWeChatUserByUnionID(UnionID);
                if (wuser != null)
                {
                    RedisBase.Item_Set(key, wuser);
                }
                return(wuser);
            }
        }
示例#12
0
        public string AddWeChatUser(WeChatUser user)
        {
            if (user == null)
            {
                return(string.Empty);
            }
            string id = WeChatUserDal.Ins.AddWeChatUser(user);

            user.ID = id;
            string key = getGetWeChatUserByUnionIDKey(user.UnionID);

            if (RedisBase.ContainsKey(key))
            {
                RedisBase.Item_Remove(key);
            }
            RedisBase.Item_Set(key, user);

            return(id);
        }
示例#13
0
        public string UpdateUserinfo(UserInfo _userinfo)
        {
            string id = UserInfoDal.Ins.UpdateUserinfo(_userinfo);

            if (!string.IsNullOrEmpty(id))
            {
                string key = getuserkey(id);
                if (RedisBase.ContainsKey(key))
                {
                    RedisBase.Item_Remove(key);
                }
                string openkey = getuseropenkey(_userinfo.Openid);
                if (RedisBase.ContainsKey(openkey))
                {
                    RedisBase.Item_Remove(openkey);
                }
                RedisBase.Item_Set(key, _userinfo);
                RedisBase.Item_Set(openkey, _userinfo);
            }
            return(id);
        }
        public async Task <IHttpActionResult> CheckPicCode([FromBody] CheckPicCodeViewModel piccode)
        {
            JsonResult <bool> result = new JsonResult <bool>();

            result.code = 1;
            result.msg  = "OK";
            if (piccode == null)
            {
                result.Result    = false;
                result.ResultMsg = "参数错误";
                return(Ok(result));
            }

            if (string.IsNullOrEmpty(piccode.token) || !RedisBase.ContainsKey(piccode.token))
            {
                result.Result    = false;
                result.ResultMsg = "验证码已过期";
                return(Ok(result));
            }
            result.Result = await Task.Run <bool>(() => {
                bool flag          = false;
                VerCodePic codepic = RedisBase.Item_Get <VerCodePic>(piccode.token);
                if (Math.Abs(codepic.Font1.X - piccode.x1) > 0.5 || Math.Abs(codepic.Font1.Y - piccode.y1) > 0.5 ||
                    Math.Abs(codepic.Font2.X - piccode.x2) > 0.5 || Math.Abs(codepic.Font2.Y - piccode.y2) > 0.5 ||
                    Math.Abs(codepic.Font3.X - piccode.x3) > 0.5 || Math.Abs(codepic.Font3.Y - piccode.y3) > 0.5 ||
                    Math.Abs(codepic.Font4.X - piccode.x4) > 0.5 || Math.Abs(codepic.Font4.Y - piccode.y4) > 0.5)
                {
                    flag             = false;
                    result.ResultMsg = "验证码错误";
                }
                else
                {
                    flag             = true;
                    result.ResultMsg = "验证码正确";
                }
                return(flag);
            });

            return(Ok(result));
        }
示例#15
0
        public UserInfo GetUserInfoByOpenID(string OpenID)
        {
            if (string.IsNullOrEmpty(OpenID))
            {
                return(null);
            }
            string key = getuseropenkey(OpenID);

            if (RedisBase.ContainsKey(key))
            {
                return(RedisBase.Item_Get <UserInfo>(key));
            }
            else
            {
                UserInfo uinfo = UserInfoDal.Ins.GetUserInfoByOpenID(OpenID);
                if (uinfo != null)
                {
                    RedisBase.Item_Set(key, uinfo);
                }
                return(uinfo);
            }
        }
        public async Task <IHttpActionResult> CheckSmsCode(string token, string telcode)
        {
            JsonResult <string> result = new JsonResult <string>();

            if (token.IsNull() || !RedisBase.ContainsKey(token))
            {
                result.code = 0;
                result.msg  = "invalid token";
                return(Ok(result));
            }
            string value = RedisBase.Item_Get <string>(token);

            if (telcode.IsNull() || value != telcode)
            {
                result.code = 0;
                result.msg  = "验证码错误";
                return(Ok(result));
            }
            result.code = 1;
            result.msg  = "验证码正确";
            return(Ok(result));
        }
示例#17
0
        /// <summary>
        /// 获取微信公共号jssdk调用接口临时凭证
        /// </summary>
        /// <returns></returns>
        public static string Getjsapi_ticket()
        {
            string key = Getjsapi_ticketKey();

            if (RedisBase.ContainsKey(key))
            {
                return(RedisBase.Item_Get <string>(key));
            }
            else
            {
                string ticket       = string.Empty;
                string Access_token = GetWeChatAccess_token();
                string url          = string.Format("https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token={0}&type=jsapi", Access_token);
                string resultJson   = HttpUtils.Ins.GET(url);
                Dictionary <string, object> resDic = JsonHelper.DeserializeObject(resultJson);
                if (resDic["errcode"].TryToInt(0) == 0)
                {
                    ticket = resDic["ticket"].TryToString();
                    RedisBase.Item_Set(key, ticket);
                    RedisBase.ExpireEntryAt(key, DateTime.Now.AddSeconds(resDic["expires_in"].TryToInt(7200)));
                }
                return(ticket);
            }
        }
示例#18
0
        public ActionResult CallBackRedirect()
        {
            //网络授权有有效期,最好用redis缓存
            //获取用户网络授权
            string code  = Request["code"].TryToString();
            string state = Request["state"].TryToString();

            ClassLoger.Info("WeixinRedirectController.CallBackRedirect", state, code);
            string access_token = string.Empty;
            string openid       = string.Empty;

            if (RedisBase.ContainsKey(code))
            {
                Access_tokenResult accResult = RedisBase.Item_Get <Access_tokenResult>(code);
                access_token = accResult.access_token;
                openid       = accResult.openid;
            }
            else
            {
                Access_tokenResult accResult = WeChatAccessTokenAPI.GetWeChatServiceAccess_token(code);
                RedisBase.Item_Set(code, accResult);
                RedisBase.ExpireEntryAt(code, DateTime.Now.AddSeconds(accResult.expires_in));
                access_token = accResult.access_token;
                openid       = accResult.openid;
            }

            //获取用户信息
            WeChatUserInfo userinfo = null;
            string         userkey  = getWeChatUserKey(access_token, openid);

            if (RedisBase.ContainsKey(userkey))
            {
                userinfo = RedisBase.Item_Get <WeChatUserInfo>(userkey);
            }
            else
            {
                userinfo = WeChatUserInfoAPI.GetWeChatUserInfo(access_token, openid);
                if (userinfo != null)
                {
                    RedisBase.Item_Set(userkey, userinfo);
                    RedisBase.ExpireEntryAt(userkey, DateTime.Now.AddDays(2));
                }
            }
            UserInfo _user = userbll.GetUserInfoByOpenID(userinfo.unionid);

            if (_user == null)
            {
                _user            = new UserInfo();
                _user.Openid     = userinfo.unionid;
                _user.CreateTime = DateTime.Now;
                _user.Headimgurl = userinfo.headimgurl;
                _user.Nickname   = userinfo.nickname;
                _user.Sex        = (SexEnum)userinfo.sex;
                _user.Name       = userinfo.nickname;
                _user.city       = userinfo.city;
                _user.province   = userinfo.province;
                userbll.UpdateUserinfo(_user);
            }
            ClassLoger.Info("CallBackRedirect", userkey);
            RedisSession <UserInfo> redissession = new Models.RedisSession <UserInfo>(HttpContext, true, 120);

            redissession["UserCode"] = _user;
            switch (state)
            {
            //普通用户个人中心
            case "UserCore":
                return(RedirectToAction("Index", "UserCore"));

            case "AdminCore":
            //return RedirectToAction("Index", "AdminCore");
            default:
                string url = HttpUtils.Ins.UrlDecode(state);
                if (RedisBase.ContainsKey(state))
                {
                    url = RedisBase.Item_Get <string>(state);
                }
                return(Redirect(url));
            }
        }
        /// <summary>
        /// 用户确认授权
        /// </summary>
        /// <param name="code"></param>
        /// <param name="state"></param>
        private void getUserinfo(string code, string state)
        {
            try
            {
                //网络授权有有效期,最好用redis缓存
                //获取用户网络授权

                string access_token = string.Empty;
                string openid       = string.Empty;
                if (RedisBase.ContainsKey(code))
                {
                    Access_tokenResult accResult = RedisBase.Item_Get <Access_tokenResult>(code);
                    access_token = accResult.access_token;
                    openid       = accResult.openid;
                }
                else
                {
                    Access_tokenResult accResult = WeChatAccessTokenAPI.GetWeChatAccess_token(code);
                    RedisBase.Item_Set(code, accResult);
                    RedisBase.ExpireEntryAt(code, DateTime.Now.AddSeconds(accResult.expires_in));
                    access_token = accResult.access_token;
                    openid       = accResult.openid;
                }

                //获取用户信息
                WeChatUserInfo userinfo = null;
                string         userkey  = getWeChatUserKey(access_token, openid);
                if (RedisBase.ContainsKey(userkey))
                {
                    userinfo = RedisBase.Item_Get <WeChatUserInfo>(userkey);
                }
                else
                {
                    userinfo = WeChatUserInfoAPI.GetWeChatUserInfo(access_token, openid);
                    if (userinfo != null)
                    {
                        RedisBase.Item_Set(userkey, userinfo);
                        RedisBase.ExpireEntryAt(userkey, DateTime.Now.AddDays(2));
                    }
                }
                WeChatUser wuser = userbll.GetWeChatUserByUnionID(userinfo.unionid);
                if (wuser == null)
                {
                    wuser = new WeChatUser();
                    wuser.PlatformOpenID = userinfo.openid;
                    wuser.UnionID        = userinfo.unionid;
                    userbll.AddWeChatUser(wuser);
                }
                else
                {
                    if (string.IsNullOrEmpty(wuser.PlatformOpenID))
                    {
                        wuser.PlatformOpenID = userinfo.openid;
                        wuser.UnionID        = userinfo.unionid;
                        userbll.UpdateWeChatUser(wuser);
                    }
                }
                UserInfoBll ubll  = new UserInfoBll();
                UserInfo    _user = ubll.GetUserInfoByOpenID(userinfo.unionid);
                // 用户绑定微信
                string bindkey = string.Format("bind_{0}", state);
                string msg     = MqttAgreement.GetWeChatLoginMA(state, true);
                if (RedisBase.ContainsKey(bindkey))
                {
                    //用户之前已经关注过微信公共号,需要把之前微信公共号账户中的信息更新到这个账户中
                    if (_user != null)
                    {
                        _user.Openid = "";
                        ubll.UpdateUserinfo(_user);
                    }
                    UserInfo binduser = RedisBase.Item_Get <UserInfo>(bindkey);
                    binduser.Openid = userinfo.unionid;
                    ubll.UpdateUserinfo(binduser);
                }
                else
                {
                    WeChatLogin login = loginbll.GetWeChatLoginByUUID(state);
                    if (login == null)
                    {
                        login            = new WeChatLogin();
                        login.UUID       = state;
                        login.CreateTime = DateTime.Now;
                        login.LoginData  = DateTime.Now.ToString("yyyy-MM-dd");
                    }
                    login.Headimgurl = userinfo.headimgurl;
                    login.Nickname   = userinfo.nickname;
                    login.Openid     = userinfo.unionid;
                    login.Sex        = userinfo.sex.TryToString();
                    login.State      = 1;
                    login.LoginData  = DateTime.Now.ToString("yyyy-MM-dd");
                    login.CreateTime = DateTime.Now;
                    loginbll.UpdateWeChatLogin(login);

                    if (_user == null)
                    {
                        _user            = new UserInfo();
                        _user.Openid     = userinfo.unionid;
                        _user.CreateTime = DateTime.Now;
                        _user.Headimgurl = userinfo.headimgurl;
                        _user.Nickname   = userinfo.nickname;
                        _user.Sex        = (SexEnum)userinfo.sex;
                        _user.Name       = userinfo.nickname;
                        _user.city       = userinfo.city;
                        _user.province   = userinfo.province;
                        ubll.UpdateUserinfo(_user);
                    }
                    //向客户端推送消息
                    MqttPublishClient.Ins.PublishOneClient(login.LockCode, msg);
                }
                MqttPublishClient.Ins.PublishAllClient(msg);
            }
            catch (Exception ex)
            {
                ClassLoger.Error("WeChatLoginCallBackController.getUserinfo", ex);
            }
        }
        public async Task <IHttpActionResult> SendSmSCode([FromBody] SendSMSCodeViewModel sendSmsCode)
        {
            JsonResult <string> result = new JsonResult <string>();

            result.code = 1;
            result.msg  = "OK";
            if (sendSmsCode == null)
            {
                result.code = 0;
                result.msg  = "参数错误";
                return(Ok(result));
            }
            string requestTimeskey = "AccountController.SendSmSCode";
            double times           = RedisBase.SortedSet_ZSCORE <string>(requestTimeskey, sendSmsCode.token);

            //if (times > 0)
            //{
            //    result.code = 0;
            //    result.msg = "验证码已失效";
            //    return Ok(result);
            //}

            if (string.IsNullOrEmpty(sendSmsCode.token) || !RedisBase.ContainsKey(sendSmsCode.token))
            {
                result.code = 0;
                result.msg  = "验证码已过期";
                return(Ok(result));
            }
            if (sendSmsCode.type == 0 && !sendSmsCode.tel.IsMobile())
            {
                result.code = 0;
                result.msg  = "invalid tel";
                return(Ok(result));
            }
            await Task.Run(() => {
                RedisBase.SortedSet_Zincrby <string>(requestTimeskey, sendSmsCode.token, 1);
                RedisBase.SortedSet_SetExpire(requestTimeskey, DateTime.Now.AddMinutes(10));

                VerCodePic codepic = RedisBase.Item_Get <VerCodePic>(sendSmsCode.token);
                if (Math.Abs(codepic.Font1.X - sendSmsCode.x1) > 0.5 || Math.Abs(codepic.Font1.Y - sendSmsCode.y1) > 0.5 ||
                    Math.Abs(codepic.Font2.X - sendSmsCode.x2) > 0.5 || Math.Abs(codepic.Font2.Y - sendSmsCode.y2) > 0.5 ||
                    Math.Abs(codepic.Font3.X - sendSmsCode.x3) > 0.5 || Math.Abs(codepic.Font3.Y - sendSmsCode.y3) > 0.5 ||
                    Math.Abs(codepic.Font4.X - sendSmsCode.x4) > 0.5 || Math.Abs(codepic.Font4.Y - sendSmsCode.y4) > 0.5)
                {
                    result.code = 0;
                    result.msg  = "验证码错误";
                }
                else
                {
                    //产生短信验证码
                    int code   = Utils.GetRandom(100000, 999999);
                    string key = cookieKey();
                    RedisBase.Item_Set(key, code.TryToString());
                    RedisBase.ExpireEntryAt(key, DateTime.Now.AddMinutes(10));
                    string tel = sendSmsCode.tel;
                    if (sendSmsCode.type == 1)
                    {
                        tel = RedisBase.Item_Get <string>(sendSmsCode.tel);
                    }
                    bool isSend = Utils.SendSMSVCode(code.TryToString(), tel);
                    if (isSend)
                    {
                        result.Result = key;
                    }
                    else
                    {
                        result.code = 0;
                        result.msg  = "发送失败";
                    }
                }
            });

            return(Ok(result));
        }