关于 GitHub 的 webhook 的 secret 的校验问题?

我的理解:
参考github的Webhook文档
我理解为附加在Header中的X-Hub-Signature是由payloadsecret通过sha1加密生成的.

我的校验代码

public function check(Request $request){
    $signature = "sha1=".hash_hmac('sha1',json_decode($request->payload),  env('WEBHOOK_SECRET_TOKEN') );
    if(strcmp($signature, $request->header('X-Hub-Signature')) == 0){
          return true;
    }
    return false;
} 

结果就是一直不匹配.

期间我参考了@shelter关于gitlab的webhook的大作
但是和我阅读github-webhook的验证原理似乎不太一样.

没有什么头绪, 上来求助, 感谢!

《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
讨论数量: 2
leo

json_encode($request->getContent())

7年前 评论

@leo 感谢提醒!
我最后测试成功的代码是

$signature = "sha1=".hash_hmac('sha1', $request->getContent(),  env('WEBHOOK_SECRET_TOKEN') );
7年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!