API de Encurtamento de Links do Linkly
Crie, atualize e gerencie links programaticamente usando a API de Encurtamento de Links do Linkly.
Relacionado: Analytics API | Webhooks
Antes de Começar
O Linkly gera solicitações de API na interface para você copiar e colar em suas aplicações.
Isso funciona para criação de links e atualização de links.
Economize tempo e deixe que fazemos o trabalho pesado:
- 1Veja abaixo as solicitações de API para criação de links.
- 2Copie as solicitações integralmente. Você pode verificar se funcionam para você.
- 3Peça ao ChatGPT ou equivalente para adaptar essas solicitações em código-fonte para sua aplicação. Não há necessidade de gastar tempo com uma integração complexa. Nossa API é totalmente consumível por máquinas.
Especificação OpenAPI 3.0
Você pode gerar solicitações de API diretamente da interface do usuário do Linkly.
Construtor de API de Encurtamento de Links do Linkly
A API de encurtamento de links do Linkly cria solicitações de API automaticamente com base no conteúdo do formulário. Você pode colar o texto fornecido aqui em qualquer LLM para gerar automaticamente código para sua aplicação.
A API do Linkly é documentada usando o padrão OpenAPI, que vai além do que é fornecido abaixo. Os mesmos endpoints também estão disponíveis como uma coleção Postman com um clique.
Autorização
Você precisará de:
- Sua Chave de API
- ID do Workspace
Você pode obter esses detalhes dentro do Linkly.
- 1Faça login no Linkly.
- 2Clique em Configurações.
- 3Clique em Chaves de API.
Criando ou atualizando um link
Para criar um link, tudo o que você precisa fazer é enviar uma solicitação POST para:
https://app.linklyhq.com/api/v1/link
com os seguintes campos no corpo.
O tipo de codificação é x-www-form-urlencoded ou application/json.
Se você estiver enviando o campo Regras, você deve usar application/json.
Recomendamos que use JSON com a especificação Open API.
| Rótulo | Chave | Tipo | Notas |
|---|---|---|---|
| Chave de API da Conta | api_key | String | Obrigatório |
| ID do Workspace | workspace_id | Integer | Obrigatório |
| ID do Link | id | Integer | Obrigatório ao atualizar link existente |
| Destino | url | String | Obrigatório |
| Apelido | name | String | |
| Notas | note | String | |
| Tags de retargeting (região head) | head_tags | String | Para pixels de retargeting |
| Tags de retargeting (região body) | body_tags | String | Para pixels de retargeting |
| Encaminhar Parâmetros | forward_params | Boolean | |
| Ocultar Referrer | hide_referrer | Boolean | Envia referrer-policy: no-referrer para que o destino não veja Linkly no header referrer |
| Camuflagem | cloaking | Boolean | Mascara a URL de destino atrás de um frame |
| Bloquear Bots | block_bots | Boolean | Bloqueia bots/crawlers conhecidos |
| Pular Rastreamento de Social Crawler | skip_social_crawler_tracking | Boolean | Quando block_bots está ativado, ainda assim deixa crawlers sociais passarem para que previsualizações OG funcionem |
| Análises Públicas | public_analytics | Boolean | Habilita a página pública /abc123.stats para este link |
| Senha | password | String | Visitantes devem inserir essa senha antes do redirecionamento |
| Status de Publicação | enabled | Boolean | |
| Origem UTM | utm_source | String | Para rastreamento UTM |
| Meio UTM | utm_medium | String | Para rastreamento UTM |
| Campanha UTM | utm_campaign | String | Para rastreamento UTM |
| Termo UTM | utm_term | String | Para rastreamento UTM |
| Conteúdo UTM | utm_content | String | Para rastreamento UTM |
| Domínio Personalizado | domain | String | Obrigatório se slug for fornecido. Veja domínios personalizados |
| Sufixo de Domínio Personalizado | slug | String | Se domain for fornecido e slug for null, será gerado automaticamente |
| Título Open Graph | og_title | String | Para previsualizações em redes sociais |
| Descrição Open Graph | og_description | String | Para previsualizações em redes sociais |
| URL de Imagem Open Graph | og_image | String | Para previsualizações em redes sociais |
| ID do Meta Pixel | fb_pixel_id | String | Para Meta Pixel |
| ID do TikTok Pixel | tiktok_pixel_id | String | |
| ID do Google Analytics 4 | ga4_tag_id | String | |
| Contêiner Google Tag Manager | gtm_id | String | |
| Linkify Words | linkify_words | String | Frases separadas por quebra de linha que devem ser auto-encurtadas em landing pages |
| Substituições | replacements | String | Regras de substituição de texto aplicadas à página de destino |
| Data/Hora de Expiração | expiry_datetime | String de Data/Hora ISO8601 | Para links com expiração |
| Destino de Expiração | expiry_destination | String (URL) | Para links com expiração. Deve começar com http. |
| Cliques de Expiração | expiry_clicks | Integer | Expirar o link após esta quantidade de cliques |
| Webhooks | webhooks | Array de strings | URLs de webhook por link. Veja webhooks. |
| IDs de Usuário para Notificar | notify_user_ids | Array de integers | IDs de usuários do workspace para notificar em cada clique |
| Estilos de Código QR | qr_styles | Objeto JSON | Para estilo de código QR. Chaves: fgColor, bgColor, qrStyle, eyeStyle, eyeColorInner, eyeColorOuter, logoImage, logoWidth, logoHeight, logoPadding, logoStyle, quietZone |
| Regras | rules | Array JSON | Para rotadores, geo-redirecionamentos, e redirecionamentos de dispositivo |
Exemplo de Solicitação usando cURL
O código abaixo ilustra como fazer uma solicitação de API para criar um link.
curl -X POST https://app.linklyhq.com/api/v1/link
-H 'cache-control: no-cache'
-d 'api_key=your_secret_key&workspace_id=1&url=http%3A%2F%2Fwww.wikijob.co.uk&name=Test%20Link'
Uma resposta bem-sucedida retornará um objeto JSON representando o link, juntamente com um id do link.
{
"id": 9512,
"url": "https://www.wikijob.co.uk",
"name": "Test Link",
"note": null,
"head_tags": null,
"body_tags": null,
"linkify_words": null,
"replacements": null,
"enabled": true,
"cloaking": false,
"forward_params": false,
"hide_referrer": false,
"block_bots": false,
"skip_social_crawler_tracking": false,
"public_analytics": false,
"password": null,
"domain": null,
"slug": null,
"utm_source": null,
"utm_medium": null,
"utm_campaign": null,
"utm_term": null,
"utm_content": null,
"og_title": null,
"og_description": null,
"og_image": null,
"fb_pixel_id": null,
"tiktok_pixel_id": null,
"ga4_tag_id": null,
"gtm_id": null,
"full_url": "https://l.linklyhq.com/l/2TQ",
"rules": [],
"expiry_datetime": null,
"expiry_destination": null,
"expiry_clicks": null,
"qr_styles": null,
"webhooks": [],
"notify_user_ids": [],
"workspace_id": 1448,
"deleted": false
}
Atualizando um link
Para atualizar um link, envie a mesma solicitação que você usaria para criar o link, mas inclua o campo id para o link que deseja atualizar, junto com as alterações.
Criando Rotadores via API
Para criar um rotador, envie um campo chamado rules como um array JSON, juntamente com o payload do link acima. Você deve usar application/json para enviar arrays JSON.
Por exemplo:
[
{"what": "rotator", "url": "https://www.microsoft.com", "percentage": "50"},
{"what": "rotator", "url": "https://www.apple.com", "percentage": "50"}
]
Criando Geo-Redirecionamentos via API
Para redirecionar por país, envie um campo chamado rules como um array JSON, juntamente com o payload do link acima. Você deve usar codificação application/json para enviar arrays JSON.
Por exemplo:
[
{"what": "country", "url": "https://www.microsoft.com", "matches": "UK"},
{"what": "country", "url": "https://www.apple.com", "matches": "US"}
]
O país é o código de país ISO 3166 alfa-2.
Criando Redirecionamentos de Dispositivo via API
Para redirecionar por dispositivo, envie um campo chamado rules como um array JSON, juntamente com o payload do link acima.
Por exemplo:
[
{"what": "platform", "url": "https://www.google.com", "matches": "windows"},
{"what": "platform", "url": "https://www.apple.com", "matches": "ios"}
]
Onde o campo matches é um de:
- ios
- android
- windows
- linux
- mac
Criando ou Atualizando Múltiplos Links em Uma Solicitação
O Linkly suporta a criação/alteração de até 1000 links por solicitação.
Para fazer isso, envie sua chave de API como parte da solicitação da seguinte forma:
https://app.linklyhq.com/api/v1/link?api_key=XXXXXXXXXXX
Em seguida, use o mesmo schema acima para os casos individuais de links, mas envolva as solicitações de links em um array, da forma:
[{link}, {link}]
Aqui está uma solicitação completa que atualizará dois links:
wget --no-check-certificate \
--method POST \
--timeout=0 \
--header 'Content-Type: application/json' \
--body-data '[
{
"workspace_id": "WORKSPACE_ID",
"url": "https://nature.com",
"name": "Test",
"id": LINK_ID
},
{
"workspace_id": "WORKSPACE_ID",
"url": "https://science.com",
"id": LINK_ID
}
]' \
'https://app.linklyhq.com/api/v1/workspace/WORKSPACE_ID/links?api_key=API_KEY'
Isso funciona tanto para ações de criação quanto de atualização.
Esteja ciente de que pode levar até 60 segundos para uma solicitação grande. Se as solicitações demorarem mais que isso, elas falharão, e você deve considerar dividir sua carga de trabalho em chunks menores.
Limites de Taxa
A API de encurtamento de links é limitada a 20 solicitações/segundo. Até 200 solicitações por segundo estão disponíveis sob demanda. Você pode fazer upload de até 1000 links em uma única solicitação.
Relacionado
- Analytics API - Exporte dados de cliques e relatórios de tráfego
- Webhooks - Notificações de clique em tempo real
- Integração Zapier - Integrações sem código
Disponibilidade do plano
Incluído em todos os planos
Rastreie 500 cliques mensais com todos os recursos incluídos.