精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

MCP Server怎么做權限控制?5分鐘教會你快速給MCP 服務成功添加授權 原創

發布于 2025-6-5 06:15
瀏覽
0收藏

2024 年,Anthropic[1] 發布 Claude 3[2] 系列的同時推出了 MCP[3](Model Context Protocol),定位更底層:不是“調函數”,而是“定義模型理解系統的結構協議”。

在企業級應用場景下,對于一些私有環境,MCP服務器可能不需要嚴格的身份認證。但如果在企業級別進行部署,對這些接口的安全性和權限管理就顯得至關重要。MCP服務器可以通過兩種方式運行:

  1. stdio
  2. http + sse

這兩種運行方式的權限控制策略各不相同。在深入討論MCP服務器的權限控制之前,我們先簡單回顧一下MCP的基本原理。

MCP組成和執行流程

MCP 架構分為以下 3 部分:

  • 客戶端:大模型應用(如 DeepSeek、ChatGPT)發起 MCP 協議請求。
  • 服務器端:服務器端響應客戶端的請求,并查詢自己的業務實現請求處理和結果返回。

運行流程

  1. 用戶提問 LLM。
  2. LLM 查詢 MCP 服務列表。
  3. 找到需要調用 MCP 服務,調用 MCP 服務器端。
  4. MCP 服務器接收到指令。
  5. 調用對應工具(如數據庫)執行。
  6. 返回結果給 LLM。

stdio模式

在 stdio 這種模式下,mcp server是作為mcp client 的一個子進程運行的。在這種模式下,可以在mcp client 中配置環境變量,mcp server讀取環境變量。

環境變量是操作系統為每個進程維護的一組鍵值對(如??PATH???、??PYTHONPATH??等),存儲在進程的內存空間中。子進程啟動時,會繼承其父進程的環境變量(如 Shell 啟動的程序會繼承 Shell 的環境變量)。

下面是cursor中mcp的配置:

{
    "mcpServers": [
      {
        "name": "my-mcp-server",
        "command": "/home/cy/Downloads/anaconda3/envs/deep-searcher/bin/python3",
        "args": ["/home/cy/Desktop/git/deep-searcher/mcp_server.py"],
        "env": {"token": "value"}
      }
    ]
}

在生產中,我們一般會把mcp server單獨部署成一個服務,所以對這個服務的權限驗證才是重點。

HTTP + SSE

2025 年 3 月發布的最新 MCP 規范引入了安全基礎,借助了廣泛使用的 OAuth2 框架[4]

MCP Server怎么做權限控制?5分鐘教會你快速給MCP 服務成功添加授權-AI.x社區

  • 作為資源托管中心,MCP的職責在于審查所有請求中的Authorization頭部信息。這個頭部信息必須攜帶一個OAuth2 access_token(代表客戶端權限的令牌)。通常情況下,這個令牌是一個JWT(JSON Web Token),或者只是一串無法解讀的隨機字符。如果令牌丟失或無效(例如無法解析、已經過期、不屬于該服務器等),請求將會被駁回。
  • 同時,作為授權中心,MCP還需要具備為客戶端安全簽發access_token的能力。在簽發令牌之前,服務器會驗證客戶端的證明,有時還需要確認訪問用戶的身份。授權中心會確定令牌的有效時間、權限范圍、目標聽眾等屬性。

在我們的內部應用體系中,token 的簽發并非由我們的 MCP 服務器完成,而是由其他服務提供。因此,MCP服務器并不完全實現了OAuth2服務器的所有功能,它主要承擔著授權校驗的職責。為了實現這一目標,我們使用了一個專門處理token相關操作的 JWT類。

# pip install python-jose[cryptography]
from jose import jwt, JWTError
class JWTManager:
    def __init__(
            self,
            secret_key: str,
            algorithm: str = "HS256",
            access_token_expire_minutes: int = 30,
            refresh_token_expire_days: int = 30
    ):
        """
        初始化JWT管理器

        Args:
            secret_key: 用于簽名JWT的密鑰
            algorithm: 加密算法,默認HS256
            access_token_expire_minutes: 訪問令牌過期時間(分鐘)
            refresh_token_expire_days: 刷新令牌過期時間(天)
        """
        self.secret_key = secret_key
        self.algorithm = algorithm
        self.access_token_expire_minutes = access_token_expire_minutes
        self.refresh_token_expire_days = refresh_token_expire_days

    def create_access_token(
            self,
            data: Dict[str, Any],
            expires_delta: Optional[timedelta] = None
    ) -> str:
        """
        創建訪問令牌

        Args:
            data: 要編碼到令牌中的數據
            expires_delta: 可選的過期時間增量

        Returns:
            str: 編碼后的JWT令牌
        """
        to_encode = data.copy()
        if expires_delta:
            expire = datetime.utcnow() + expires_delta
        else:
            expire = datetime.utcnow() + timedelta(minutes=self.access_token_expire_minutes)

        to_encode.update({"exp": expire})
        encoded_jwt = jwt.encode(to_encode, self.secret_key, algorithm=self.algorithm)
        return encoded_jwt

    def create_refresh_token(
            self,
            data: Dict[str, Any],
            expires_delta: Optional[timedelta] = None
    ) -> str:
        """
        創建刷新令牌

        Args:
            data: 要編碼到令牌中的數據
            expires_delta: 可選的過期時間增量

        Returns:
            str: 編碼后的JWT令牌
        """
        to_encode = data.copy()
        if expires_delta:
            expire = datetime.utcnow() + expires_delta
        else:
            expire = datetime.utcnow() + timedelta(days=self.refresh_token_expire_days)

        to_encode.update({"exp": expire})
        encoded_jwt = jwt.encode(to_encode, self.secret_key, algorithm=self.algorithm)
        return encoded_jwt

    def verify_token(self, token: str) -> Dict[str, Any]:
        """
        驗證并解碼JWT令牌

        Args:
            token: 要驗證的JWT令牌

        Returns:
            Dict[str, Any]: 解碼后的令牌數據

        Raises:
            HTTPException: 當令牌無效或過期時
        """
        try:
            payload = jwt.decode(token, self.secret_key, algorithms=[self.algorithm])
            return payload
        except JWTError:
            raise HTTPException(
                status_code=status.HTTP_401_UNAUTHORIZED,
                detail="Could not validate credentials",
                headers={"WWW-Authenticate": "Bearer"},
            )

    def is_token_expired(self, token: str) -> bool:
        """
        檢查令牌是否過期

        Args:
            token: 要檢查的JWT令牌

        Returns:
            bool: 如果令牌過期返回True,否則返回False
        """
        try:
            payload = self.verify_token(token)
            exp = payload.get("exp")
            if exp isNone:
                returnTrue
            return datetime.utcnow() > datetime.fromtimestamp(exp)
        except HTTPException:
            returnTrue

在這個環境下,我們采用了中間件的方法。通過深入研究mcp這個package的源代碼,我們了解到其底層實際上還是利用starlette創建的app來提供服務。因此,我們需要對這個app添加自定義的中間件。

class JwtMiddleware(BaseHTTPMiddleware):
    def __init__(self, app: ASGIApp, dispatch: DispatchFunction | None = None) -> None:
        super().__init__(app, dispatch)
        self.jwt_manager = JWTManager(
            secret_key="your-secret-key",
            access_token_expire_minutes=30,
            refresh_token_expire_days=30
        )

    def verify_token(self, token):
        try:
            payload = self.jwt_manager.verify_token(token)
            return payload
        except Exception:
            raise



    asyncdef dispatch(self, request: Request, call_next: RequestResponseEndpoint) -> Response:
        token = request.headers.get("Authorization")

        ifnot token:
            return JSONResponse({"error": "unauthorized"}, status_code=401)
        token = token.lstrip("Bearer").strip()
        try:
            payload = self.verify_token(token)
            logging.info(payload)
        except Exception as e:
            logging.error(e)
            return JSONResponse({"error": "unauthorized"}, status_code=401)
        else:
            response = await call_next(request)
            return response

然而,在MCP這個包的源代碼中,并沒有提供直接添加中間件的入口。因此,我們需要自行進行擴展。為了實現這一目標,我們決定繼承原有的FastMCP類來完成這個擴展。

class CustomFastMCP(FastMCP):
    def __init__(
            self, name: str | None = None, instructions: str | None = None, **settings: Any
    ):
        super().__init__(name, instructions, **settings)
        self.app = self.sse_app()

# 添加的方法
    def add_middleware(
        self,
        middleware_class
    ) -> None:
        self.app.add_middleware(middleware_class)

    asyncdef run_sse_async(self) -> None:
        """Run the server using SSE transport."""
        starlette_app = self.app

        config = uvicorn.Config(
            starlette_app,
            host=self.settings.host,
            port=self.settings.port,
            log_level=self.settings.log_level.lower(),
        )
        server = uvicorn.Server(config)
        await server.serve()

在此新類中,我們對run_sse_async和init方法進行了重寫,并添加了一個新的函數add_middleware來支持中間件的添加。現在,我們可以通過使用這個自定義的CustomFastMCP類來運行MCP server。如果請求頭中未帶有Authorization或其值錯誤,系統會返回一個錯誤信息:

{"error":"unauthorized"}

一旦正確地攜帶了Authorization,請求將正常處理。

curl -X GET "http://127.0.0.1:8000/sse" \
>      -H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoxLCJleHAiOjE3NDg5NDExMzd9.GadUzsaiJYK215KIzl1c3ACQYiwQAmWaheb2o4ZI8d8"
event: endpoint
data: /messages/?session_id=eb18beb2ff4e4e70a61066d74f59a064

: ping - 2025-06-03 08:29:47.996746+00:00

: ping - 2025-06-03 08:30:02.997993+00:00

: ping - 2025-06-03 08:30:17.998910+00:00

總結

至此,我們已成功地為MCP服務加入了認證機制。現在,只有經過授權的用戶才能獲取我們MCP服務的接入權,進一步確保了我們服務的安全性和管理效率。盡管存在多種實現MCP服務權限認證的方法,但值得注意的是,當前MCP在這個領域的研究還處于草案階段,我們會繼續關注并優化這一塊的工作。

參考資料

[1] Anthropic: ??https://zhida.zhihu.com/search?content_id=256440304&content_type=Article&match_order=1&q=Anthropic&zhida_source=entity??

[2] Claude 3: ??https://zhida.zhihu.com/search?content_id=256440304&content_type=Article&match_order=1&q=Claude+3&zhida_source=entity??

[3] MCP: ??https://zhida.zhihu.com/search?content_id=256440304&content_type=Article&match_order=1&q=MCP&zhida_source=entity??

[4] OAuth2 框架: ???https://modelcontextprotocol.info/specification/draft/basic/authorization/??


本文轉載自??AI 博物院?? 作者:longyunfeigu


?著作權歸作者所有,如需轉載,請注明出處,否則將追究法律責任
已于2025-6-5 06:15:34修改
收藏
回復
舉報
回復
相關推薦
国产一级二级视频| 成人网站免费观看入口| 国产男男gay体育生白袜| 欧美日韩综合| 日韩精品免费观看| 手机av在线免费| 538视频在线| 国产精品久久久久一区| 国产91精品入口17c| 伊人中文字幕在线观看 | 国产偷拍一区二区| 国产真实久久| 一本一本久久a久久精品牛牛影视 一本色道久久综合亚洲精品小说 一本色道久久综合狠狠躁篇怎么玩 | 欧美体内she精高潮| 欧美xxxx视频| 中文字幕不卡在线| 黄色国产精品一区二区三区| 伊人免费在线观看| 国产精品免费看| 亚洲摸下面视频| 天堂中文av在线| 澳门成人av网| 亚洲第一综合色| 一区国产精品| 免费动漫网站在线观看| 国产99一区视频免费| 国产精品久久久久久久久借妻| 欧美激情aaa| 91精品导航| 欧美精品久久99| 成人免费xxxxx在线视频| av影视在线看| 亚洲美女一区二区三区| 亚洲va久久久噜噜噜久久狠狠| 精品成人av一区二区在线播放| 成人爽a毛片| 欧美影片第一页| 青青青青草视频| 伊人福利在线| 亚洲美女淫视频| 永久久久久久| 日韩伦理在线观看| 中文字幕不卡的av| 日本日本精品二区免费| 久久手机免费观看| 国产亚洲精品中文字幕| 久久久久久久久久久久久久久久av | 蜜桃精品噜噜噜成人av| 亚洲国产精品专区久久| 少妇伦子伦精品无吗| 欧美成人精品午夜一区二区| 欧美人伦禁忌dvd放荡欲情| 午夜在线观看av| 日本欧美韩国| 欧美视频日韩视频| 狠狠躁狠狠躁视频专区| 欧美精品高清| 在线观看区一区二| av在线无限看| 国产三级一区| 欧美日本高清视频在线观看| 在线免费看v片| 视频一区国产| 亚洲国产精品999| 精品人妻一区二区三区日产| 美女扒开腿让男人桶爽久久动漫| 色系网站成人免费| 老司机午夜av| 国产亚洲欧美日韩精品一区二区三区| 亚洲一区二区三区影院| 久久人人爽人人爽人人av| 免费看电影在线| 激情懂色av一区av二区av| 欧美日韩在线视频一区二区三区| 日韩理伦片在线| 又紧又大又爽精品一区二区| 久艹在线免费观看| 中文字幕在线视频网站| 在线观看av一区| 日韩av加勒比| 精品精品精品| 最近日韩中文字幕中文| 中文字幕在线观看成人| 亚洲人妖在线| 国产精品视频成人| 成人午夜免费在线观看| 91在线精品秘密一区二区| 日本不卡高清视频一区| 超碰在线caoporen| 天天av天天翘天天综合网| 一级黄色香蕉视频| 91久久精品无嫩草影院| 亚洲人成电影在线播放| 男人在线观看视频| 国产日韩亚洲| 91丨九色丨国产在线| 五月婷婷久久久| 国产女同互慰高潮91漫画| 中国一级大黄大黄大色毛片| 里番在线播放| 欧美精三区欧美精三区| xxxx黄色片| 日韩超碰人人爽人人做人人添| 男人的天堂亚洲| 国产精品狼人色视频一区| 国产强伦人妻毛片| 91免费国产在线| 日本黄色播放器| 一区二区电影免费观看| 欧美一区二区三区不卡| 中文字幕丰满乱子伦无码专区| 99re6热只有精品免费观看| 亚洲欧美在线一区二区| 久久久久亚洲AV成人| 日韩av在线发布| 国产一区二区三区奇米久涩 | 性xxxxfjsxxxxx欧美| 欧美性少妇18aaaa视频| 亚洲三级在线视频| 国产欧美日韩影院| 97人人做人人爱| 国产福利视频导航| 中文字幕在线视频一区| 黄色成人免费看| 亲子伦视频一区二区三区| 欧美超级免费视 在线| 在线永久看片免费的视频| 成人一级视频在线观看| mm131午夜| 91精品网站在线观看| 亚洲最新在线视频| 黄瓜视频在线免费观看| hitomi一区二区三区精品| 日韩精品免费一区| av在线精品| 日韩一中文字幕| 中文字幕二区三区| 国产欧美日韩综合| 妓院一钑片免看黄大片| 丝袜久久网站| 青草热久免费精品视频| 手机在线观看免费av| 亚洲一二三区不卡| 中文字幕第九页| 狠狠噜噜久久| 国产精品成人一区二区三区| 伊人春色在线观看| 日韩美女视频一区二区在线观看| 欧美 日本 国产| 亚洲国产一区二区三区高清| 鬼打鬼之黄金道士1992林正英| 午夜视频www| 亚洲成人av一区二区三区| 亚洲911精品成人18网站| 最新国产精品| 国产精品综合久久久久久| 97人澡人人添人人爽欧美| 欧美精品一区二区久久婷婷| 国产第一页在线播放| 成人免费毛片app| 动漫av网站免费观看| 亚洲精品aaaaa| 国产精品精品视频| 高潮毛片在线观看| 欧美va亚洲va在线观看蝴蝶网| www.狠狠爱| 美女任你摸久久| 国产a级片免费看| 午夜久久av| 亚州欧美日韩中文视频| 噜噜噜噜噜在线视频| 色婷婷av一区二区三区大白胸| 18禁一区二区三区| 狠久久av成人天堂| 欧美日韩精品免费在线观看视频| 女同视频在线观看| 日韩国产激情在线| 免费又黄又爽又猛大片午夜| 国产精品久久99| 亚洲精品一二三四| 国产精品日韩久久久| 亚洲国产激情一区二区三区| 国产一区二区三区| 777午夜精品福利在线观看| 国产日产精品久久久久久婷婷| 一个色在线综合| 欧美在线一级片| 麻豆国产欧美日韩综合精品二区| 美媛馆国产精品一区二区| 91九色综合| 九色精品美女在线| 国际av在线| 欧美不卡一二三| 国产又粗又猛又黄视频| 亚洲美女视频在线观看| 30一40一50老女人毛片| 久草精品在线观看| 亚洲自偷自拍熟女另类| 希岛爱理av一区二区三区| 久久66热这里只有精品| 欧美激情啪啪| 欧美性受xxxx黑人猛交| yellow91字幕网在线| 日韩久久免费电影| 国产成人免费看一级大黄| 日韩人体视频一二区| 特级片在线观看| 欧美国产禁国产网站cc| 久久久久国产精品区片区无码| 99在线精品免费视频九九视| 亚洲国产欧美日韩| 女同另类激情重口| yy111111少妇影院日韩夜片| 大胆人体一区二区| 久久久久女教师免费一区| 无遮挡动作视频在线观看免费入口| 欧美视频一区二区| 国内免费精品视频| 亚洲最新视频在线观看| 久久精品日韩无码| 国产亚洲一区二区三区在线观看| 国产一级不卡毛片| 国产视频一区三区| 野外做受又硬又粗又大视频√| 动漫av一区| 91在线视频导航| 成人午夜毛片| 国产精品黄色av| 欧美人与性动交xxⅹxx| 国模吧一区二区三区| 污视频网站在线免费| 久久精品欧美视频| 日本中文字幕在线2020| 最近2019好看的中文字幕免费| 国产精品无码专区av免费播放| 一区二区三区日韩| 色在线观看视频| 18涩涩午夜精品.www| 美国黑人一级大黄| 亚洲国产经典视频| 摸摸摸bbb毛毛毛片| 91亚洲精品一区二区乱码| japanese在线观看| 成人精品国产一区二区4080| 中文字幕人妻熟女在线| 国产宾馆实践打屁股91| 黑森林av导航| 粉嫩欧美一区二区三区高清影视| 北条麻妃在线观看| 久久久精品午夜少妇| 北条麻妃在线视频| 日韩av不卡一区二区| 我看黄色一级片| 精品一区二区综合| 国产人妻精品久久久久野外| 国产成人综合视频| 性色av蜜臀av浪潮av老女人 | 亚洲欧美另类图片小说| 日韩视频在线观看一区二区三区| 亚洲三级观看| 乱妇乱女熟妇熟女网站| 亚洲黄色影片| 欧美精品第三页| 日本亚洲免费观看| 岛国毛片在线播放| 国产盗摄视频一区二区三区| 色欲欲www成人网站| 成人午夜又粗又硬又大| 国产人妻人伦精品1国产丝袜| 韩国精品一区二区| 成人在线观看一区二区| 99久久国产综合精品女不卡| 国产一级黄色录像| 国产香蕉久久精品综合网| 一本色道久久88| 一区二区在线免费| 波多野结衣视频网站| 欧美中文字幕一区二区三区亚洲| 久久久久久免费观看| 精品成人av一区| 中文在线字幕av| 日韩精品中文字幕一区二区三区 | 在线免费看视频| 亚洲伦在线观看| 日本三级一区二区| 欧美日韩免费一区二区三区视频| 日本在线播放视频| 精品视频在线免费观看| 国产成人精品一区二区无码呦| 欧美日韩国产综合草草| 亚洲爱情岛论坛永久| 亚洲区在线播放| 欧美xxxx少妇| 国产欧美日韩视频| 奇米影视777在线欧美电影观看| 高清视频一区| 欧美色图国产精品| 国产乱子伦精品无码专区| 视频一区视频二区在线观看| 超级砰砰砰97免费观看最新一期 | 女同性恋一区二区三区| 日本一区二区动态图| 国产精品成人久久| 欧美精品粉嫩高潮一区二区| 亚洲 欧美 激情 另类| 日韩中文字幕国产| 三妻四妾完整版在线观看电视剧 | 少妇一级淫片免费放中国| 欧美精选一区二区| 黄色国产在线| 97色在线播放视频| 一区中文字幕| 国产奶头好大揉着好爽视频| 日日夜夜精品视频天天综合网| 热久久精品免费视频| 成人精品免费视频| 欧美精品色哟哟| 91精品国产美女浴室洗澡无遮挡| 91亚洲欧美激情| 国产一区二区黑人欧美xxxx| gratisvideos另类灌满| 91久久久久久| 久久精品国产大片免费观看| 色综合av综合无码综合网站| 国产精品自产自拍| 中文字幕乱码av| 欧美丝袜自拍制服另类| 国产在线观看网站| 欧美在线视频网| 欧美调教网站| 99精品人妻少妇一区二区| 成人看片黄a免费看在线| 激情五月婷婷在线| 91精品欧美一区二区三区综合在| 男人的天堂a在线| 欧美国产日韩免费| 欧美经典影片视频网站| 亚洲免费av网| 国产一区二区三区免费播放| 好吊视频在线观看| 色噜噜偷拍精品综合在线| 日韩福利一区二区| 欧洲成人免费aa| 国产一区二区三区网| 精品久久久久久中文字幕2017| 国产精品一区2区| 黄色一级大片在线免费观看| 国产综合成人久久大片91| 亚洲精品91在线| 欧美体内she精视频| 在线观看黄色av| 国产专区精品视频| 婷婷综合视频| 性一交一黄一片| 午夜伦欧美伦电影理论片| 天堂成人在线| 日本精品视频在线观看| 国产探花在线精品| 亚洲免费av一区| 依依成人综合视频| 日韩在线观看视频网站| 欧美一级淫片videoshd| 色棕色天天综合网| 欧美三级午夜理伦三级富婆| 中文字幕亚洲欧美在线不卡| 99国产精品99| 国内精品久久久久久| 免费看成人哺乳视频网站| 亚洲综合日韩欧美| 亚洲精品一二三| 香蕉视频成人在线| 国产成人精品视频在线观看| 91欧美在线| 日韩女优在线视频| 一本大道综合伊人精品热热| 毛片在线播放a| 国产精品永久入口久久久| 老司机免费视频久久| 无码人妻精品中文字幕| 精品国产伦一区二区三区观看体验| 欧洲日本在线| 国产精品免费一区二区三区在线观看| 欧美成人精品一区二区三区在线看| 青青草精品视频在线| 国产欧美精品国产国产专区 | 成人日批视频| 国语精品免费视频| 麻豆精品在线视频| 日韩高清免费av| 中文字幕在线精品| 风间由美性色一区二区三区四区| 欧美 另类 交| 久久综合999| 国产影视一区二区| 91精品国产91久久久久福利| 午夜精品毛片| 精品国产av无码| 欧美v日韩v国产v| 欧美aaa级| 东京热加勒比无码少妇|