2025-06-06 00:30:47 +08:00

2.8 KiB
Raw Blame History

MCP Server的OAuth鉴权实现

在使用 SSEStreamable HTTP 进行连接时为增强安全性可为接口设计鉴权机制MCP 官方推荐采用 OAuth 协议。下面以获取 GitHub 用户信息为例,演示如何通过 openmcp-client 完成带 OAuth 认证的接口调试。

部署服务器

1. 获取Github OAuth认证ID和secret

由于我们使用了Github用户信息相关API需要先获取Github OAuth应用的Client ID和Client secret。

先进入Github Developers,点击New OAuth App新建一个OAuth APP应用名称随便填Homepage URL填写http://localhost:8000,Authorization callback URL填写http://localhost:8000/github/callback。然后点击Register application按钮,即可成功注册一个应用。

注册成功后,请记录Client ID,然后点击Generate a new client secret生成一个secret注意secret仅在生成的时候可见。

2. 设置环境变量

在获取Client IDsecret之后,需要将其设置为环境变量:

在bash里

export MCP_GITHUB_GITHUB_CLIENT_ID={{Client ID}}
export MCP_GITHUB_GITHUB_CLIENT_SECRET={{secret}}

在windows cmd里

set MCP_GITHUB_GITHUB_CLIENT_ID={{Client ID}}
set MCP_GITHUB_GITHUB_CLIENT_SECRET={{secret}}

注意cmd里面设置环境变量请不要加引号。

3. 克隆源码

首先我们需要部署MCP服务器。可以参照官方python例子进行。

需要先克隆官方python-sdk源码

git clone https://github.com/modelcontextprotocol/python-sdk/ # 克隆源码
cd examples/servers/simple-auth # 进入对应的目录

4. 启动MCP Server

先根据需要创建虚拟环境安装依赖,然后直接运行python main.py即可,注意需要先设置环境变量,不然启动会报错2 validation errors for ServerSettings

5. 启动openmcp-client

接下来你就可以使用openmcp-client连接刚刚启动的server了不管是使用网页端还是VSCode均可。

点击加号添加连接根据server代码中的--transport参数决定是SSE还是Streamable HTTP。如果是SSE则URL填写http://localhost:8000/sse如果是Streamable HTTP则URL填写http://localhost:8000/mcp。认证签名无需填写。

接下来连接到当前server此时会自动打开一个网页进行认证首次打开需要点击认证认证成功后该网页会自动关闭。

认证成功后,进入工具页面,应该能看到一个get_user_profile工具点击使用就可以获取到你的Github个人信息了。