php-mcp-server

he426100/php-mcp-server

3.4

If you are the rightful owner of php-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.

PHP MCP Server is a framework for implementing Model Control Protocol servers using PHP, allowing elegant service definitions through annotations.

Tools
3
Resources
0
Prompts
0

PHP MCP Server

这是一个基于 PHP 实现的 MCP (Model Control Protocol) 服务器框架,支持通过注解优雅地定义 MCP 服务。

项目概述

本项目提供了一个完整的 MCP 服务器实现,特色功能:

  • 基于注解的 MCP 服务定义
  • 支持 Tool、Prompt、Resource 三种处理器
  • 支持 Stdio、Sse 两种传输方式
  • 支持 SwowSwoole 两种环境
  • 完整的日志系统
  • Docker 支持

系统要求

  • PHP >= 8.1
  • Composer
  • Swow 扩展 > 1.5 或 Swoole > 5.1
  • Docker (可选)

快速开始

安装

# 1. 克隆项目
git clone https://github.com/he426100/php-mcp-server
cd php-mcp-server

# 2. 安装依赖
composer install

# 3. 可选,安装 Swow 扩展(如果没有)
./vendor/bin/swow-builder --install

关于 Swow 扩展的详细安装说明,请参考 Swow 官方文档

运行示例服务器

php bin/console mcp:test-server
通用命令参数
ParameterDescriptionDefault ValueOptions
--transportTransport typestdiostdio, sse
--portPort to listen on for SSE8000

注解使用指南

本框架提供三种核心注解用于定义 MCP 服务:

1. Tool 注解

用于定义工具类处理器:

use Mcp\Annotation\Tool;

class MyService {
    #[Tool(
        name: 'calculate-sum',
        description: '计算两个数的和',
        parameters: [
            'num1' => [
                'type' => 'number',
                'description' => '第一个数字',
                'required' => true
            ],
            'num2' => [
                'type' => 'number',
                'description' => '第二个数字',
                'required' => true
            ]
        ]
    )]
    public function sum(int $num1, int $num2): int 
    {
        return $num1 + $num2;
    }
}

2. Prompt 注解

用于定义提示模板处理器:

use Mcp\Annotation\Prompt;

class MyService {
    #[Prompt(
        name: 'greeting',
        description: '生成问候语',
        arguments: [
            'name' => [
                'description' => '要问候的人名',
                'required' => true
            ]
        ]
    )]
    public function greeting(string $name): string 
    {
        return "Hello, {$name}!";
    }
}

3. Resource 注解

用于定义资源处理器:

use Mcp\Annotation\Resource;

class MyService {
    #[Resource(
        uri: 'example://greeting',
        name: 'Greeting Text',
        description: '问候语资源',
        mimeType: 'text/plain'
    )]
    public function getGreeting(): string 
    {
        return "Hello from MCP server!";
    }
}

创建自定义服务

  1. 创建服务类:
namespace Your\Namespace;

use Mcp\Annotation\Tool;
use Mcp\Annotation\Prompt;
use Mcp\Annotation\Resource;

class CustomService 
{
    #[Tool(name: 'custom-tool', description: '自定义工具')]
    public function customTool(): string 
    {
        return "Custom tool result";
    }
}
  1. 创建命令类:
namespace Your\Namespace\Command;

use He426100\McpServer\Command\AbstractMcpServerCommand;
use Your\Namespace\CustomService;

class CustomServerCommand extends AbstractMcpServerCommand 
{
    protected string $serverName = 'custom-server';
    protected string $serviceClass = CustomService::class;

    protected function configure(): void 
    {
        parent::configure();
        $this->setName('custom:server')
            ->setDescription('运行自定义 MCP 服务器');
    }
}

注解参数说明

Tool 注解参数

参数类型说明必填
namestring工具名称
descriptionstring工具描述
parametersarray参数定义

Prompt 注解参数

参数类型说明必填
namestring提示模板名称
descriptionstring提示模板描述
argumentsarray参数定义

Resource 注解参数

参数类型说明必填
uristring资源URI
namestring资源名称
descriptionstring资源描述
mimeTypestringMIME类型

注解函数返回类型说明

Tool 注解函数支持的返回类型

返回类型说明转换结果
TextContent/ImageContent/EmbeddedResource直接返回内容对象原样保留
TextContent/ImageContent/EmbeddedResource 数组内容对象数组原样保留
ResourceContents资源内容对象转换为 EmbeddedResource
字符串或标量类型如 string、int、float、bool转换为 TextContent
null空值转换为空字符串的 TextContent
数组或对象复杂数据结构转换为 JSON 格式的 TextContent

Prompt 注解函数支持的返回类型

返回类型说明转换结果
PromptMessage消息对象原样保留
PromptMessage 数组消息对象数组原样保留
Content 对象TextContent/ImageContent 等转换为用户角色的 PromptMessage
字符串或标量类型如 string、int、float、bool转换为带 TextContent 的用户消息
null空值转换为空内容的用户消息
数组或对象复杂数据结构转换为 JSON 格式的用户消息

Resource 注解函数支持的返回类型

返回类型说明转换结果
TextResourceContents/BlobResourceContents资源内容对象原样保留
ResourceContents 数组资源内容对象数组原样保留
字符串或可转字符串对象文本内容根据 MIME 类型转换为对应资源内容
null空值转换为空的 TextResourceContents
数组或对象复杂数据结构转换为 JSON 格式的资源内容

注意事项:

  • 对于超过 2MB 的大文件内容会自动截断
  • 文本类型 (text/*) 的 MIME 类型会使用 TextResourceContents
  • 其他 MIME 类型会使用 BlobResourceContents

日志配置

服务器日志默认保存在 runtime/server_log.txt,可通过继承 AbstractMcpServerCommand 修改:

protected string $logFilePath = '/custom/path/to/log.txt';

Docker 支持

构建并运行容器:

docker build -t php-mcp-server .
docker run --name=php-mcp-server -p 8000:8000 -itd php-mcp-server mcp:test-server --transport sse

sse地址:http://127.0.0.1:8000/sse

通过 CPX 使用

您可以通过 CPX (Composer Package Executor) 直接运行本项目,无需事先安装:

前提条件

  1. 全局安装 CPX:
composer global require cpx/cpx
  1. 确保 Composer 的全局 bin 目录在您的 PATH 中

使用方式

# 运行测试服务器
cpx he426100/php-mcp-server mcp:test-server

# 使用 SSE 传输模式
cpx he426100/php-mcp-server mcp:test-server --transport=sse

# 查看可用命令
cpx he426100/php-mcp-server list

许可证

贡献

欢迎提交 Issue 和 Pull Request。

作者

he426100
logiscape