【EasyWeChat】http与console的缓存不通用导致报错Credential "component_verify_ticket" does not exist in cache的解决方法

【EasyWeChat】http与console的缓存不通用导致报错Credential "component_verify_ticket" does not exist in cache的解决方法

EasyWeChat是什么,在这里就不多说了。

【测试环境】

📀Windows10
📀php7.2.10
📀Apache2.4
📀Laravel5.4

做微信开发有一段时间了,一开始使用微信官方接口进行开发。后来改用EasyWeChat微信开发SDK,使用EasyWeChat后确实方便很多。但遇到一个问题,这个问题就是:在开发微信开放平台的时候,通过http路由访问时,所有功能都是没问题的,但是通过命令行console去实现消息发送的时候就会报错【Credential "component_verify_ticket" does not exist in cache】,当时由于时间紧迫,没怎么去考虑问题的原因,临时采用了比较掉牙的方法勉强实现了功能,就是通过新建一个路由,然后把原来命令需要执行的过程变为路由控制器执行的过程,最后通过原命令请求这个新建的路由。此方法留下了很多隐患,比如:如果路由外泄,谁都能去操作控制器的执行过程,这不是我们想看到的,当然你也可以加一些其他的辅助代码去规避一些可预见的不利操作(😄这样的话就有违Laravel框架的优雅😄)。

现在我们来分析原因:通过http访问没问题,说明component_verify_ticket是缓存成功的;通过console执行却说component_verify_ticket不在缓存内,初步判断应该是缓存驱动的问题。曾一度以为EasyWeChat的缓存配置与Laravel框架的缓存配置默认项是一致的,因为EasyWeChat的配置文件中有个use_laravel_cache配置项(其实这个配置项在目前来看没什么卵用)。

image

Laravel配置的是Redis缓存,通过查看EasyWeChat源码,找到component_verify_ticket缓存对应的键为

easywechat.kernel.access_token.【APPID】

然后在Redis中模糊查找 keys access_token发现没有匹配到结果,说明EasyWeChat的缓存驱动和Laravel框架配置的默认缓存驱动是不一样的。

❓EasyWeChat缓存不存在Redis中,那到底存在哪里了呢?飞外太空了?

查看了EasyWeChat官方文档后,文档是这么说的【EasyWeChat项目使用 symfony/cache 来完成缓存工作,SDK 中的所有缓存默认使用文件缓存,缓存路径取决于 PHP 的临时目录】

默认使用文件缓存,那就在Laravel下找文件缓存的位置\storage\framework\cache\data呗,然而目录下也没发现有任何文件,说明EasyWeChat的文件缓存路径与Laravel框架的文件缓存路径也是不一样的,即使你配置了use_laravel_cache(那个没什么卵用的配置项)为true。

再往后看,缓存路径取决于 PHP 的临时目录,那就是PHP的配置问题的。通过http访问与通过console执行,PHP的临时目录不一致。

🔍进行了测试:分别进行http访问输出sys_get_temp_dir()和console执行命令记录sys_get_temp_dir(),结果也在预料之内,不一样的结果:前者C:/Windows/Temp,后者C:\Users\z\AppData\Local\Temp。

最初的问题已转变为:如何使http过程中的PHP临时目录console过程中的PHP临时目录保持一致?

一般情况下安装PHP时,很多人不会去配置php.ini文件的 sys_temp_dir 选项。这个选项主要就是配置PHP 的临时目录。sys_temp_dir 选项默认是关闭的,在windows系统下默认配置的PHP的临时目录为C:/Windows/Temp。

配置sys_temp_dir 选项:sys_temp_dir = "C:/Windows/Temp"

🔍再进行测试:进行http访问输出sys_get_temp_dir()和console执行命令记录sys_get_temp_dir(),结果:两者都是C:/Windows/Temp

回到项目再进行测试,发现问题不存在了。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,284评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,115评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,614评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,671评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,699评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,562评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,309评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,223评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,668评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,859评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,981评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,705评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,310评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,904评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,023评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,146评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,933评论 2 355

推荐阅读更多精彩内容