public static SendCustomLog ( string typeName, string content ) : void | ||
typeName | string | 日志类型 |
content | string | 日志内容 |
return | void |
/// <summary> /// 开始 Senparc.Weixin SDK 初始化参数流程 /// </summary> /// <param name="registerService"></param> /// <param name="senparcWeixinSetting">微信全局设置参数,必填</param> /// <param name="senparcSetting">用于提供 SenparcSetting.Cache_Redis_Configuration 和 Cache_Memcached_Configuration 两个参数,如果不使用这两种分布式缓存可传入null</param> /// <returns></returns> public static IRegisterService UseSenparcWeixin(this IRegisterService registerService, SenparcWeixinSetting senparcWeixinSetting, SenparcSetting senparcSetting = null) { senparcWeixinSetting = senparcWeixinSetting ?? new SenparcWeixinSetting(); senparcSetting = (senparcSetting ?? CO2NET.Config.SenparcSetting) ?? new SenparcSetting(); //Senparc.Weixin SDK 配置 Senparc.Weixin.Config.SenparcWeixinSetting = senparcWeixinSetting; /* 扩展缓存注册开始 */ var cacheTypes = "";//所有注册的扩展缓存 // 微信的 本地 缓存 var cache = LocalContainerCacheStrategy.Instance;//只要引用就可以被激活 cacheTypes += typeof(LocalContainerCacheStrategy); var dt1 = SystemTime.Now; //官方扩展缓存注册 //var officialTypes = new List<Type>() { typeof(LocalContainerCacheStrategy) };//官方提供的扩展缓存策略 //自动注册 Redis 和 Memcached //Redis var redisConfiguration = senparcSetting.Cache_Redis_Configuration; if (!string.IsNullOrEmpty(redisConfiguration) && /*缓存配置默认值,不启用*/ redisConfiguration != "Redis配置" && redisConfiguration != "#{Cache_Redis_Configuration}#") { try { { //StackExchange.Redis var redisInstance = ReflectionHelper.GetStaticMember("Senparc.Weixin.Cache.Redis", "Senparc.Weixin.Cache.Redis", "RedisContainerCacheStrategy", "Instance"); if (redisInstance != null) { //officialTypes.Add(redisInstance.GetType()); cacheTypes += "\r\n" + redisInstance.GetType(); } } { //CsRedis var redisInstance = ReflectionHelper.GetStaticMember("Senparc.Weixin.Cache.CsRedis", "Senparc.Weixin.Cache.CsRedis", "RedisContainerCacheStrategy", "Instance"); if (redisInstance != null) { //officialTypes.Add(redisInstance.GetType()); cacheTypes += "\r\n" + redisInstance.GetType(); } } } catch (Exception ex) { WeixinTrace.WeixinExceptionLog(new Exceptions.WeixinException(ex.Message, ex)); } } //Memcached var memcachedConfiguration = senparcSetting.Cache_Memcached_Configuration; if (!string.IsNullOrEmpty(memcachedConfiguration) && /*缓存配置默认值,不启用*/ memcachedConfiguration != "Memcached配置" && memcachedConfiguration != "#{Cache_Memcached_Configuration}#") { try { var memcachedInstance = ReflectionHelper.GetStaticMember("Senparc.Weixin.Cache.Memcached", "Senparc.Weixin.Cache.Memcached", "MemcachedContainerCacheStrategy", "Instance"); if (memcachedInstance != null) { //officialTypes.Add(memcachedInstance.GetType()); cacheTypes += "\r\n" + memcachedInstance.GetType(); } } catch (Exception ex) { WeixinTrace.WeixinExceptionLog(new Exceptions.WeixinException(ex.Message, ex)); } } var exCacheLog = $"微信扩展缓存注册总用时:{SystemTime.DiffTotalMS(dt1, "f4")}ms\r\n扩展缓存:{cacheTypes}"; WeixinTrace.SendCustomLog("微信扩展缓存注册完成", exCacheLog); /* 扩展缓存注册结束 */ //ApiBind 自动扫描 Senparc.NeuChar.Register.RegisterApiBind(false); return(registerService); }
/// <summary> /// 开始 Senparc.Weixin SDK 初始化参数流程 /// </summary> /// <param name="registerService"></param> /// <param name="senparcWeixinSetting">微信全局设置参数,必填</param> /// <param name="senparcSetting">用于提供 SenparcSetting.Cache_Redis_Configuration 和 Cache_Memcached_Configuration 两个参数,如果不使用这两种分布式缓存可传入null</param> /// <returns></returns> public static IRegisterService UseSenparcWeixin(this IRegisterService registerService, SenparcWeixinSetting senparcWeixinSetting, SenparcSetting senparcSetting = null) { senparcWeixinSetting = senparcWeixinSetting ?? new SenparcWeixinSetting(); senparcSetting = senparcSetting ?? new SenparcSetting(); //Senparc.Weixin SDK 配置 Senparc.Weixin.Config.SenparcWeixinSetting = senparcWeixinSetting; /* 扩展缓存注册开始 */ var cacheTypes = "";//所有注册的扩展缓存 // 微信的 本地 缓存 var cache = LocalContainerCacheStrategy.Instance;//只要引用就可以被激活 cacheTypes += typeof(LocalContainerCacheStrategy); DateTime dt1 = DateTime.Now; //官方扩展缓存注册 //var officialTypes = new List<Type>() { typeof(LocalContainerCacheStrategy) };//官方提供的扩展缓存策略 //自动注册 Redis 和 Memcached //Redis var redisConfiguration = senparcSetting.Cache_Redis_Configuration; if ((!string.IsNullOrEmpty(redisConfiguration) && redisConfiguration != "Redis配置")) { try { var redisInstance = ReflectionHelper.GetStaticMember("Senparc.Weixin.Cache.Redis", "Senparc.Weixin.Cache.Redis", "RedisContainerCacheStrategy", "Instance"); if (redisInstance != null) { //officialTypes.Add(redisInstance.GetType()); cacheTypes += "\r\n" + redisInstance.GetType(); } } catch (Exception ex) { WeixinTrace.WeixinExceptionLog(new Exceptions.WeixinException(ex.Message, ex)); } } //Memcached var memcachedConfiguration = senparcSetting.Cache_Memcached_Configuration; if ((!string.IsNullOrEmpty(memcachedConfiguration) && memcachedConfiguration != "Memcached配置")) { try { var memcachedInstance = ReflectionHelper.GetStaticMember("Senparc.Weixin.Cache.Memcached", "Senparc.Weixin.Cache.Memcached", "MemcachedContainerCacheStrategy", "Instance"); if (memcachedInstance != null) { //officialTypes.Add(memcachedInstance.GetType()); cacheTypes += "\r\n" + memcachedInstance.GetType(); } } catch (Exception ex) { WeixinTrace.WeixinExceptionLog(new Exceptions.WeixinException(ex.Message, ex)); } } DateTime dt2 = DateTime.Now; var exCacheLog = "微信扩展缓存注册总用时:{0}ms\r\n扩展缓存:{1}".FormatWith((dt2 - dt1).TotalMilliseconds, cacheTypes); WeixinTrace.SendCustomLog("微信扩展缓存注册完成", exCacheLog); /* 扩展缓存注册结束 */ //ApiBind 自动扫描 Senparc.NeuChar.Register.RegisterApiBind(); return(registerService); }