Claude Code接入Github

Claude Code接入Github

目前AI编程工具可以分为3种类别:

  1. 1.本地IDE,代表产品有cursor、windsurf
  2. 2.在线网站,代表产品有lovable、bolt.new
  3. 3.命令行,代表产品有claude code、codex

claude code这种命令行工具可以很方便地集成到各种平台中,本篇文章就是介绍如何把claude code快速接入到github中,在开发流程中嵌入AI能力。

claude code 接入github,我们不需要重复造轮子,anthropic官方提供并开源了名为claude code action(https://github.com/anthropics/claude-code-action)的工具,claude code action更新很频繁,前段时间刚发布了正式版本v1,借助它可以快速把claude code集成到github中。

接下来按照配置api key、在github安装claude、让claude code参与开发3个步骤,分享一下如何把claude code集成到github。

配置api key

claude对国内账号封控很严重,我们很难用到claude官方的api,好在国产模型进步很快,并且都原生提供anthropic接口格式了,可以作为sonnet的平替接入claude code。我测试glm-4.6和kimi-k2都能够驱动claude code正常运行。可以在 https://bigmodel.cn/usercenter/proj-mgmt/apikeys 创建glm的api key,在 https://platform.moonshot.cn/console/api-keys 创建kimi的api key,然后在你期望接入claude code的github仓库中配置api key。

进入github仓库中,点击settings,然后选择secrets and variables中的actions,点击new repository secret按钮。

在新打开的页面中填写Name:ANTHROPIC_API_KEY,Secret:你刚刚创建的glm 或 kimi api key,最后点击add secret配置成功。

在github安装claude

接下来,需要在GitHub中安装claude。在浏览器打开 https://github.com/apps/claude,进入claude github app页面,点击install按钮安装claude应用,如果按钮位置显示的不是install而是configure,表示已经安装过该应用。

然后在下面的安装确认页面中,可以配置安装到所有仓库或者指定仓库中,点击install & authorize按钮确认安装。

在安装成功后,如果你的github仓库还没有.github/workflows目录,你需要先创建该目录,然后在该目录中添加claude.yml和claude-review.yml文件。

claude.yml文件内容如下

name: Claude Code on:   issue_comment:     types: [created]   pull_request_review_comment:     types: [created]   issues:     types: [opened, assigned]   pull_request_review:     types: [submitted] jobs:   claude:     if: |       (github.event_name == 'issue_comment' && contains(github.event.comment.body, '@claude')) ||       (github.event_name == 'pull_request_review_comment' && contains(github.event.comment.body, '@claude')) ||       (github.event_name == 'pull_request_review' && contains(github.event.review.body, '@claude')) ||       (github.event_name == 'issues' && (contains(github.event.issue.body, '@claude') || contains(github.event.issue.title, '@claude')))     runs-on: ubuntu-latest     permissions:       contents: write       pull-requests: write       issues: write       id-token: write       actions: write     steps:       - name: Checkout repository         uses: actions/checkout@v4         with:           fetch-depth: 1       - name: Run Claude Code         id: claude         uses: anthropics/claude-code-action@v1         env:           # ANTHROPIC_BASE_URL: https://api.moonshot.cn/anthropic           ANTHROPIC_BASE_URL: https://open.bigmodel.cn/api/anthropic         with:           anthropic_api_key: ${{ secrets.ANTHROPIC_API_KEY }}           claude_args: |             --allowedTools "mcp__github_inline_comment__create_inline_comment,Bash(gh pr comment:*),Bash(gh pr diff:*),Bash(gh pr view:*),Bash(gh issue:*),Bash(gh search:*),Bash(gh label:*)"

claude-review.yml文件内容如下

name: Claude Review on:   pull_request:     types: [opened, synchronize]     # Optional: Only run on specific file changes     # paths:     #   - "src/**/*.ts"     #   - "src/**/*.tsx"     #   - "src/**/*.js"     #   - "src/**/*.jsx" jobs:   claude-review:     # Optional: Filter by PR author     # if: |     #   github.event.pull_request.user.login == 'external-contributor' ||     #   github.event.pull_request.user.login == 'new-developer' ||     #   github.event.pull_request.author_association == 'FIRST_TIME_CONTRIBUTOR'     runs-on: ubuntu-latest     permissions:       contents: read       pull-requests: write       id-token: write     steps:       - name: Checkout repository         uses: actions/checkout@v4         with:           fetch-depth: 0       - name: Run Claude Review         id: claude-review         uses: anthropics/claude-code-action@v1         env:           # ANTHROPIC_BASE_URL: https://api.moonshot.cn/anthropic           ANTHROPIC_BASE_URL: https://open.bigmodel.cn/api/anthropic         with:           anthropic_api_key: ${{ secrets.ANTHROPIC_API_KEY }}           track_progress: true           prompt: |             REPO: ${{ github.repository }}             PR NUMBER: ${{ github.event.pull_request.number }}             Please review this pull request with a focus on:             - Code quality and best practices             - Potential bugs or issues             - Security implications             - Performance considerations             Provide detailed feedback using inline comments for specific issues.             Please respond in Simplified Chinese.           claude_args: |             --allowedTools "mcp__github_inline_comment__create_inline_comment,Bash(gh pr comment:*),Bash(gh pr diff:*),Bash(gh pr view:*)"

注意在上面两个文件中有 ANTHROPIC_BASE_URL 配置,默认配置的是glm网址,如果使用的kimi模型,需要更改为 https://api.moonshot.cn/anthropic。另外在配置文件最后有--allowedTools参数,claude code使用的是工具白名单,如果需要某个特定的工具,需要配置到该参数中。

可能有人不熟悉.github/workflows目录,它是github中的保留目录,用于保存自动化工作流程的配置文件,可以配置当触发某些事件时执行哪些操作。比如可以在此目录中配置实现当提交新的代码时自动运行打包镜像、测试代码等功能。claude code action也是通过此机制实现的让claude回答用户提问、自动审阅代码等功能。

让claude code参与开发

执行完上述步骤,claude code就已经接入到你的github仓库中了。你可以在github中issue中评论@claude,让ai回答你的问题甚至可以让ai直接提交代码完成你的需求。下面是一些例子

我创建了python包管理方案讨论的issue,在评论中询问claude,让claude推荐一个方案。

在一个后端接口需求中直接让claude实现该需求,claude code能够提交代码到某个分支,点击Create PR链接可以手动创建代码合并。

除了可以在issue/pr中@claude以外,claude-review.yml工作流还支持自动审阅代码。提交pr后,claude可以自动审阅提交的代码,查看代码中的问题,并给出改进建议。

Read more

【HarmonyOS 6.0】Media Kit:细粒度控制屏幕捕获,详解图像填充模式C API

【HarmonyOS 6.0】Media Kit:细粒度控制屏幕捕获,详解图像填充模式C API

文章目录 * 1 -> 概述:从“能录”到“录得好”——Media Kit的战略性升级 * 2 -> 基础概念:理解屏幕捕获中的“画布”与“填充” * 2.1 -> 捕获源与目标区域 * 2.2 -> 矛盾的焦点:宽高比不一致 * 2.3 -> 填充模式 (`OH_AVScreenCapture_FillMode`) * 3 -> API详解:设置捕获策略的完整链路 * 3.1 -> 核心数据结构:`OH_AVScreenCapture_

By Ne0inhk
Linux 底层深入:目标文件、ELF 格式与程序加载全解析

Linux 底层深入:目标文件、ELF 格式与程序加载全解析

🔥草莓熊Lotso:个人主页 ❄️个人专栏: 《C++知识分享》《Linux 入门到实践:零基础也能懂》 ✨生活是默默的坚持,毅力是永久的享受! 🎬 博主简介: 文章目录 * 前言: * 一. 目标文件:编译后的 “半成品” * 1.1 目标文件的本质 * 1.2 目标文件的生成与验证 * 1.3 目标文件的核心问题:未解析的外部符号 * 二. ELF 文件:Linux 下的 “万能二进制格式” * 2.1 ELF 文件的四大类型 * 2.2 ELF 文件的核心结构 * 2.2.1 ELF 头:文件的 “身份证” * 2.2.

By Ne0inhk
Linux匿名管道通信:原理深挖+代码实现,一篇吃透进程间数据流转

Linux匿名管道通信:原理深挖+代码实现,一篇吃透进程间数据流转

🔥个人主页:Cx330🌸 ❄️个人专栏:《C语言》《LeetCode刷题集》《数据结构-初阶》《C++知识分享》 《优选算法指南-必刷经典100题》《Linux操作系统》:从入门到入魔 《Git深度解析》:版本管理实战全解 🌟心向往之行必能至 🎥Cx330🌸的简介: 目录 前言: 一. 进程间通信介绍 1.1 进程间通信目的 1.2 进程间通信的发展与分类 二、先搞懂:什么是管道?匿名管道有何特殊性? 2.1 管道的本质 2.2 管道的核心特性 三、匿名管道的创建 3.1 匿名管道的创建流程 3.2 匿名管道的使用示例 四. 核心深挖:匿名管道的底层原理 4.1 fork

By Ne0inhk

多模态AI前沿:从Agent构建到视频AIGC

多模态AI前沿:从Agent构建到视频AIGC 2025年,多模态AI(Multimodal AI)已成为人工智能领域的核心前沿,它通过融合文本、图像、音频、视频等多种数据模态,实现更接近人类感知的智能系统。这一演进路径从“Agent构建”——即构建自主、多模态协作的AI代理(Agents),逐步延伸到“视频AIGC”——即AI生成内容(AI Generated Content)的视频创作革命。根据Gartner预测,到2027年,40%的生成式AI解决方案将全面多模态化,而2025年已见证市场规模从2024年的16亿美元飙升至更高水平,CAGR超过32.7%。 本文将从Agent构建入手,逐步探讨至视频AIGC的最新进展、关键技术和应用趋势。 1. 多模态AI Agent的构建:从模块化到自主协作 多模态AI Agent是指能够处理多种输入(如文本+视频+语音),并通过规划、反思和执行实现复杂任务的智能实体。不同于单一模态的LLM(如GPT系列),这些Agent强调“代理性”(Agentic)

By Ne0inhk