GitHub利用webhook实现push时项目自动部署

在网站根目录下放置 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);
      }
相关文章
相关标签/搜索