status状态码 | message描述信息 | 注释 |
---|---|---|
0 | 成功 | 请求成功 |
1 | 服务器内部错误 | 请求成功 |
2 | 参数错误 | 具体错误信息将在 message 中给出 |
3 | http method错误 | 检查请求的 http method(get/post)是否与接口描述一致 |
3003 | 指定 entity 不存在 | 未查询到 entity_name 为设定值的 entity,请检查 entity_name 是否输入错误或已被删除 |
3005 | entity_name已存在 | entity_name 是 entity 的唯一标识,在同一 service 中不可创建 entity_name 重复的 entity,请更换名字后再次尝试 |
3006 | 查询时间段内的轨迹点过多,无法进行纠偏,请缩短查询时间 | entity_name不符合命名规范:仅支持中文、英文大小字母、英文下划线"_"、英文横线"-"和数字。 |
3007 | 数据解析失败,数据中包含非utf8编码字符 | 返回的字段值中存在非 utf8编码的字符。所有上传的字符均应以 utf8 编码 |
4005 | 指定service_id不存在 | 请求参数中service_id填写错误或不属于当前账号,请检查是否填写了正确的service_id |
5101 | 监控对象的围栏个数超出范围,最多100个 | 一个监控对象最多可创建100个围栏,建议定期清理无效围栏 |
5102 | 监控对象不存在 | 创建或更新围栏时,指定的监控对象 entity_name 不存在 |
5103 | 监控对象上没有fence_id为xxx的围栏 | |
5104 | 指定fence_id不存在 | |
9001 | 查询时间段内的轨迹点过多,无法进行轨迹分析,请缩短查询时间 | 一次请求查询的轨迹点不可超过两万,否则将返回失败 |
api请求中需要用到中文或一些特殊字符的参数,如query、region等,为了避免提交到后台乱码,需要对这几个参数值进行编码处理,转换成utf-8字符的二字符十六进制值,凡是不在下表中的字符都需要进行编码。
字符集合 | 字符 |
---|---|
url非保留字 | a b c d e f g h i j k l m n o p q r s t u v w x y z a b c d e f g h i j k l m n o p q r s t u v w x y z 0 1 2 3 4 5 6 7 8 9 - _ . ~ |
url保留字 | ! * ' ( ) ; : @ & = $ , / ? % # [ ] |
如果中文参数中使用url保留字字符的字面意思,例如:region关键字取值为"?北京",检索关键字包含一个问号,此问号也必须进行编码。
javascript中一般采用encodeuricomponent函数对特殊字符进行编码。
java中可以使用函数urlencoder.encode对特殊字符进行编码。
c#中可以使用函数httputility.urlencode对特殊字符进行编码。
php中可以使用函数urlencode对特殊字符进行编码。
假设ak=yourak(yourak为一个字符串),
在 中配置了该ak的验证方式是sn签名的验证方式,点击下面那排星号,显示security key,可以看到此ak对应的sk私钥,假设sk=yoursk。
请求的url是:
package test;import java.io.unsupportedencodingexception;import java.net.urlencoder;import java.security.nosuchalgorithmexception;import java.util.linkedhashmap;import java.util.map;import java.util.map.entry;//java版计算signature签名publicclasssncal{publicstaticvoidmain(string[] args) throws unsupportedencodingexception,nosuchalgorithmexception{sncal sncal =newsncal();// 计算sn跟参数对出现顺序有关,get请求请使用linkedhashmap保存,该方法根据key的插入顺序排序;post请使用treemap保存 ,该方法会自动将key按照字母a-z顺序排序。所以get请求可自定义参数顺序(sn参数必须在最后)发送请求,但是post请求必须按照字母a-z顺序填充body(sn参数必须在最后)。以get请求为例:https://api.map.baidu.com/geocoder/v2/?address=百度大厦&output=json&ak=yourak,paramsmap中先放入address,再放output,然后放ak,放入顺序必须跟get请求中对应参数的出现顺序保持一致。 map paramsmap =newlinkedhashmap<string,string>();paramsmap.put("address","百度大厦");paramsmap.put("output","json");paramsmap.put("ak","yourak");// 调用下面的toquerystring方法,对linkedhashmap内所有value作utf8编码,拼接返回结果address=百度大厦&output=json&ak=yourakstring paramsstr = sncal.toquerystring(paramsmap);// 对paramsstr前面拼接上/geocoder/v2/?,后面直接拼接yoursk得到/geocoder/v2/?address=百度大厦&output=json&ak=yourakyourskstring wholestr =newstring("/geocoder/v2/?" paramsstr "yoursk");// 对上面wholestr再作utf8编码string tempstr =urlencoder.encode(wholestr,"utf-8");// 调用下面的md5方法得到最后的sn签名7de5a22212ffaa9e326444c75a58f9a0system.out.println(sncal.md5(tempstr));}// 对map内所有value作utf8编码,拼接返回结果publicstringtoquerystring(map<?,?> data)throws unsupportedencodingexception{stringbuffer querystring =newstringbuffer();for(entry<?,?> pair : data.entryset()){querystring.append(pair.getkey()"=");querystring.append(urlencoder.encode((string) pair.getvalue(),"utf-8")"&");}if(querystring.length()>0){querystring.deletecharat(querystring.length()-1);}return querystring.tostring();}// 来自stackoverflow的md5计算方法,调用了messagedigest库函数,并把byte数组结果转换成16进制publicstringmd5(string md5){try{java.security.messagedigest md = java.security.messagedigest.getinstance("md5");byte[] array = md.digest(md5.getbytes());stringbuffer sb =newstringbuffer();for(int i =0; i < array.length;i){sb.append(integer.tohexstring((array[i]&0xff)|0x100).substring(1,3));}return sb.tostring();}catch(java.security.nosuchalgorithmexception e){}returnnull;}}
上一篇
下一篇
本篇文章对您是否有帮助?