0

0

使用 PHP 连接 Monday.com API:自动化潜在客户与交易创建教程

心靈之曲

心靈之曲

发布时间:2025-09-25 17:09:32

|

305人浏览过

|

来源于php中文网

原创

使用 PHP 连接 Monday.com API:自动化潜在客户与交易创建教程

本教程详细指导如何使用 PHP 和 Monday.com GraphQL API 在 Monday.com 平台中创建新的潜在客户或交易项。文章涵盖了 API 密钥配置、GraphQL 查询构建、数据映射以及通过 HTTP POST 请求发送数据到 Monday.com 的实现细节,并提供了完整的示例代码和注意事项,帮助开发者快速实现自动化数据录入。

引言

monday.com 作为一个强大的工作操作系统,广泛应用于项目管理、crm 等领域。通过其开放的 graphql api,我们可以实现与其他系统的深度集成,例如从外部表单自动创建潜在客户或交易。本教程将详细介绍如何使用 php 语言,结合 monday.com 的 graphql api,实现这一自动化流程。

准备工作

在开始之前,请确保您已具备以下条件:

  1. Monday.com API 密钥 (Token):这是访问 Monday.com API 的凭证。您可以在 Monday.com 账户的“管理”->“开发者”->“个人访问令牌”中生成。
  2. Monday.com 看板 (Board) ID:您希望创建潜在客户或交易项的看板 ID。
  3. PHP 运行环境:确保您的服务器或本地环境已安装 PHP。
  4. 了解 GraphQL 基础:Monday.com API 基于 GraphQL,了解其查询和变异 (mutation) 概念将有助于理解。

Monday.com GraphQL API 概览

Monday.com API 允许您通过 GraphQL 语言与平台进行交互。创建新的项(item,例如潜在客户或交易)是通过执行一个 mutation 操作来完成的。核心的 mutation 是 create_item,它需要以下参数:

  • board_id:要创建项的看板 ID。
  • item_name:新项的名称。
  • column_values:一个 JSON 字符串,包含所有列的值。这是最关键的部分,需要根据您的看板列类型和 ID 进行精确构造。

配置 API 访问 (config.php)

为了更好地管理 API 密钥和常用配置,我们首先创建一个 config.php 文件。

 1918282734, // 示例看板1 ID
    "boardName2" => 1987654321, // 示例看板2 ID
    "testBoard"  => 6376637288  // 您的测试看板 ID
);

// 如果您需要指定某个组(Group)ID,可以在这里定义
// "testGroup"  => 6376637288 
?>

重要提示:请务必将 [YOUR API KEY] 替换为您的实际 Monday.com API 密钥。为了安全起见,API 密钥不应直接硬编码在生产环境中,而应通过环境变量或其他安全方式管理。

立即学习PHP免费学习笔记(深入)”;

构建数据提交逻辑 (create_lead.php)

接下来,我们将创建主脚本,它将接收表单数据,构建 GraphQL 变异,并发送请求到 Monday.com API。

 'status_1', 'date4' -> 'date_column', 'text__1' -> 'text_column' 等。
    $vars = [
        'itemName'        => $companyName, // 新项的名称,通常是公司名或主要联系人
        'columnVals'      => json_encode([
            // 状态列:需要一个包含 'label' 的数组
            'status'        => [ 
                'label' => 'New Lead' // 例如:'New Lead', 'Contacted' 等
            ], 
            // 日期列:需要一个包含 'date' 的数组,格式为 YYYY-MM-DD
            'date4' => [ // 假设您的日期列 ID 是 'date4'
                'date' => $todaysDate
            ],
            // 文本列:直接传递字符串
            'text__1' => $firstName,    // 假设您的名字列 ID 是 'text__1'
            'text5__1' => $lastName,    // 假设您的姓氏列 ID 是 'text5__1'
            // 邮箱列:需要一个包含 'email' 和 'text' 的数组
            'email__1' => [ // 假设您的邮箱列 ID 是 'email__1'
                'email' => $contactEmail,
                'text' => $contactEmail // 邮箱列的显示文本
            ],
            // 电话列:需要一个包含 'phone' 和 'countryShortName' 的数组
            'phone__1' => [ // 假设您的电话列 ID 是 'phone__1'
                'phone' => $contactPhone,
                'countryShortName' => 'US' // 国家简称,例如 'US', 'CN'
            ],
            // 文本列
            'text7__1' => $projectState, // 假设您的项目状态列 ID 是 'text7__1'
            // 长文本列
            'long_text4__1' => $projectMessage // 假设您的长文本列 ID 是 'long_text4__1'
            // 'link_column' => ['url' => $contactWebSite, 'text' => $contactWebSite] // URL 列可能需要特殊处理,原问题中提到此项未成功。
        ])
    ];

    // 4. 发送 API 请求
    // 使用 file_get_contents 结合 stream_context_create 发送 POST 请求
    $data = @file_get_contents($apiUrl, false, stream_context_create([
        'http' => [
            'method' => 'POST',
            'header' => $headers, // 包含授权和内容类型
            'content' => json_encode([
                'query' => $query,
                'variables' => $vars
            ]),
            'ignore_errors' => true // 即使 HTTP 状态码表示错误也读取响应
        ]
    ]));

    // 5. 处理 API 响应
    $responseContent = json_decode($data, true);
    echo json_encode($responseContent, JSON_PRETTY_PRINT); // 以美观的格式输出响应
  } else {
    // 如果不是 POST 请求,可以显示一个简单的表单或错误信息
    echo "请通过 POST 请求提交数据。";
    // 示例 HTML 表单(用于测试)
    echo '
    








'; } ?>

发送 API 请求

在上述代码中,我们使用了 file_get_contents 函数结合 stream_context_create 来发送 HTTP POST 请求。这种方法对于简单的 API 调用是有效的。

Magician
Magician

Figma插件,AI生成图标、图片和UX文案

下载

stream_context_create 允许我们定义 HTTP 请求的各种选项,包括:

  • method:指定为 POST。
  • header:包含 Content-Type: application/json 和 Authorization: Bearer YOUR_TOKEN。
  • content:请求体,这里是 JSON 编码后的 GraphQL 查询和变量。

关于 cURL 的说明: 虽然原始问题提到了 cURL,但提供的解决方案使用了 file_get_contents。PHP 的 cURL 扩展是进行复杂 HTTP 请求的更强大和灵活的工具,特别是在需要处理文件上传、代理、SSL 证书验证等高级功能时。如果您需要使用 cURL,其基本结构如下:

 $query, 'variables' => $vars]));
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, $headers); // $headers 数组需要调整为 ['Content-Type: application/json', 'Authorization: Bearer ' . $token]

$data = curl_exec($ch);
$httpCode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
curl_close($ch);

// 继续处理 $data
?>

两种方法都能实现 API 请求,您可以根据个人偏好和项目需求选择。

处理 API 响应

Monday.com API 会返回一个 JSON 格式的响应。在我们的示例中,responseContent 将包含新创建项的 id 和 name。

{
    "data": {
        "create_item": {
            "id": "1234567890",
            "name": "测试公司"
        }
    },
    "account_id": 987654321
}

您可以根据 responseContent 中的 data 字段来判断操作是否成功,并获取新创建项的信息。

注意事项

  1. 列 ID 匹配是关键:Monday.com 看板中的每一列都有一个唯一的 ID。您必须在 columnVals 中使用正确的列 ID 来更新相应的值。这些 ID 通常可以在列设置中或通过 Monday.com API 浏览器查询获取。例如,text__1、email__1、phone__1 等都是示例 ID,您需要替换为实际的 ID。
  2. 数据类型与格式
    • 状态列 (Status):需要一个包含 label 键的数组,label 的值必须是 Monday.com 中实际存在的状态标签。
    • 日期列 (Date):需要一个包含 date 键的数组,日期格式必须是 YYYY-MM-DD。
    • 邮箱列 (Email):需要一个包含 email 和 text 键的数组。
    • 电话列 (Phone):需要一个包含 phone 和 countryShortName 键的数组。countryShortName 遵循 ISO 3166-1 alpha-2 标准,例如 'US'、'CN'。
    • URL 列 (Link):原始问题中提到 URL 列未能成功添加。Monday.com 的 URL 列通常需要一个包含 url 和 text 的对象。如果直接传递字符串无效,尝试使用 ['url' => 'https://example.com', 'text' => 'Example Website'] 这样的结构。如果仍然存在问题,建议查阅最新的 Monday.com API 文档或在 Monday.com 开发者社区寻求帮助。
  3. 错误处理:在生产环境中,您应该添加健壮的错误处理机制。例如,检查 file_get_contents 的返回值是否为 false,以及 API 响应中是否包含 errors 字段。
  4. API 密钥安全:切勿将 API 密钥暴露在客户端代码中,也不要将其直接提交到版本控制系统(如 Git)。始终将其存储在服务器端,并通过安全方式访问。
  5. GraphQL 查询优化:您可以根据需要调整 create_item 变异的返回字段,例如获取更多列的信息,而不仅仅是 id 和 name。

总结

通过本教程,您应该已经掌握了如何使用 PHP 和 Monday.com GraphQL API 自动化创建潜在客户或交易项的基本流程。这包括配置 API 密钥、构建 GraphQL 变异查询、正确映射不同类型的列数据以及发送和处理 API 请求。此集成能力为您的业务流程自动化提供了广阔的可能性,例如将网站表单提交、CRM 数据同步等直接集成到 Monday.com 中,从而提高效率并减少手动数据输入。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Python GraphQL API 开发实战
Python GraphQL API 开发实战

本专题系统讲解 Python 在 GraphQL API 开发中的实际应用,涵盖 GraphQL 基础概念、Schema 设计、Query 与 Mutation 实现、权限控制、分页与性能优化,以及与现有 REST 服务和数据库的整合方式。通过完整示例,帮助学习者掌握 使用 Python 构建高扩展性、前后端协作友好的 GraphQL 接口服务,适用于中大型应用与复杂数据查询场景。

14

2026.01.21

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

419

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

535

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

311

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

77

2025.09.10

数据类型有哪几种
数据类型有哪几种

数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

309

2023.10.31

php数据类型
php数据类型

本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

222

2025.10.31

curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

440

2023.06.14

clawdbot ai使用教程 保姆级clawdbot部署安装手册
clawdbot ai使用教程 保姆级clawdbot部署安装手册

Clawdbot是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

19

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 10.1万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号