> ## Documentation Index
> Fetch the complete documentation index at: https://x-preview-mintlify-066e8699.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

# Realiza tu primera solicitud

> Envía tu primera solicitud a la X API v2 en minutos usando cURL o Postman, incluyendo autenticación, selección del endpoint y análisis de la respuesta JSON.

export const Button = ({href, children}) => {
  return <div className="not-prose group">
    <a href={href}>
      <button className="flex items-center space-x-2.5 py-1 px-4 bg-primary-dark dark:bg-white text-white dark:text-gray-950 rounded-full group-hover:opacity-[0.9] font-medium">
        <span>
          {children}
        </span>
        <svg width="3" height="24" viewBox="0 -9 3 24" class="h-6 rotate-0 overflow-visible"><path d="M0 0L3 3L0 6" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round"></path></svg>
      </button>
    </a>
  </div>;
};

Esta guía te muestra paso a paso cómo realizar tu primera solicitud a la X API. Necesitarás una [cuenta de desarrollador con credenciales de app](/x-api/getting-started/getting-access) antes de comenzar.

***

## Inicio rápido con cURL

La forma más rápida de probar la API es con cURL. Vamos a buscar un usuario:

```bash theme={null}
curl "https://api.x.com/2/users/by/username/xdevelopers" \
  -H "Authorization: Bearer $BEARER_TOKEN"
```

Reemplaza `$BEARER_TOKEN` con tu Bearer Token real. Obtendrás una respuesta como esta:

```json theme={null}
{
  "data": {
    "id": "2244994945",
    "name": "X Developers",
    "username": "xdevelopers"
  }
}
```

***

## Guía paso a paso

<Steps>
  <Step title="Obtén tu Bearer Token">
    En la [Developer Console](https://console.x.com), navega a tu app y copia el Bearer Token.
  </Step>

  <Step title="Elige un endpoint">
    Comienza con alguno de estos endpoints aptos para principiantes:

    | Endpoint                                          | Qué hace                                              |
    | :------------------------------------------------ | :---------------------------------------------------- |
    | [User lookup](/x-api/users/lookup/introduction)   | Obtén el perfil de usuario por nombre de usuario o ID |
    | [Post lookup](/x-api/posts/lookup/introduction)   | Obtén un post por ID                                  |
    | [Recent search](/x-api/posts/search/introduction) | Busca posts de los últimos 7 días                     |
  </Step>

  <Step title="Realiza la solicitud">
    Usa cURL, Postman o tu cliente HTTP preferido:

    ```bash theme={null}
    # Buscar un usuario por nombre de usuario
    curl "https://api.x.com/2/users/by/username/xdevelopers" \
      -H "Authorization: Bearer $BEARER_TOKEN"
    ```
  </Step>

  <Step title="Analiza la respuesta">
    Las respuestas son JSON. Los datos principales están en el campo `data`:

    ```json theme={null}
    {
      "data": {
        "id": "2244994945",
        "name": "X Developers",
        "username": "xdevelopers"
      }
    }
    ```
  </Step>
</Steps>

***

## Solicita más datos con fields

Por defecto, los endpoints devuelven campos mínimos. Usa el parámetro `fields` para solicitar datos adicionales:

```bash theme={null}
curl "https://api.x.com/2/users/by/username/xdevelopers?user.fields=created_at,description,public_metrics" \
  -H "Authorization: Bearer $BEARER_TOKEN"
```

Respuesta:

```json theme={null}
{
  "data": {
    "id": "2244994945",
    "name": "X Developers",
    "username": "xdevelopers",
    "created_at": "2013-12-14T04:35:55.000Z",
    "description": "The voice of the X Developer Platform",
    "public_metrics": {
      "followers_count": 570842,
      "following_count": 2048,
      "tweet_count": 14052,
      "listed_count": 1672
    }
  }
}
```

[Más información sobre fields →](/x-api/fundamentals/fields)

***

## Más ejemplos

<Tabs>
  <Tab title="Buscar un post">
    ```bash theme={null}
    curl "https://api.x.com/2/tweets/1460323737035677698?tweet.fields=created_at,public_metrics" \
      -H "Authorization: Bearer $BEARER_TOKEN"
    ```
  </Tab>

  <Tab title="Buscar posts recientes">
    ```bash theme={null}
    curl "https://api.x.com/2/tweets/search/recent?query=from:xdevelopers&tweet.fields=created_at" \
      -H "Authorization: Bearer $BEARER_TOKEN"
    ```
  </Tab>

  <Tab title="Obtener los posts de un usuario">
    ```bash theme={null}
    curl "https://api.x.com/2/users/2244994945/tweets?max_results=5" \
      -H "Authorization: Bearer $BEARER_TOKEN"
    ```
  </Tab>
</Tabs>

***

## Usar código en lugar de cURL

<Tabs>
  <Tab title="Python">
    ```python theme={null}
    import requests

    bearer_token = "YOUR_BEARER_TOKEN"
    url = "https://api.x.com/2/users/by/username/xdevelopers"

    headers = {"Authorization": f"Bearer {bearer_token}"}
    response = requests.get(url, headers=headers)

    print(response.json())
    ```
  </Tab>

  <Tab title="JavaScript">
    ```javascript theme={null}
    const bearerToken = "YOUR_BEARER_TOKEN";
    const url = "https://api.x.com/2/users/by/username/xdevelopers";

    fetch(url, {
      headers: { Authorization: `Bearer ${bearerToken}` }
    })
      .then(res => res.json())
      .then(data => console.log(data));
    ```
  </Tab>

  <Tab title="SDKs oficiales">
    Para uso en producción, recomendamos los SDKs oficiales:

    * [Python SDK](/xdks/python/overview)
    * [TypeScript SDK](/xdks/typescript/overview)

    Se encargan automáticamente de la autenticación, la paginación y los límites de tasa.
  </Tab>
</Tabs>

***

## Herramientas para pruebas

<CardGroup cols={3}>
  <Card title="Postman" icon="server" href="/tutorials/postman-getting-started">
    Pruebas visuales de la API con nuestra colección.
  </Card>

  <Card title="Código de muestra" icon="github" href="https://github.com/xdevplatform/Twitter-API-v2-sample-code">
    Ejemplos en múltiples lenguajes.
  </Card>

  <Card title="Referencia de la API" icon="code" href="/x-api/posts/lookup/introduction">
    Documentación completa de los endpoints.
  </Card>
</CardGroup>

***

## Solución de problemas

<Accordion title="401 Unauthorized">
  * Verifica que tu Bearer Token sea correcto
  * Asegúrate de que el token no haya sido regenerado
  * Verifica el formato del encabezado `Authorization`: `Bearer YOUR_TOKEN`
</Accordion>

<Accordion title="403 Forbidden">
  * Es posible que tu app no tenga acceso a este endpoint
  * Algunos endpoints requieren autenticación de contexto de usuario (OAuth 1.0a o 2.0)
  * Verifica los permisos de tu app en la Developer Console
</Accordion>

<Accordion title="429 Too Many Requests">
  * Alcanzaste un límite de tasa
  * Consulta el encabezado `x-rate-limit-reset` para saber cuándo reintentar
  * Implementa retroceso exponencial en tu código
</Accordion>

[Referencia completa de errores →](/x-api/fundamentals/response-codes-and-errors)

***

## Próximos pasos

<CardGroup cols={2}>
  <Card title="Aprende sobre autenticación" icon="key" href="/resources/fundamentals/authentication/overview">
    Comprende OAuth para solicitudes con contexto de usuario.
  </Card>

  <Card title="Explora los endpoints" icon="compass" href="/x-api/posts/search/introduction">
    Descubre lo que puedes construir.
  </Card>

  <Card title="Usa un SDK" icon="cube" href="/tools-and-libraries">
    Desarrollo más rápido con bibliotecas oficiales.
  </Card>

  <Card title="Construye algo" icon="hammer" href="/x-api/what-to-build">
    Ideas de qué crear.
  </Card>
</CardGroup>
