## DETRAN / SP / Débitos e Restrições

      
        Consulta a existência de débitos, restrições e vistorias de veículos de terceiros do Estado de São Paulo através da placa e renavam informados.
      
      
        Se você deseja utilizar uma única API para consultar restrições de veículos em DETRANs de todos os estados do Brasil, recomendamos utilizar a API Detran / Restrições (Unificada).
      
      Atenção! Esta consulta pode ter limite de utilização num único dia. Recomendamos não processar lotes ou grandes volumes com esta consulta utilizando o mesmo login, num mesmo dia.


### Site URL
- https://www.detran.sp.gov.br/detransp/pb/servicos/veiculos/consultar_debitos_restricoes?id=carta_de_servico_consultar_debitos_restricoes

### Request
POST endpoint: `https://api.infosimples.com/api/v2/consultas/detran/sp/debitos`



| Parameter     | Description                                                                                                                                                                                                                                                               |
| ------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| token*        | The token that will authenticate and authorize the request.                                                                                                                                                                                                               |
| login_cpf**   | Deve ser informado o CPF para fazer login no GOV.BR.                                                                                                                                                                                                                      |
| login_senha** | Deve ser informada a senha para fazer login no GOV.BR.                                                                                                                                                                                                                    |
| pkcs12_cert** | Este parâmetro é necessário caso o login no GOV.BR seja feito com certificado digital. Conteúdo do arquivo do certificado digital A1 encriptado seguindo <a href="http://api.infosimples.com/consultas/docs/certificados#criptografia">as instruções de criptografia</a>. |
| pkcs12_pass** | Este parâmetro é necessário caso o login no GOV.BR seja feito com certificado digital. Senha do certificado digital A1 encriptada seguindo <a href="http://api.infosimples.com/consultas/docs/certificados#criptografia">as instruções de criptografia</a>.               |
| placa*        | License plate of the vehicle to be queried.                                                                                                                                                                                                                               |
| renavam*      | RENAVAM of the vehicle to be queried.                                                                                                                                                                                                                                     |

> * Required parameter.

> ** Optional parameter. Sometimes it is necessary to set at least one of the optional parameters for the service to work properly.


### Response examples (OK)
```json
{
  "code": 200,
  "code_message": "A requisição foi processada com sucesso.",
  "errors": [],
  "header": {
    "api_version": "v2",
    "api_version_full": "2.2.37-20260522144947",
    "product": "Consultas",
    "service": "detran/sp/debitos",
    "parameters": {
      "login_cpf_md5": "e379c59a3573be16480533ae3f53ea1b",
      "login_senha_md5": "e379c59a3573be16480533ae3f53ea1b",
      "placa": "AAA1111",
      "renavam": "1111111111"
    },
    "client_name": "Minha Empresa",
    "token_name": "Token de Produção",
    "billable": true,
    "price": "0.26",
    "requested_at": "2026-05-25T08:28:43.000-03:00",
    "elapsed_time_in_milliseconds": 273,
    "remote_ip": "111.111.111.111",
    "signature": "f5kOdbV9UHpl6YkYvHWHwdvyP8aN21RZ74W+nGnzqI0yihg9r5lIEKLaUB/Trc52ZZbIZ7C4BKiHPp3PBpksK+vPgIds6B3/baP+0Q=="
  },
  "data_count": 1,
  "data": [
    {
      "ano_fabricacao": "2018",
      "ano_modelo": "2019",
      "bloqueio_furto": "Nada consta",
      "carroceria": "JIPE",
      "categoria": "PARTICULAR",
      "chassi": "1AA11111AA1111111",
      "combustivel": "ALCOOL/GASOLINA",
      "cor": "BRANCA",
      "debitos_ipva": [
        {
          "exercicio": "2026",
          "data_vencimento": "11/11/1111",
          "valor": 1160.07,
          "cota": "8",
          "nome_cota": "Pagamento Parcelado"
        },
        {
          "exercicio": "2026",
          "data_vencimento": "11/11/1111",
          "valor": 1160.07,
          "cota": "3",
          "nome_cota": "Pagamento Parcelado"
        }
      ],
      "debitos_licenciamento": [
        {
          "exercicio": "2026",
          "data_vencimento": "11/11/1111",
          "valor": 174.08
        }
      ],
      "debitos_multas": [
        {
          "auto_infracao": "ABC1111111",
          "data_infracao": "11/11/1111",
          "hora_infracao": "23:53:00",
          "data_vencimento": "11/11/1111",
          "valor": 203.62,
          "descricao": "Exemplo de descrição",
          "local": "Avenida Paulista, 1636",
          "municipio": "SAO PAULO / SP",
          "orgao_autuador": {
            "codigo": "111",
            "nome": "Exemplo de Nome"
          }
        }
      ],
      "debitos_renainf": [],
      "especie": "Exemplo de espécie",
      "inspecao_gnv": "",
      "inspecao_veicular_ano": "21/11/2022",
      "ipva": "1160.07",
      "ipva_mensagem": "",
      "licenciamento_digital": {
        "acesso_permitido": "",
        "motivo": null
      },
      "licenciamento_mensagem": "",
      "licenciamento_valor": 174.08,
      "marca_modelo": "FIAT/MOBI LIKE",
      "multas_mensagem": "",
      "multas_total": "203.62",
      "municipio": "SAO PAULO / SP",
      "normalizado_ipva": 1160.07,
      "normalizado_multas_total": 203.62,
      "normalizado_placa": "AAA1111",
      "normalizado_renavam": "1111111111",
      "placa": "AAA1111",
      "registro_guincho": "Nada consta",
      "renainf_mensagem": "",
      "renavam": "1111111111",
      "restricao_administrativa": "Nada consta",
      "restricao_financeira": "",
      "restricao_judiciaria": "Não Consta Bloqueio Judicial - Renajud",
      "restricao_tributaria": "Nada consta",
      "status_licenciamento": "",
      "tipo": "AUTOMÓVEL",
      "ultimo_licenciamento": "exercicio 2025",
      "valor_debitos": 0.0,
      "vistorias": [
        {
          "data": "11/11/2011",
          "km": "61957 km"
        }
      ],
      "site_receipt": "https://www.exemplo.com/exemplo-de-url"
    }
  ],
  "site_receipts": [
    "https://www.exemplo.com/exemplo-de-url"
  ]
}
```


### Preview file

The preview file (`site_receipts`) in the response JSON may be **synthesized by Infosimples** using data from the source (website/app) that processed the automation if the file generated by the source is not suitable for viewing.

### Code snippets


#### Python
```python
# Tested with: Python 3.10.19, Python 3.14.0
import requests
import base64
# pip install aes-bridge
import aes_bridge

url = 'https://api.infosimples.com/api/v2/consultas/detran/sp/debitos'
args = {
  "login_cpf":   "VALUE_OF_PARAMETER_LOGIN_CPF",
  "login_senha": "VALUE_OF_PARAMETER_LOGIN_SENHA",
  "pkcs12_cert": aes_bridge.encrypt(base64.b64encode(open("certificate.pfx", "rb").read()).decode(), "ENCRYPTION_KEY").decode("ascii").replace("+", "-").replace("/", "_").rstrip("="),
  "pkcs12_pass": aes_bridge.encrypt("CERTIFICATE_PASSWORD", "ENCRYPTION_KEY").decode("ascii").replace("+", "-").replace("/", "_").rstrip("="),
  "placa":       "VALUE_OF_PARAMETER_PLACA",
  "renavam":     "VALUE_OF_PARAMETER_RENAVAM",
  "token":       "WRITE_YOUR_TOKEN_HERE",
  "timeout":     "300"
}

response = requests.post(url, args)
response_json = response.json()
response.close()

if response_json['code'] == 200:
  print("Retorno com sucesso: ", response_json['data'])
elif response_json['code'] in range(600, 799):
  mensagem = "Resultado sem sucesso. Leia para saber mais: \n"
  mensagem += "Código: {} ({})\n".format(response_json['code'], response_json['code_message'])
  mensagem += "; ".join(response_json['errors'])
  print(mensagem)

print("Cabeçalho da consulta: ", response_json['header'])
print("URLs com arquivos de visualização (HTML/PDF): ", response_json['site_receipts'])
```


## We are here to help
Do you still need to figure something out? Reach us at [suporte@infosimples.com.br](mailto:suporte@infosimples.com.br) and our highly qualified support team will be happy to help.
