Consultar constancia de Inscripción de ARCA en C#

Con pocas líneas de código

Ivan Muñoz feb 17, 2025 - Ultima edicion feb 22, 2025
.NET

Consultar constancia de Inscripción de ARCA en C#

Para obtener la constancia de inscripción de ARCA en C#, debemos usar el web service de Padrón de constancia de inscripción.

Consumir los web services de ARCA en C# puede ser complicado, por eso vamos a utilizar la API de Afip SDK, que nos permite conectarnos a los web services de ARCA en C# sin complicarnos con el uso de SOAP y la autenticación.

Vamos a usar Newtonsoft.Json para trabajar con JSON.

dotnet add package Newtonsoft.Json

Obtener la autorización

Lo primero que tenemos que hacer es obtener el “Token authorization”, que sería la autorización en ARCA.

Para usar los web services de ARCA, se requiere un certificado digital, con Afip SDK puedes integrarte en modo desarrollo usando el CUIT 20409378472 sin necesidad de obtener un certificado, para poder integrarte lo más rápido posible.

Te dejo este enlace por si luego quieres usar tu propio certificado para desarrollo.

Debemos ejecutar una solicitud POST al endpoint:

https://app.afipsdk.com/api/v1/afip/auth
using System;
using System.Net.Http;
using System.Text;
using System.Text.Json;
using System.Threading.Tasks;
using Newtonsoft.Json;


var client = new HttpClient();

// Paso 1: Obtener el Token y Sign
var authUrl = "https://app.afipsdk.com/api/v1/afip/auth";
var authData = new
{
    environment = "dev",
    tax_id = "20409378472", // CUIT a utilizar
    wsid = "ws_sr_constancia_inscripcion"
};

var authJsonContent = JsonConvert.SerializeObject(authData);
var authContent = new StringContent(authJsonContent, Encoding.UTF8, "application/json");

var authResponse = await client.PostAsync(authUrl, authContent);

if (!authResponse.IsSuccessStatusCode)
{
    Console.WriteLine($"Error en la autorización: {authResponse.StatusCode}");
    return;
}

var authResponseBody = await authResponse.Content.ReadAsStringAsync();
dynamic auth = JsonConvert.DeserializeObject(authResponseBody);

string token = auth.token;
string sign = auth.sign;

Console.WriteLine($"Token: {token}");
Console.WriteLine($"Sign: {sign}");

En este ejemplo utilizamos el web service id ws_sr_constancia_inscripcion, que corresponde al web service constancia de inscripción.

En la pestaña “API” de la documentación puedes consultar todos los parámetros del endpoint.

Ahora tenemos token y sign que nos dio ARCA para usar el web service. No es necesario guardarlos, ya que Afip SDK se encarga de ello por nosotros. Solo debemos solicitarlos antes de cada llamada a los métodos del web service.

Obtenemos los datos

Vamos a obtener los datos del contribuyente con el CUIT 33693450239 (cambiar esto por el CUIT que queramos consultar). Esto lo vamos a hacer llamando al método getPersona_v2.

Debemos ejecutar una solicitud POST al endpoint

https://app.afipsdk.com/api/v1/afip/requests
// Paso 2: Crear la consulta con el Token y Sign obtenidos
var inscriptionUrl = "https://app.afipsdk.com/api/v1/afip/requests";
var inscriptionData = new
{
    environment = "dev",
    method = "getPersona_v2",
    wsid = "ws_sr_constancia_inscripcion",
    @params = new
    {
        token = token, // Token obtenido previamente
        sign = sign,   // Sign obtenido previamente
        cuitRepresentada = "20409378472", // CUIT que estamos utilizando
        idPersona = 33693450239 // CUIT a consultar
    }
};

var inscriptionJsonContent = JsonConvert.SerializeObject(inscriptionData);
var inscriptionContent = new StringContent(inscriptionJsonContent, Encoding.UTF8, "application/json");

var inscriptionResponse = await client.PostAsync(inscriptionUrl, inscriptionContent);

if (!inscriptionResponse.IsSuccessStatusCode)
{
    Console.WriteLine($"Error: {inscriptionResponse.StatusCode}");
    return;
}

var inscriptionResponseBody = await inscriptionResponse.Content.ReadAsStringAsync();
dynamic inscription = JsonConvert.DeserializeObject(inscriptionResponseBody);

Console.WriteLine($"Response: {inscription}");

En inscription, nos devolverá los datos de la constancia de inscripción del contribuyente.

{
    "apellido": ...,
    "nombre": ...,
    "domicilioFiscal": ...,
    "actividad": ...
}

Problemas comunes

Si estás teniendo el error “No existe persona con ese ID”, se debe a que no todos los CUIT están disponibles en el ambiente de desarrollo. Te recomiendo leer este artículo:

No existe persona con ese Id

No existe persona con ese Id

Pasos para resolver este error

Con esto ya tenemos los datos del contribuyente. También podes usar el padrón de alcance 13 o el padrón de alcance 10.

Lo único que nos queda es pasar a modo producción para obtener información real de los contribuyentes.


Ante cualquier duda o pregunta al respecto, pueden resolverla rápidamente dentro de la Comunidad Afip SDK. Además, puedes unirte para estar al tanto de las novedades y problemas técnicos al usar los servicios de ARCA.

Conéctate a ARCA hoy mismo

Certificados, código, tutoriales, soporte... todo lo que necesitas para usar los web services de ARCA en un solo lugar.