- Para implementar una puerta de enlace para su organización, consulte Implementar una puerta de enlace LLM
- Para ver qué envía Claude Code a una puerta de enlace, consulte la referencia del protocolo de puerta de enlace
Comprobar una configuración existente
Los administradores pueden distribuir la dirección de la puerta de enlace y la credencial a través de configuración administrada, administración de dispositivos, o unapiKeyHelper, para que Claude Code las recoja al iniciar sin que tenga que configurar nada. Para comprobar si su organización ya lo hizo:
Iniciar Claude Code
Ejecute
claude. Si se abre en la pantalla de inicio de sesión en lugar de una sesión, no se distribuyó ninguna credencial de puerta de enlace; configúrela usted mismo a continuación.Comprobar la pestaña Estado
Si Claude Code inició una sesión sin mostrar la pantalla de inicio de sesión, ejecute
/status, abra la pestaña Estado, y compruebe dos líneas:Anthropic base URL: esta línea solo aparece cuando se establece una dirección de puerta de enlace. Si no está ahí, Claude Code no está apuntando a la puerta de enlace; configúrela usted mismo a continuación.Auth tokenoAPI key: una línea que nombreANTHROPIC_AUTH_TOKEN,ANTHROPIC_API_KEY, o unapiKeyHelperconfirma que una credencial de puerta de enlace está activa. Una líneaLogin methodque nombre una cuenta de claude.ai en su lugar significa que la credencial no se distribuyó; establézcala usted mismo.
/status se ven bien pero el mensaje a Claude falla, consulte la tabla de solución de problemas.
Configurar Claude Code usted mismo
Para configurar Claude Code para la puerta de enlace usted mismo, necesita de su equipo de puerta de enlace:- La URL base de la puerta de enlace
- Una credencial: una cadena de clave o token, o un comando que obtenga una
- Si su equipo de puerta de enlace no dijo qué tipo de credencial es, la sección variable de credencial a continuación cubre qué intentar
- Establecer la variable de credencial y establecer la URL base: las dos variables que toda conexión de puerta de enlace necesita
- Verificar la conexión: confirmar que funciona antes de persistir nada
- Configurar cada superficie: si está usando una superficie además de la CLI de Claude Code, como VS Code, vea cómo configurarla con sus credenciales de puerta de enlace
- Configuración adicional: variables que algunas puertas de enlace necesitan más allá de la URL base y la credencial, como un encabezado personalizado, un asistente de credencial, descubrimiento de modelos, o una URL base en formato de proveedor. Establezca estos solo si su administrador los nombró
Establecer la variable de credencial
Para autenticar Claude Code en la puerta de enlace, establezca su credencial en una variable de entorno. Qué variable depende de lo que su equipo de puerta de enlace le dijo:| Establecer la credencial en | Usar cuando |
|---|---|
ANTHROPIC_AUTH_TOKEN | Su equipo de puerta de enlace dijo “bearer token” o “Authorization header” |
ANTHROPIC_API_KEY | Su equipo de puerta de enlace dijo “API key” o “x-api-key” |
apiKeyHelper | La credencial rota o viene de un almacén |
ANTHROPIC_AUTH_TOKEN; la solicitud de verificación a continuación muestra cómo saber si necesita cambiar.
Establecer la URL base y la credencial
Establezca la URL base de la puerta de enlace y la variable de credencial que eligió arriba como variables de entorno. Los ejemplos usanANTHROPIC_AUTH_TOKEN; cámbielo por ANTHROPIC_API_KEY si esa es la variable que eligió. Puede establecerlos en su shell, que dura una sesión de terminal, o en un archivo de configuración de Claude Code, que persiste en todas partes donde se ejecuta Claude Code.
Para su primera conexión, comience con exportaciones de shell y ejecute la solicitud de verificación antes de mover los valores a un archivo de configuración.
Establecer como variables de entorno de shell
Reemplace los valores con los que su equipo de puerta de enlace le dio:- Bash o Zsh
- PowerShell
~/.zshrc, ~/.bashrc, o su $PROFILE de PowerShell, o use un archivo de configuración en su lugar.
Establecer en un archivo de configuración
Para que la configuración se aplique en todas partes donde se ejecuta Claude Code sin depender de su shell, establezca las variables en el bloqueenv de un archivo de configuración. Los archivos de configuración tienen diferentes alcances:
~/.claude/settings.jsonse aplica a todos sus proyectos. En Windows la ruta es%USERPROFILE%\.claude\settings.json.claude/settings.local.jsonse aplica a un proyecto. Claude Code lo agrega a su gitignore cuando crea el archivo; si lo crea usted mismo, agréguelo a su gitignore manualmente primero para que no cometa accidentalmente su credencial
env se ve igual en cualquiera de los archivos:
env de archivo de configuración establecen la misma variable, se aplica el valor del archivo de configuración. Ejecute /status para ver qué URL base y fuente de credencial está usando Claude Code.
Verificar la conexión
Con las variables exportadas en su shell, envíe una solicitud de un token a la puerta de enlace directamente. Esto confirma que la URL y la credencial funcionan antes de abrir Claude Code, por lo que una falla apunta a la puerta de enlace en lugar de su configuración. Los comandos a continuación leen las variables de shell, por lo que necesitan las exportaciones de shell incluso si también pone los valores en un archivo de configuración.- Bash o Zsh
- PowerShell
x-api-key, reemplace el encabezado Authorization con x-api-key: $ANTHROPIC_API_KEY en el comando Bash, o la entrada de tabla hash "Authorization" con "x-api-key" = "$env:ANTHROPIC_API_KEY" en el comando PowerShell.
Una respuesta JSON que comience con {"id":"msg_ e incluya un campo "content":[...] significa que la puerta de enlace es alcanzable y la credencial funciona. Un error que nombre un modelo desconocido aún prueba que la URL y la credencial funcionan, ya que la puerta de enlace autenticó la solicitud antes de rechazar el nombre del modelo; no necesita encontrar un modelo que su puerta de enlace sirva para esta prueba. Un 401 significa que la credencial fue rechazada: si adivinó la variable, cambie a la otra y re-exporte.
Confirmar en Claude Code
Inicieclaude desde el mismo shell para que herede las exportaciones, envíe un mensaje, y ejecute /status.
En la pestaña Estado, la línea Anthropic base URL debe mostrar su dirección de puerta de enlace, lo que confirma que las solicitudes se enrutan allí; si la línea no está ahí, la variable no llegó a la sesión. Una línea Auth token o API key que nombre la variable que estableció confirma que la credencial de puerta de enlace está activa en lugar de un inicio de sesión de claude.ai guardado.
Si el mensaje falla, o /status no muestra la URL de la puerta de enlace, consulte la tabla de solución de problemas a continuación.
Cómo la variable de credencial se asigna a un encabezado
Cada variable envía la credencial en un encabezado HTTP diferente:ANTHROPIC_AUTH_TOKEN en Authorization: Bearer, ANTHROPIC_API_KEY en x-api-key, y apiKeyHelper en ambos. Una credencial en la variable incorrecta llega a la puerta de enlace en un encabezado que no lee, y la solicitud falla con 401. Si la solicitud de verificación devolvió 401, cambie a la otra variable e intente de nuevo.
Conflictos con un inicio de sesión existente
Una variable de credencial de puerta de enlace tiene precedencia sobre un inicio de sesión de claude.ai guardado o una clave de Consola. Su inicio de sesión de claude.ai permanece guardado y sin usar mientras la variable está establecida; desestablezca la variable y Claude Code vuelve a ella. ConANTHROPIC_AUTH_TOKEN, la variable tiene precedencia inmediatamente. Con ANTHROPIC_API_KEY, se le solicita una vez en modo interactivo para aprobar la clave antes de que tome el control.
Ejecute /status para confirmar qué fuente de credencial está activa. Si el inicio muestra una advertencia de conflicto de autenticación que nombra dos fuentes, consulte la primera fila de la tabla de solución de problemas para saber cuál descartar. Para borrar un inicio de sesión guardado para que solo permanezca la credencial de puerta de enlace, ejecute /logout.
Configurar cada superficie
La CLI lee las variables de entorno y archivos de configuración anteriores. Las otras superficies son la extensión de VS Code, la aplicación de escritorio, GitHub Actions, el Agent SDK, y las superficies en la nube como Slack y la web; las secciones a continuación cubren si esa configuración llega a cada una.Extensión de VS Code
Establezca las variables de puerta de enlace para la extensión de VS Code enclaudeCode.environmentVariables, en la configuración de usuario propia de VS Code abierta con el comando Preferences: Open User Settings (JSON). La extensión comprueba las credenciales de esta configuración antes de lanzarse, por lo que es el lugar confiable para la credencial de puerta de enlace; los valores en ~/.claude/settings.json llegan al proceso generado pero no a la comprobación de inicio de sesión propia de la extensión.
Aplicación de escritorio
La aplicación de escritorio lee el enrutamiento de puerta de enlace de una configuración distribuida por administrador, no deANTHROPIC_BASE_URL o settings.json. Si su organización la ha distribuido, la aplicación de escritorio se enruta a través de la puerta de enlace sin configuración de su parte; si no, use la CLI de terminal o la extensión de VS Code para sesiones de puerta de enlace. Los administradores distribuyen la configuración como se describe en la implementación de la organización.
Si la aplicación de escritorio muestra Gateway was unreachable, la aplicación no pudo alcanzar la URL base configurada al iniciar; compruebe la URL y la ruta de red con la prueba de curl anterior.
GitHub Actions
Claude Code GitHub Actions leeANTHROPIC_BASE_URL y ANTHROPIC_CUSTOM_HEADERS del bloque env del flujo de trabajo. Pase la credencial como la entrada anthropic_api_key de la acción; la acción la establece como ANTHROPIC_API_KEY, por lo que llega a la puerta de enlace en el encabezado x-api-key.
Para una puerta de enlace x-api-key, establezca la URL base en env y pase la clave de puerta de enlace como entrada:
anthropic_api_key y ANTHROPIC_AUTH_TOKEN en el bloque env del flujo de trabajo. La acción requiere anthropic_api_key, CLAUDE_CODE_OAUTH_TOKEN, o federación de identidad de carga de trabajo antes de lanzar Claude Code, y no lee ANTHROPIC_AUTH_TOKEN, por lo que la entrada satisface esa comprobación de lanzamiento mientras la variable de entorno pone la clave en el encabezado Authorization que la puerta de enlace lee. La copia en x-api-key se ignora:
CLAUDE_CODE_OAUTH_TOKEN y federación de identidad de carga de trabajo, consulte Claude Code GitHub Actions y el README de la acción.
Agent SDK
El Agent SDK no tiene opciones específicas de puerta de enlace; pasa variables de entorno al proceso de Claude Code que genera. Cada SDK acepta una opciónenv que establece el entorno del proceso generado, y los SDK de TypeScript y Python lo tratan de manera diferente:
- TypeScript: el proceso generado hereda el entorno principal de forma predeterminada, pero establecer
options.envreemplaza el entorno completamente. Extiendaprocess.enven él para mantener sus variables de puerta de enlace. - Python:
ClaudeAgentOptions(env=...)se fusiona en el entorno heredado, por lo que las variables de puerta de enlace establecidas en el proceso principal se transmiten sin extender.
Slack, web y Control Remoto
Claude Code en Slack y Claude Code en la web son productos alojados por Anthropic que siempre usan la API de Anthropic; no son parte de una implementación de puerta de enlace. Las variables de puerta de enlace establecidas en la configuración de entorno de una sesión en la nube no se aplican. Si su tráfico debe permanecer en la puerta de enlace, no habilite estas superficies para esos usuarios. Control Remoto y dictado de voz ambos se basan en una identidad de claude.ai: Control Remoto para emparejar una sesión en vivo con su cuenta, y dictado de voz para alcanzar el punto final de transcripción de claude.ai. No están disponibles mientrasANTHROPIC_API_KEY, ANTHROPIC_AUTH_TOKEN, o un apiKeyHelper está activo. Para usar cualquiera de ellos, desestablezca la credencial de puerta de enlace e inicie sesión con claude.ai en su lugar; /doctor nombra la variable a desestablecer.
Configuración adicional
Estas configuraciones cubren casos más allá de la URL base y la credencial. Establézcalas solo si las instrucciones de su administrador o la tabla de solución de problemas llaman a una.Enviar encabezados adicionales
Algunas puertas de enlace enrutan o etiquetan solicitudes usando un encabezado personalizado además de la credencial, por ejemplo un identificador de inquilino o una clave de enrutamiento. Para enviar uno, establezcaANTHROPIC_CUSTOM_HEADERS con un par Name: Value por línea. El ejemplo a continuación agrega un encabezado de enrutamiento llamado X-Org-Route:
- Bash o Zsh
- PowerShell
ANTHROPIC_CUSTOM_HEADERS en el bloque env de un archivo de configuración. Use \n entre pares allí, ya que las cadenas JSON no pueden abarcar múltiples líneas:
Agregar modelos de puerta de enlace al selector de modelos
El descubrimiento de modelos consulta la puerta de enlace para su lista de modelos al iniciar y agrega esos nombres al selector/model junto con las entradas integradas.
Habilítelo si su puerta de enlace sirve nombres de modelos que no están en la lista integrada de Claude Code y desea seleccionarlos del selector. Si los modelos integrados son los que usa, no necesita descubrimiento; su administrador también puede haberlo habilitado ya a través de configuración administrada.
Para habilitarlo, establezca CLAUDE_CODE_ENABLE_GATEWAY_MODEL_DISCOVERY=1 en su shell o en el bloque env de ~/.claude/settings.json. El descubrimiento requiere Claude Code v2.1.129 o posterior.
Los modelos descubiertos aparecen como entradas /model adicionales etiquetadas como From gateway. Para confirmar que el descubrimiento se ejecutó, inicie claude --debug y busque las líneas [gatewayDiscovery]: un éxito registra cuántos modelos se almacenaron en caché, y un 404, tiempo de espera, o redirección se registra allí también. Para cuándo se ejecuta el descubrimiento, qué filtra, y el formato de respuesta que las puertas de enlace sirven, consulte la referencia de descubrimiento de modelos.
Rotar credenciales con apiKeyHelper
UnapiKeyHelper es un comando que Claude Code ejecuta para obtener su credencial de puerta de enlace, en lugar de leerla de una variable de entorno estática.
Use un asistente cuando la credencial expira en un cronograma, viene de un comando de almacén o SSO, o su administrador le dijo que configure uno. Si su credencial es una cadena fija que establece una vez, la variable de credencial es todo lo que necesita y puede omitir esta sección.
El asistente es cualquier comando de shell que imprime la credencial actual en stdout. Claude Code lo ejecuta a través de su shell del sistema, por lo que en Windows puede ser un ejecutable o una invocación de PowerShell. Escriba el script, hágalo ejecutable, y haga referencia a él desde apiKeyHelper en su archivo de configuración:
- Bash o Zsh
- PowerShell
Por ejemplo, un script que lee desde un almacén:Haga referencia a su ruta en
~/.claude/settings.json:CLAUDE_CODE_API_KEY_HELPER_TTL_MS en milisegundos, por ejemplo CLAUDE_CODE_API_KEY_HELPER_TTL_MS=900000 para 15 minutos.
El valor del asistente se envía en los encabezados Authorization y x-api-key, por lo que funciona cualquiera que sea el encabezado que su puerta de enlace lea.
Enrutar a un proveedor en la nube a través de una puerta de enlace
Estas configuraciones apuntan Claude Code a una puerta de enlace a través de una variable de URL base específica del proveedor en lugar deANTHROPIC_BASE_URL. Las puertas de enlace de Bedrock y Vertex aceptan los formatos de solicitud nativos de esos proveedores; las puertas de enlace de Foundry y Claude Platform en AWS aceptan el formato de Mensajes de Anthropic y difieren solo en qué variable de URL base las alcanza.
Use una solo si su equipo de puerta de enlace nombró específicamente Bedrock, Vertex, Foundry, o Claude Platform en AWS. Si la solicitud de verificación anterior devolvió JSON, puede omitir esta sección.
Establezca el bloque para el proveedor que su equipo de puerta de enlace nombró. Las variables de omitir autenticación le dicen a Claude Code que no firme solicitudes con credenciales de proveedor, ya que la puerta de enlace tiene esas. Si la puerta de enlace necesita su propio token, agregue ANTHROPIC_AUTH_TOKEN después del bloque, excepto para Foundry, que usa ANTHROPIC_FOUNDRY_API_KEY como se muestra.
Amazon Bedrock
- Bash o Zsh
- PowerShell
Google Vertex AI
- Bash o Zsh
- PowerShell
Microsoft Foundry
Ponga la credencial de la puerta de enlace enANTHROPIC_FOUNDRY_API_KEY; se envía a la puerta de enlace como el encabezado x-api-key. CLAUDE_CODE_SKIP_FOUNDRY_AUTH no se aplica aquí: sin una clave de API, el cliente de Foundry falla cada solicitud antes de que salga de la máquina.
- Bash o Zsh
- PowerShell
Claude Platform en AWS
Consulte Claude Platform en AWS para el ID del espacio de trabajo.- Bash o Zsh
- PowerShell
Solucionar problemas de errores de puerta de enlace
Estos son los errores más comunes al ejecutar Claude Code a través de una puerta de enlace, con la causa del lado de la puerta de enlace y la solución:| Error | Causa | Solución |
|---|---|---|
Una advertencia de inicio que nombra dos fuentes de credencial y termina en auth may not work as expected. Las versiones más antiguas muestran Auth conflict: Both a token (SOURCE) and an API key (SOURCE) are set en su lugar. | Una credencial de puerta de enlace y un inicio de sesión guardado están ambos activos; la variable se usa para solicitudes, pero el inicio de sesión obsoleto puede causar comportamiento de autenticación inesperado | Desestablezca la variable para usar el inicio de sesión guardado, o ejecute /logout para usar la credencial de puerta de enlace |
Errores 401 que nombran un token inválido o no reconocido | La credencial no es una que la puerta de enlace emitió, o está en un encabezado que la puerta de enlace no lee | Confirme que la variable coincida con su tipo de credencial en la tabla de credencial, y regenere la clave en la puerta de enlace si fue revocada |
Unable to connect to API (ConnectionRefused), o (ECONNREFUSED) de instalaciones de npm, a menudo después de una pausa silenciosa mientras Claude Code reintenta con retroceso | Nada respondió en la URL base: la dirección es incorrecta, o una VPN o firewall bloquea la ruta a la puerta de enlace | Ejecute la prueba de curl anterior, que falla inmediatamente con la misma causa, y confirme la URL y la ruta de red con su equipo de puerta de enlace |
API returned an empty or malformed response (HTTP 200) | La puerta de enlace o un proxy intermedio devolvió una respuesta que no es de API, a menudo una página de error HTML o de inicio de sesión | Pruebe con la solicitud de curl anterior; corrija la ruta de puerta de enlace que devuelve JSON no válido |
Errores 400 que nombran context_management, Extra inputs are not permitted, u otros campos no reconocidos | La puerta de enlace reenvía solicitudes a un upstream que rechaza campos que Claude Code envía a puntos finales en formato de Anthropic | Establezca CLAUDE_CODE_DISABLE_EXPERIMENTAL_BETAS=1, que suprime la mayoría de campos de pre-lanzamiento; consulte paso de características. Algunos betas no están controlados por esta bandera; para esos, establezca la variable de proveedor CLAUDE_CODE_USE_* coincidente para que Claude Code envíe solo lo que ese proveedor acepta |
Errores 400 que nombran thinking o adaptive, como Input tag 'adaptive' found | La compilación del modelo upstream no acepta razonamiento adaptativo, que Claude Code solicita para modelos Claude 4.6 y posteriores | Actualice el upstream de la puerta de enlace. En Opus 4.6 y Sonnet 4.6, CLAUDE_CODE_DISABLE_ADAPTIVE_THINKING=1 funciona en su lugar. Las variables de capacidad de configuración de modelo se aplican solo a las configuraciones de proveedor, como CLAUDE_CODE_USE_BEDROCK y CLAUDE_CODE_USE_VERTEX, no detrás de una puerta de enlace ANTHROPIC_BASE_URL |
Errores 400 que indican un contexto o límite de token en las propias palabras de la puerta de enlace, como ContextWindowExceededError o prompt token count of N exceeds the limit of M | La puerta de enlace aplica un contexto más pequeño que la ventana nativa del modelo y reescribe el error upstream, por lo que el compacto automático y reintento, que coincide con la redacción prompt is too long de Anthropic, no se dispara | Ejecute /compact para recuperar la sesión. Para prevenirlo, establezca CLAUDE_CODE_AUTO_COMPACT_WINDOW al límite de la puerta de enlace; el valor se fija a al menos 100,000 tokens y como máximo la ventana de contexto del modelo, por lo que un límite de puerta de enlace por debajo de 100,000 no puede coincidir y /compact permanece como la recuperación allí. También establezca CLAUDE_CODE_MAX_OUTPUT_TOKENS por debajo del límite de salida del modelo de puerta de enlace |
Modelos faltantes del selector /model | Los nombres de modelos de puerta de enlace no están en la lista integrada de Claude Code | Habilite descubrimiento de modelos de puerta de enlace o agregue nombres con las variables de configuración de modelo |
| Claude Code le pide que inicie sesión aunque la prueba de curl tenga éxito | La CLI no tiene credencial propia: una URL base alcanzable no es una, y un bloque env en el .claude/settings.json o .claude/settings.local.json de un proyecto se aplica solo después del asistente de primera ejecución y la solicitud de confianza | Establezca ANTHROPIC_AUTH_TOKEN en algún lugar que Claude Code lea antes de la configuración de primera ejecución: una exportación de shell, el bloque env en ~/.claude/settings.json, o configuración administrada |
ANTHROPIC_API_KEY está establecido pero ignorado, sin solicitud | La clave necesita una aprobación única en sesiones interactivas, y una clave previamente rechazada se ignora sin preguntar de nuevo | Habilítela bajo /config con la opción Use custom API key |
This machine's managed settings require a first-party login | La configuración administrada incluye forceLoginMethod o forceLoginOrgUUID, que en Claude Code v2.1.146 y posterior no pueden coexistir con ANTHROPIC_API_KEY, ANTHROPIC_AUTH_TOKEN, o apiKeyHelper | Su administrador debe eliminar forceLoginMethod y forceLoginOrgUUID de la configuración administrada para usar credenciales de puerta de enlace, o eliminar la credencial de puerta de enlace para usar inicio de sesión de primera parte. Los dos no pueden combinarse |
403 con un cuerpo HTML como 403 Forbidden, cuando los registros propios de la puerta de enlace no muestran ninguna solicitud recibida | Un firewall de aplicación web o proxy inverso frente a la puerta de enlace bloqueó el cuerpo de la solicitud antes de que llegara a la puerta de enlace. Los avisos de Claude Code incluyen etiquetas de estilo XML y código fuente que coinciden con reglas de cuerpo de secuencias de comandos entre sitios, por lo que una prueba de curl corta pasa mientras una sesión real no | Exima la ruta /v1/messages de la puerta de enlace de la inspección del cuerpo de la solicitud. En AWS WAF esta es la regla administrada CrossSiteScripting_Body; en nginx con ModSecurity es la regla de cuerpo OWASP CRS equivalente |
Errores de certificado o TLS como SSL certificate verification failed o Self-signed certificate detected, cuando la prueba de curl tiene éxito | El tiempo de ejecución de Claude Code no está confiando en la misma autoridad de certificación que curl usa. Común detrás de proxies de inspección TLS corporativos | Establezca NODE_EXTRA_CA_CERTS a la ruta del paquete de CA; consulte almacén de certificados de CA |
Recursos relacionados
- Descripción general de puertas de enlace LLM: qué es una puerta de enlace y cómo interactúa con las suscripciones de claude.ai
- Implementar una puerta de enlace LLM para su organización: la lista de verificación orientada al administrador para implementar y distribuir la configuración de puerta de enlace
- Referencia del protocolo de puerta de enlace: qué envía Claude Code a una puerta de enlace, incluidos los encabezados y campos que la puerta de enlace debe reenviar
- Configuración: dónde viven los archivos de configuración y cómo se lee el bloque
env - Autenticación: cómo interactúan las variables de credencial,
apiKeyHelper, e inicio de sesión OAuth