前言
公司购买了某IOT平台的硬件,数据 会上传到对方平台可以查询,但是如果需要对接数据需要付费API,试了下自己可以抓取web页面的接口,但是发现返回的JSON数据是经过转义的(估计是防止白嫖) 记录下数据处理过程
一、数据格式
下面是获取到的接口数据,发现是个JSON字符串但是转义了
以下是接口返回的数据 被""括起来了。然后里面还有一层Data也是一个转义后的JSON字符串
"{
\"IsSuccess\":true,\"Token\":\"eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.1111.cnk_nAigUNBRb6RFLgzo9Gk3XAC1EoPqblCVIQPva6Q\",\"ErrorCode\":\"\",\"ErrorMsg\":\"\",\"Data\":\"{
\\r\\n \\\"list\\\": [],\\r\\n \\\"index\\\": 1,\\r\\n \\\"count\\\": 0,\\r\\n \\\"pageCount\\\": 0\\r\\n}\"}"
二、解决方法
先尝试了用Java处理但是因为镶套了多层JSON的转移,json去掉字符串不太好判断,
最后采用Java里面 JS处理数据解决,这里采用了hutool快速处理解析成功JSON数据,成功白嫖API
public class TestApi {
public static void main(String[] args) {
String body = "请求参数";
HttpResponse authorization = HttpRequest.post("http://xxxxxx/api/Monitor/PageForWaterRawData")
.header("Content-Type", "application/json")
.header("Authorization", "Bearer " + "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VySWQiOiIxNzc4MiIsIlBJRCI6IjEwMTIwIiwiTGFuZyI6ImNuIiwiUlR5cGUiOiJzdHJpbmciLCJDbGllbnQiOiIxIiwiZXhwIjoxNzA5MDE2NDA0fQ.1GFj1X4QAZRJQB_3UXajdnu_4hMFBU2MPLdOHCSnOZE")
.body(body).execute();
String bodyInfo = authorization.body();
JSONObject jsonObject = jsonParse(bodyInfo);
System.out.println(jsonObject);
JSONObject obj = JSONUtil.parseObj(jsonObject.getStr("Data"));
System.out.println(obj);
}
/**
* 用js的JSON.parse()方法解析字符串
*/
private static JSONObject jsonParse(String bodyInfo) {
//因为js不区分单双引号 可以直接JSON.parse了
String script = "JSON.parse(" + bodyInfo + ")";
// 执行js脚本
Object eval = ScriptUtil.eval(script);
return JSONUtil.parseObj(eval);
}
}