价格: 22.00-42.00元
接口地址: https://登录后显示/pyi/170/379(支持:http/https)
返回格式:json,xml,jsonp调用
请求方式:GET,POST
POST 请求需要设置Header头:Content-Type: application/x-www-form-urlencoded;charset=utf-8
Api测试工具请求说明:
名称 | 必填 | 类型 | 说明 | 示例 参数另存 |
---|---|---|---|---|
appid | 是 | String | 应用ID,在后台我的应用查看或者添加 | 1 |
car_request_id | 是 | String | 提交维保时返回的request_id | 9d10df45964fd60941aaf0f59d4b80c2 |
format | 否 | String | 返回数据格式类型,每个接口已经说明支持返回格式:json,xml, jsonp调用方法说明 | json |
sign | 是 | String | 1.使用Md5方式验证,参数按一定规则md5后返回的字符串,详情点击这里阅读 2.使用Hash验证方式,直接跟上密钥即可。如何设置hash验证 通过我的应用里面修改验证方式 |
52a32be274a5c537bbf7a53e2d66c09f |
Md5验证方式-加密顺序
返回参数说明:
名称 | 必填 | 类型 | 说明 | 示例 参数另存 |
---|---|---|---|---|
appearance_is_repair | 否 | Integer | 外观件是否有维修(1是, 2否,0没有这项) | 0 |
brand_id | 是 | Integer | 品牌id | 76 |
car_is_fire | 否 | Integer | 是否火烧(1是, 2否,0没有这项) | 0 |
car_is_water | 否 | Integer | 是否泡水(1是, 2否,0没有这项) | 0 |
car_no | 是 | String | 查询的车牌号,必须大写 | |
codeid | 否 | Integer | 状态码,返回10000状态都会进行计费。具体说明可查看状态码说明 | 10000 |
content | 否 | String | 2014 BMW秋季活动免费检测 | |
engine_no | 否 | String | 发动机号 | |
important_parts_is_repair | 否 | Integer | 重要部件是否维修(1是, 2否,0没有这项) | 0 |
kilomete | 否 | String | 维保公里数 | 74537 |
kilomete_is_normal | 否 | Integer | 公里数是否正常(1正常, 2不正常,0没有这项) | 0 |
last_kilometer | 否 | String | 最后公里数 | 107653 |
last_maintain_time | 否 | Integer | 最后保养时间 | 1436457600 |
last_repair_time | 否 | Integer | 最后维修时间 | 1436457600 |
last_to_shop_time | 否 | Integer | 最后到店时间 | 1436457600 |
maintain_dateline | 否 | Integer | 维保时间戳 | 1411228800 |
maintain_type | 否 | String | 维保类型 | 内部结算 |
message | 否 | String | 请求状态说明 | 查询成功 |
meterial | 否 | String | 维保材料 | |
query_id | 否 | String | 12f6635c7d2b62355f7d557aada3fd9b | |
result | 否 | Array | 查询结果列表 | |
result_status | 否 | String | 查询状态(1成功, 2查询中, 3失败) | 1 |
retdata | 否 | Array | 回数据集合,可能是数据、对象或者字符串 | |
structure_is_repair | 否 | Integer | 结构件是否有维修(1是, 2否) | 0 |
time | 否 | String | 请求时传递的当前服务器时间戳 | 1705376892 |
vin | 否 | String | 车架号(vin) | LS5A2DKRXPA011111 |
vin_sub | 否 | String | VIN前缀 | LS5 |
JSON返回示例:
服务器状态码:
状态码 | 说明 |
---|---|
10000 | 返回成功 |
10001 | appid必须指定,可以我的应用里面查看 |
10002 | sign值必须指定,加密规则请前往帮助中心查看 |
10003 | sign值验证不通过,加密规则请前往帮助中心查看 |
10004 | 时差不能超过10分钟,可以不传递这个参数,注意时间戳单位是秒 |
10005 | appid错误,请检查appid值,前往会员中心->我的应用查看或添加 |
10006 | 当前IP地址未授权,请前往用户中心->我的应用添加ip{@info} |
10007 | 应用被禁用,请联系客服处理 |
10008 | 应用内没有该接口,请到我的应用里面添加这个接口 |
10009 | api接口不存在 |
10010 | 您没有添加该api接口 |
10011 | api已经到期 |
10012 | 没有订购任何api,请前往购买后再操作 |
10013 | 该接口已经暂停使用 |
10014 | 未知的错误,可以联系客服处理 |
10015 | 参数个数错误 |
10019 | {@info} |
10017 | time必须是整型 |
10018 | 次数不足 |
10020 | 子接口不存在,可能已经被关闭 |
10021 | 服务器发生错误 |
10022 | 帐户余额不足,请充值! |
10023 | 订单提交成功,等待回调结果 |
10024 | 调试模式数据 |
10025 | 查无数据 |
请选择开发语言:
$method = 'GET'; //请求方式 GET,POST $secretType = 'MD5'; //验证方式MD5,Hash 通过后台 我的应用去修改 $api_url = 'https://登录后显示/pyi/170/379'; $appid = '应用id';// 在后台我的应用查看; $secret = '应用密钥';// 在后台我的应用查看; $data = array( 'appid'=> '1', 'car_request_id'=> '9d10df45964fd60941aaf0f59d4b80c2', 'format'=> 'json', ); $data['appid'] = $appid; $data['time'] = time();//当前服务器时间 if('MD5' == $secretType){ ksort($data); //按照键名对数组排序,为数组值保留原来的键。 $md5String = ''; foreach($data as $key=>$val){ if(strlen($val)>0){ //过滤空值 $md5String.=$key.$val; } } $secret = md5($md5String.$secret); } $data['sign'] = $secret; if('GET'==$method){ $sendUrl = $api_url.'?'.http_build_query($data); //把数据转换成url参数形式,a=b&c=d&e=f $result = file_get_contents($sendUrl); }else{ $header = ['Content-Type: application/x-www-form-urlencoded;charset=utf-8']; $ch = curl_init(); if(is_array($data))$data = http_build_query($data); curl_setopt($ch, CURLOPT_URL, $api_url); curl_setopt($ch, CURLOPT_HTTPHEADER, $header); curl_setopt($ch, CURLOPT_POST, true);//POST curl_setopt($ch, CURLOPT_POSTFIELDS, $data); curl_setopt($ch, CURLOPT_AUTOREFERER, true); curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE); curl_setopt($ch, CURLOPT_ENCODING,'gzip,deflate'); $result = curl_exec($ch); } $result = json_decode($result,true); print_r($result);
#!/usr/bin/python3 # -*- coding: UTF-8 -*- #该代码为python3.7示例代码 import ssl,time,hashlib,string from urllib import request,parse,error; from urllib.parse import quote api_url = 'https://登录后显示/pyi/170/379'; appid = '应用id';#在后台我的应用查看; secret = '应用密钥';#在后台我的应用查看; data = { 'appid':'1', 'car_request_id':'9d10df45964fd60941aaf0f59d4b80c2', 'format':'json', }; data['appid'] = appid; data['time'] = round(time.time());#当前服务器时间 keysArr = list(data.keys()) #取出字典key keysArr.sort()#对字典key进行排序 md5String = ''; params = [] for key in keysArr: if data[key]: val = str(data[key]) md5String+=key+val params.append(key + "=" + val ) md5String += secret; m = hashlib.md5() b = md5String.encode(encoding='utf-8') m.update(b) sign = m.hexdigest() params.append('sign='+sign)#加入计算后的sign值去请求 params = '&'.join(tuple(params)); #把列表转成元组后用&分隔,最终转换成字符串 a=b&c=d&e=f ssl._create_default_https_context = ssl._create_unverified_context url = api_url+'?'+params; url = quote(url, safe=string.printable) req = request.Request(url) opener = request.build_opener() r = opener.open(fullurl=req) doc = r.read(); print(doc.decode('utf-8'))