Loading...
    • Guida per sviluppatori
    • Riferimento API
    • MCP
    • Risorse
    • Note sulla versione
    Search...
    ⌘K
    Primi passi
    Introduzione a ClaudeAvvio rapido
    Modelli e prezzi
    Panoramica dei modelliScelta di un modelloNovità in Claude 4.6Guida alla migrazioneDeprecazioni dei modelliPrezzi
    Crea con Claude
    Panoramica delle funzioniUtilizzo dell'API MessagesGestione dei motivi di arrestoBest practice per i prompt
    Capacità del modello
    Extended thinkingAdaptive thinkingEffortFast mode (anteprima di ricerca)Output strutturatiCitazioniStreaming dei messaggiElaborazione batchSupporto PDFRisultati di ricercaSupporto multilingueEmbeddingsVision
    Strumenti
    PanoramicaCome implementare l'uso degli strumentiStrumento di ricerca webStrumento di recupero webStrumento di esecuzione del codiceStrumento di memoriaStrumento BashStrumento Computer useStrumento editor di testo
    Infrastruttura degli strumenti
    Ricerca strumentiChiamata programmatica degli strumentiStreaming granulare degli strumenti
    Gestione del contesto
    Finestre di contestoCompattazioneModifica del contestoPrompt cachingConteggio dei token
    File e risorse
    API Files
    Agent Skills
    PanoramicaAvvio rapidoBest practiceSkills per l'aziendaUtilizzo di Skills con l'API
    Agent SDK
    PanoramicaAvvio rapidoTypeScript SDKTypeScript V2 (anteprima)Python SDKGuida alla migrazione
    MCP nell'API
    Connettore MCPServer MCP remoti
    Claude su piattaforme di terze parti
    Amazon BedrockMicrosoft FoundryVertex AI
    Prompt engineering
    PanoramicaGeneratore di promptUsa modelli di promptMiglioratore di promptSii chiaro e direttoUsa esempi (multishot prompting)Lascia che Claude pensi (CoT)Usa tag XMLDai a Claude un ruolo (prompt di sistema)Concatena prompt complessiSuggerimenti per il contesto lungoSuggerimenti per extended thinking
    Test e valutazione
    Definisci criteri di successoSviluppa casi di testUtilizzo dello strumento di valutazioneRiduzione della latenza
    Rafforza i guardrail
    Riduci le allucinazioniAumenta la coerenza dell'outputMitiga i jailbreakStreaming dei rifiutiRiduci la perdita di promptMantieni Claude nel personaggio
    Amministrazione e monitoraggio
    Panoramica dell'API AdminResidenza dei datiWorkspaceAPI di utilizzo e costiAPI Claude Code AnalyticsZero Data Retention
    Console
    Log in
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...

    Solutions

    • AI agents
    • Code modernization
    • Coding
    • Customer support
    • Education
    • Financial services
    • Government
    • Life sciences

    Partners

    • Amazon Bedrock
    • Google Cloud's Vertex AI

    Learn

    • Blog
    • Catalog
    • Courses
    • Use cases
    • Connectors
    • Customer stories
    • Engineering at Anthropic
    • Events
    • Powered by Claude
    • Service partners
    • Startups program

    Company

    • Anthropic
    • Careers
    • Economic Futures
    • Research
    • News
    • Responsible Scaling Policy
    • Security and compliance
    • Transparency

    Learn

    • Blog
    • Catalog
    • Courses
    • Use cases
    • Connectors
    • Customer stories
    • Engineering at Anthropic
    • Events
    • Powered by Claude
    • Service partners
    • Startups program

    Help and security

    • Availability
    • Status
    • Support
    • Discord

    Terms and policies

    • Privacy policy
    • Responsible disclosure policy
    • Terms of service: Commercial
    • Terms of service: Consumer
    • Usage policy
    MCP nell'API

    Connettore MCP

    Connetti a server MCP remoti direttamente dall'API Messages senza un client MCP separato

    La funzionalità del connettore Model Context Protocol (MCP) di Claude ti consente di connetterti a server MCP remoti direttamente dall'API Messages senza un client MCP separato.

    Versione corrente: Questa funzionalità richiede l'intestazione beta: "anthropic-beta": "mcp-client-2025-11-20"

    La versione precedente (mcp-client-2025-04-04) è deprecata. Vedi la documentazione della versione deprecata di seguito.

    This feature is in beta and is not covered by Zero Data Retention (ZDR) arrangements. Beta features are excluded from ZDR.

    Caratteristiche principali

    • Integrazione API diretta: Connettiti a server MCP senza implementare un client MCP
    • Supporto per le chiamate di strumenti: Accedi agli strumenti MCP tramite l'API Messages
    • Configurazione flessibile degli strumenti: Abilita tutti gli strumenti, crea una lista di strumenti specifici o nega gli strumenti indesiderati
    • Configurazione per singolo strumento: Configura singoli strumenti con impostazioni personalizzate
    • Autenticazione OAuth: Supporto per token Bearer OAuth per server autenticati
    • Server multipli: Connettiti a più server MCP in una singola richiesta

    Limitazioni

    • Della serie di funzionalità della specifica MCP, attualmente sono supportate solo le chiamate di strumenti.
    • Il server deve essere esposto pubblicamente tramite HTTP (supporta sia i trasporti HTTP Streamable che SSE). I server STDIO locali non possono essere connessi direttamente.
    • Il connettore MCP non è attualmente supportato su Amazon Bedrock e Google Vertex.

    Utilizzo del connettore MCP nell'API Messages

    Il connettore MCP utilizza due componenti:

    1. Definizione del server MCP (array mcp_servers): Definisce i dettagli della connessione al server (URL, autenticazione)
    2. Set di strumenti MCP (array tools): Configura quali strumenti abilitare e come configurarli

    Esempio di base

    Questo esempio abilita tutti gli strumenti da un server MCP con configurazione predefinita:

    curl https://api.anthropic.com/v1/messages \
      -H "Content-Type: application/json" \
      -H "X-API-Key: $ANTHROPIC_API_KEY" \
      -H "anthropic-version: 2023-06-01" \
      -H "anthropic-beta: mcp-client-2025-11-20" \
      -d '{
        "model": "claude-opus-4-6",
        "max_tokens": 1000,
        "messages": [{"role": "user", "content": "What tools do you have available?"}],
        "mcp_servers": [
          {
            "type": "url",
            "url": "https://example-server.modelcontextprotocol.io/sse",
            "name": "example-mcp",
            "authorization_token": "YOUR_TOKEN"
          }
        ],
        "tools": [
          {
            "type": "mcp_toolset",
            "mcp_server_name": "example-mcp"
          }
        ]
      }'

    Configurazione del server MCP

    Ogni server MCP nell'array mcp_servers definisce i dettagli della connessione:

    {
      "type": "url",
      "url": "https://example-server.modelcontextprotocol.io/sse",
      "name": "example-mcp",
      "authorization_token": "YOUR_TOKEN"
    }

    Descrizioni dei campi

    ProprietàTipoObbligatorioDescrizione
    typestringSìAttualmente è supportato solo "url"
    urlstringSìL'URL del server MCP. Deve iniziare con https://
    namestringSìUn identificatore univoco per questo server MCP. Deve essere referenziato da esattamente un MCPToolset nell'array tools.
    authorization_tokenstringNoToken di autorizzazione OAuth se richiesto dal server MCP. Vedi la specifica MCP.

    Configurazione del set di strumenti MCP

    MCPToolset si trova nell'array tools e configura quali strumenti dal server MCP sono abilitati e come devono essere configurati.

    Struttura di base

    {
      "type": "mcp_toolset",
      "mcp_server_name": "example-mcp",
      "default_config": {
        "enabled": true,
        "defer_loading": false
      },
      "configs": {
        "specific_tool_name": {
          "enabled": true,
          "defer_loading": true
        }
      }
    }

    Descrizioni dei campi

    ProprietàTipoObbligatorioDescrizione
    typestringSìDeve essere "mcp_toolset"
    mcp_server_namestringSìDeve corrispondere a un nome di server definito nell'array mcp_servers
    default_configobjectNoConfigurazione predefinita applicata a tutti gli strumenti in questo set. Le configurazioni di singoli strumenti in configs sovrascriveranno questi valori predefiniti.
    configsobjectNoOverride di configurazione per singolo strumento. Le chiavi sono nomi di strumenti, i valori sono oggetti di configurazione.
    cache_controlobjectNoConfigurazione del punto di interruzione della cache per questo set di strumenti

    Opzioni di configurazione dello strumento

    Ogni strumento (sia configurato in default_config che in configs) supporta i seguenti campi:

    ProprietàTipoPredefinitoDescrizione
    enabledbooleantrueSe questo strumento è abilitato
    defer_loadingbooleanfalseSe true, la descrizione dello strumento non viene inviata al modello inizialmente. Utilizzato con Tool Search Tool.

    Fusione della configurazione

    I valori di configurazione si uniscono con questa precedenza (da più alta a più bassa):

    1. Impostazioni specifiche dello strumento in configs
    2. default_config a livello di set
    3. Impostazioni predefinite del sistema

    Esempio:

    {
      "type": "mcp_toolset",
      "mcp_server_name": "google-calendar-mcp",
      "default_config": {
        "defer_loading": true
      },
      "configs": {
        "search_events": {
          "enabled": false
        }
      }
    }

    Risultati in:

    • search_events: enabled: false (da configs), defer_loading: true (da default_config)
    • Tutti gli altri strumenti: enabled: true (impostazione predefinita del sistema), defer_loading: true (da default_config)

    Modelli di configurazione comuni

    Abilita tutti gli strumenti con configurazione predefinita

    Il modello più semplice - abilita tutti gli strumenti da un server:

    {
      "type": "mcp_toolset",
      "mcp_server_name": "google-calendar-mcp",
    }

    Lista di autorizzazione - Abilita solo strumenti specifici

    Imposta enabled: false come predefinito, quindi abilita esplicitamente strumenti specifici:

    {
      "type": "mcp_toolset",
      "mcp_server_name": "google-calendar-mcp",
      "default_config": {
        "enabled": false
      },
      "configs": {
        "search_events": {
          "enabled": true
        },
        "create_event": {
          "enabled": true
        }
      }
    }

    Lista di negazione - Disabilita strumenti specifici

    Abilita tutti gli strumenti per impostazione predefinita, quindi disabilita esplicitamente gli strumenti indesiderati:

    {
      "type": "mcp_toolset",
      "mcp_server_name": "google-calendar-mcp",
      "configs": {
        "delete_all_events": {
          "enabled": false
        },
        "share_calendar_publicly": {
          "enabled": false
        }
      }
    }

    Misto - Lista di autorizzazione con configurazione per singolo strumento

    Combina la lista di autorizzazione con configurazione personalizzata per ogni strumento:

    {
      "type": "mcp_toolset",
      "mcp_server_name": "google-calendar-mcp",
      "default_config": {
        "enabled": false,
        "defer_loading": true
      },
      "configs": {
        "search_events": {
          "enabled": true,
          "defer_loading": false
        },
        "list_events": {
          "enabled": true
        }
      }
    }

    In questo esempio:

    • search_events è abilitato con defer_loading: false
    • list_events è abilitato con defer_loading: true (ereditato da default_config)
    • Tutti gli altri strumenti sono disabilitati

    Regole di convalida

    L'API applica queste regole di convalida:

    • Il server deve esistere: Il mcp_server_name in un MCPToolset deve corrispondere a un server definito nell'array mcp_servers
    • Il server deve essere utilizzato: Ogni server MCP definito in mcp_servers deve essere referenziato da esattamente un MCPToolset
    • Set di strumenti univoco per server: Ogni server MCP può essere referenziato da un solo MCPToolset
    • Nomi di strumenti sconosciuti: Se un nome di strumento in configs non esiste sul server MCP, viene registrato un avviso di backend ma non viene restituito alcun errore (i server MCP possono avere disponibilità di strumenti dinamica)

    Tipi di contenuto della risposta

    Quando Claude utilizza strumenti MCP, la risposta includerà due nuovi tipi di blocco di contenuto:

    Blocco di utilizzo dello strumento MCP

    {
      "type": "mcp_tool_use",
      "id": "mcptoolu_014Q35RayjACSWkSj4X2yov1",
      "name": "echo",
      "server_name": "example-mcp",
      "input": { "param1": "value1", "param2": "value2" }
    }

    Blocco di risultato dello strumento MCP

    {
      "type": "mcp_tool_result",
      "tool_use_id": "mcptoolu_014Q35RayjACSWkSj4X2yov1",
      "is_error": false,
      "content": [
        {
          "type": "text",
          "text": "Hello"
        }
      ]
    }

    Server MCP multipli

    Puoi connetterti a più server MCP includendo più definizioni di server in mcp_servers e un MCPToolset corrispondente per ciascuno nell'array tools:

    {
      "model": "claude-opus-4-6",
      "max_tokens": 1000,
      "messages": [
        {
          "role": "user",
          "content": "Use tools from both mcp-server-1 and mcp-server-2 to complete this task"
        }
      ],
      "mcp_servers": [
        {
          "type": "url",
          "url": "https://mcp.example1.com/sse",
          "name": "mcp-server-1",
          "authorization_token": "TOKEN1"
        },
        {
          "type": "url",
          "url": "https://mcp.example2.com/sse",
          "name": "mcp-server-2",
          "authorization_token": "TOKEN2"
        }
      ],
      "tools": [
        {
          "type": "mcp_toolset",
          "mcp_server_name": "mcp-server-1"
        },
        {
          "type": "mcp_toolset",
          "mcp_server_name": "mcp-server-2",
          "default_config": {
            "defer_loading": true
          }
        }
      ]
    }

    Autenticazione

    Per i server MCP che richiedono l'autenticazione OAuth, dovrai ottenere un token di accesso. Il beta del connettore MCP supporta il passaggio di un parametro authorization_token nella definizione del server MCP. I consumatori di API devono gestire il flusso OAuth e ottenere il token di accesso prima di effettuare la chiamata API, nonché aggiornare il token secondo necessità.

    Ottenere un token di accesso per i test

    L'ispettore MCP può guidarti attraverso il processo di ottenimento di un token di accesso a scopo di test.

    1. Esegui l'ispettore con il seguente comando. Hai bisogno di Node.js installato sulla tua macchina.

      npx @modelcontextprotocol/inspector
    2. Nella barra laterale a sinistra, per "Tipo di trasporto", seleziona "SSE" o "Streamable HTTP".

    3. Inserisci l'URL del server MCP.

    4. Nell'area a destra, fai clic sul pulsante "Open Auth Settings" dopo "Need to configure authentication?".

    5. Fai clic su "Quick OAuth Flow" e autorizza nella schermata OAuth.

    6. Segui i passaggi nella sezione "OAuth Flow Progress" dell'ispettore e fai clic su "Continue" fino a raggiungere "Authentication complete".

    7. Copia il valore access_token.

    8. Incollalo nel campo authorization_token nella configurazione del tuo server MCP.

    Utilizzo del token di accesso

    Una volta ottenuto un token di accesso utilizzando uno dei flussi OAuth sopra, puoi utilizzarlo nella configurazione del tuo server MCP:

    {
      "mcp_servers": [
        {
          "type": "url",
          "url": "https://example-server.modelcontextprotocol.io/sse",
          "name": "authenticated-server",
          "authorization_token": "YOUR_ACCESS_TOKEN_HERE"
        }
      ]
    }

    Per spiegazioni dettagliate del flusso OAuth, fai riferimento alla sezione Autorizzazione nella specifica MCP.

    Helper MCP lato client (TypeScript)

    Se gestisci la tua connessione client MCP (ad esempio, con server stdio locali, prompt MCP o risorse MCP), l'SDK TypeScript fornisce funzioni helper che convertono tra tipi MCP e tipi API Claude. Ciò elimina il codice di conversione manuale quando si utilizza l'SDK MCP insieme all'SDK Anthropic.

    Questi helper sono attualmente disponibili solo nell'SDK TypeScript.

    Utilizza il parametro API mcp_servers quando hai server remoti accessibili tramite URL e hai bisogno solo del supporto degli strumenti. Se stai utilizzando l'Agent SDK, le connessioni MCP vengono gestite automaticamente. Utilizza gli helper lato client quando hai bisogno di server locali, prompt, risorse o più controllo sulla connessione con l'SDK di base.

    Installazione

    Installa sia l'SDK Anthropic che l'SDK MCP:

    npm install @anthropic-ai/sdk @modelcontextprotocol/sdk

    Helper disponibili

    Importa gli helper dallo spazio dei nomi beta:

    import {
      mcpTools,
      mcpMessages,
      mcpResourceToContent,
      mcpResourceToFile
    } from "@anthropic-ai/sdk/helpers/beta/mcp";
    HelperDescrizione
    mcpTools(tools, mcpClient)Converte gli strumenti MCP in strumenti API Claude per l'uso con client.beta.messages.toolRunner()
    mcpMessages(messages)Converte i messaggi di prompt MCP nel formato di messaggio API Claude
    mcpResourceToContent(resource)Converte una risorsa MCP in un blocco di contenuto API Claude
    mcpResourceToFile(resource)Converte una risorsa MCP in un oggetto file per il caricamento

    Utilizza gli strumenti MCP

    Converti gli strumenti MCP per l'uso con il tool runner dell'SDK, che gestisce l'esecuzione dello strumento automaticamente:

    import Anthropic from "@anthropic-ai/sdk";
    import { mcpTools } from "@anthropic-ai/sdk/helpers/beta/mcp";
    import { Client } from "@modelcontextprotocol/sdk/client/index.js";
    import { StdioClientTransport } from "@modelcontextprotocol/sdk/client/stdio.js";
    
    const anthropic = new Anthropic();
    
    // Connect to an MCP server
    const transport = new StdioClientTransport({ command: "mcp-server", args: [] });
    const mcpClient = new Client({ name: "my-client", version: "1.0.0" });
    await mcpClient.connect(transport);
    
    // List tools and convert them for the Claude API
    const { tools } = await mcpClient.listTools();
    const runner = await anthropic.beta.messages.toolRunner({
      model: "claude-sonnet-4-6",
      max_tokens: 1024,
      messages: [{ role: "user", content: "What tools do you have available?" }],
      tools: mcpTools(tools, mcpClient)
    });

    Utilizza i prompt MCP

    Converti i messaggi di prompt MCP nel formato di messaggio API Claude:

    import { mcpMessages } from "@anthropic-ai/sdk/helpers/beta/mcp";
    
    const { messages } = await mcpClient.getPrompt({ name: "my-prompt" });
    const response = await anthropic.beta.messages.create({
      model: "claude-sonnet-4-6",
      max_tokens: 1024,
      messages: mcpMessages(messages)
    });

    Utilizza le risorse MCP

    Converti le risorse MCP in blocchi di contenuto da includere nei messaggi, o in oggetti file per il caricamento:

    import { mcpResourceToContent, mcpResourceToFile } from "@anthropic-ai/sdk/helpers/beta/mcp";
    
    // As a content block in a message
    const resource = await mcpClient.readResource({ uri: "file:///path/to/doc.txt" });
    await anthropic.beta.messages.create({
      model: "claude-sonnet-4-6",
      max_tokens: 1024,
      messages: [
        {
          role: "user",
          content: [
            mcpResourceToContent(resource),
            { type: "text", text: "Summarize this document" }
          ]
        }
      ]
    });
    
    // As a file upload
    const fileResource = await mcpClient.readResource({ uri: "file:///path/to/data.json" });
    await anthropic.beta.files.upload({ file: mcpResourceToFile(fileResource) });

    Gestione degli errori

    Le funzioni di conversione lanciano UnsupportedMCPValueError se un valore MCP non è supportato dall'API Claude. Questo può accadere con tipi di contenuto non supportati, tipi MIME o link di risorse non HTTP.

    Guida alla migrazione

    Se stai utilizzando l'intestazione beta deprecata mcp-client-2025-04-04, segui questa guida per migrare alla nuova versione.

    Modifiche principali

    1. Nuova intestazione beta: Cambia da mcp-client-2025-04-04 a mcp-client-2025-11-20
    2. Configurazione dello strumento spostata: La configurazione dello strumento ora si trova nell'array tools come oggetti MCPToolset, non nella definizione del server MCP
    3. Configurazione più flessibile: Il nuovo modello supporta liste di autorizzazione, liste di negazione e configurazione per singolo strumento

    Passaggi di migrazione

    Prima (deprecato):

    {
      "model": "claude-opus-4-6",
      "max_tokens": 1000,
      "messages": [...],
      "mcp_servers": [
        {
          "type": "url",
          "url": "https://mcp.example.com/sse",
          "name": "example-mcp",
          "authorization_token": "YOUR_TOKEN",
          "tool_configuration": {
            "enabled": true,
            "allowed_tools": ["tool1", "tool2"]
          }
        }
      ]
    }

    Dopo (corrente):

    {
      "model": "claude-opus-4-6",
      "max_tokens": 1000,
      "messages": [...],
      "mcp_servers": [
        {
          "type": "url",
          "url": "https://mcp.example.com/sse",
          "name": "example-mcp",
          "authorization_token": "YOUR_TOKEN"
        }
      ],
      "tools": [
        {
          "type": "mcp_toolset",
          "mcp_server_name": "example-mcp",
          "default_config": {
            "enabled": false
          },
          "configs": {
            "tool1": {
              "enabled": true
            },
            "tool2": {
              "enabled": true
            }
          }
        }
      ]
    }

    Modelli di migrazione comuni

    Modello precedenteNuovo modello
    Nessun tool_configuration (tutti gli strumenti abilitati)MCPToolset senza default_config o configs
    tool_configuration.enabled: falseMCPToolset con default_config.enabled: false
    tool_configuration.allowed_tools: [...]MCPToolset con default_config.enabled: false e strumenti specifici abilitati in configs

    Versione deprecata: mcp-client-2025-04-04

    Questa versione è deprecata. Esegui la migrazione a mcp-client-2025-11-20 utilizzando la guida alla migrazione sopra.

    La versione precedente del connettore MCP includeva la configurazione dello strumento direttamente nella definizione del server MCP:

    {
      "mcp_servers": [
        {
          "type": "url",
          "url": "https://example-server.modelcontextprotocol.io/sse",
          "name": "example-mcp",
          "authorization_token": "YOUR_TOKEN",
          "tool_configuration": {
            "enabled": true,
            "allowed_tools": ["example_tool_1", "example_tool_2"]
          }
        }
      ]
    }

    Descrizioni dei campi deprecati

    ProprietàTipoDescrizione
    tool_configurationobjectDeprecato: Utilizza MCPToolset nell'array tools
    tool_configuration.enabledbooleanDeprecato: Utilizza default_config.enabled in MCPToolset
    tool_configuration.allowed_toolsarrayDeprecato: Utilizza il modello di lista di autorizzazione con configs in MCPToolset

    Was this page helpful?

    • Caratteristiche principali
    • Limitazioni
    • Utilizzo del connettore MCP nell'API Messages
    • Esempio di base
    • Configurazione del server MCP
    • Descrizioni dei campi
    • Configurazione del set di strumenti MCP
    • Struttura di base
    • Descrizioni dei campi
    • Opzioni di configurazione dello strumento
    • Fusione della configurazione
    • Modelli di configurazione comuni
    • Abilita tutti gli strumenti con configurazione predefinita
    • Lista di autorizzazione - Abilita solo strumenti specifici
    • Lista di negazione - Disabilita strumenti specifici
    • Misto - Lista di autorizzazione con configurazione per singolo strumento
    • Regole di convalida
    • Tipi di contenuto della risposta
    • Blocco di utilizzo dello strumento MCP
    • Blocco di risultato dello strumento MCP
    • Server MCP multipli
    • Autenticazione
    • Ottenere un token di accesso per i test
    • Utilizzo del token di accesso
    • Helper MCP lato client (TypeScript)
    • Installazione
    • Helper disponibili
    • Utilizza gli strumenti MCP
    • Utilizza i prompt MCP
    • Utilizza le risorse MCP
    • Gestione degli errori
    • Guida alla migrazione
    • Modifiche principali
    • Passaggi di migrazione
    • Modelli di migrazione comuni
    • Versione deprecata: mcp-client-2025-04-04
    • Descrizioni dei campi deprecati