/// <summary>
        /// 验证用户的令牌openId
        /// </summary>
        /// <param name="userId">用户主键</param>
        /// <param name="openId">用户的令牌</param>
        /// <param name="systemCode">子系统</param>
        /// <param name="useCaching">采用缓存</param>
        /// <param name="useDataBase">采用数据库</param>
        /// <param name="useUserCenterHost">采用用户中心接口</param>
        /// <returns>验证通过</returns>
        public static bool ValidateOpenId(string userId, string openId, string systemCode = null, bool useCaching = true, bool useDataBase = false, bool useUserCenterHost = false)
        {
            var result = false;

            if (string.IsNullOrEmpty(systemCode))
            {
                systemCode = string.Empty;
            }

            // 2016-03-14 吉日嘎拉、PDA系统的单独处理、其他的都认为是一样的。
            if (!systemCode.Equals("PDA"))
            {
                systemCode = string.Empty;
            }

            if (!string.IsNullOrWhiteSpace(openId))
            {
                // 使用缓存进行验证、效率高,减少数据库的I/O压力。
                if (useCaching)
                {
                    var key = string.Empty;
                    if (string.IsNullOrEmpty(systemCode))
                    {
                        key = "openId:" + openId;
                    }
                    else
                    {
                        key = "openId:" + systemCode + ":" + openId;
                    }
                    result = string.IsNullOrEmpty(CacheUtil.Get <string>(key));
                }

                // 用数据库的方式进行验证
                if (!result && useDataBase)
                {
                    var userLogonManager = new BaseUserLogonManager();
                    result = userLogonManager.ValidateOpenId(userId, openId, systemCode);
                    if (result)
                    {
                        // 提高缓存效率、若读取到了,写入到缓存里去
                        if (!string.IsNullOrWhiteSpace(userId) && useCaching)
                        {
                            SetUserOpenId(userId, openId, systemCode);
                        }
                        result = true;
                    }
                }

                // 不能访问数据库时、通过远程用户中心服务进行验证OpenId、通过服务方式进行验证
                if (!result && useUserCenterHost)
                {
                    var url        = BaseSystemInfo.UserCenterHost + "/UserCenterV42/LogonService.ashx";
                    var webClient  = new WebClient();
                    var postValues = new NameValueCollection();
                    if (!string.IsNullOrEmpty(systemCode))
                    {
                        postValues.Add("systemCode", systemCode);
                    }
                    postValues.Add("ipAddress", Utils.GetIp());
                    postValues.Add("securityKey", BaseSystemInfo.SecurityKey);
                    postValues.Add("function", "ValidateOpenId");
                    postValues.Add("userId", userId);
                    postValues.Add("openId", openId);
                    // 向服务器发送POST数据
                    var responseArray = webClient.UploadValues(url, postValues);
                    var response      = Encoding.UTF8.GetString(responseArray);
                    if (!string.IsNullOrEmpty(response))
                    {
                        result = response.Equals(true.ToString(), StringComparison.InvariantCultureIgnoreCase);
                    }
                }
            }

            return(result);
        }