在网站根目录下放置 webhook.php 自动部署文件,而后GitHub服务器的对应项目的 webhooks 配置上该文件的网址(Payload URL)与 密钥(Secret),需启用php的shell_exec函数。 php
webhook.php 代码git
<?php $target = '/home/www/im'; // 生产环境web目录 //密钥 $secret = "123456"; $wwwUser = 'www'; $wwwGroup = 'www'; //日志文件地址 $fs = fopen('../storage/logs/gitHubAuto_hook.log', 'a'); //获取GitHub发送的内容 $json = file_get_contents('php://input'); $content = json_decode($json, true); //github发送过来的签名 $signature = $_SERVER['HTTP_X_HUB_SIGNATURE']; if (!$signature) { fclose($fs); return http_response_code(404); } list($algo, $hash) = explode('=', $signature, 2); //计算签名 $payloadHash = hash_hmac($algo, $json, $secret); // 判断签名是否匹配 if ($hash === $payloadHash) { $cmd = "cd $target && git pull"; $res = shell_exec($cmd); $res_log .= 'Success:'.PHP_EOL; $res_log .= $content['head_commit']['author']['name'] . ' 在' . date('Y-m-d H:i:s') . '向' . $content['repository']['name'] . '项目的' . $content['ref'] . '分支push了' . count($content['commits']) . '个commit:' . PHP_EOL; $res_log .= $res.PHP_EOL; $res_log .= '======================================================================='.PHP_EOL; fwrite($fs, $res_log); $fs and fclose($fs); } else { $res_log = 'Error:'.PHP_EOL; $res_log .= $content['head_commit']['author']['name'] . ' 在' . date('Y-m-d H:i:s') . '向' . $content['repository']['name'] . '项目的' . $content['ref'] . '分支push了' . count($content['commits']) . '>个commit:' . PHP_EOL; $res_log .= '密钥不正确不能pull'.PHP_EOL; $res_log .= '======================================================================='.PHP_EOL; fwrite($fs, $res_log); $fs and fclose($fs); }