1.           在不知道你要转的对象的类型的时候,用com.alibaba.fastjson.JSON.parse();

       Object parse = com.alibaba.fastjson.JSON.parse(response);
            System.out.println("parse的类型::::::"+parse.getClass());

2.    如果对象为list数组类型[], 用com.alibaba.fastjson.JSON.parseArray();
            com.alibaba.fastjson.JSONArray parseArray = com.alibaba.fastjson.JSON.parseArray(response);

下面出示一段代码:

package com.awspaas.user.apps.hh500.job;

import java.util.List;
import java.util.Map; import net.sf.json.JSONArray; import org.json.JSONException;
import org.quartz.Job;
import org.quartz.JobExecutionContext; import com.actionsoft.bpms.bo.engine.BO;
import com.actionsoft.bpms.server.UserContext;
import com.actionsoft.bpms.util.DBSql;
import com.actionsoft.bpms.util.UtilString;
import com.actionsoft.sdk.local.SDK;
import com.awspaas.user.apps.hh500.util.WebService; public class SwanInterfaceJob implements Job {
private static WebService webService = null; @Override
public void execute(JobExecutionContext jec) {
try {
getTestDataUser();
getTestDataKpi();
} catch (JSONException e) {
e.printStackTrace();
}
} @SuppressWarnings("unchecked")
public String getTestDataUser() throws JSONException {
String URL = "http://192.168.1.240:8080/honghu/synchronizInterfaceController.do?getOrg";
webService = new WebService();
Map<String, Object> userData = webService.request(URL, "{\"mainData\": \"测试组织架构\"}");
JSONArray jsonArray = null;
if (!UtilString.isEmpty(userData.get("response"))) {
DBSql.update("DELETE FROM BO_EU_ORG_INTERFACE");
String response = userData.get("response").toString(); Object parse = com.alibaba.fastjson.JSON.parse(response);
System.out.println("parse的类型::::::"+parse.getClass());
System.out.println(parse); // com.alibaba.fastjson.JSONArray parseArray = com.alibaba.fastjson.JSON.parseArray(response);
// System.out.println("||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||"+parseArray);
jsonArray = JSONArray.fromObject(parse.toString());
List<Map<String, Object>> aList = (List<Map<String, Object>>) jsonArray;
List<BO> bos = new java.util.ArrayList<BO>();
BO bo = null;
for (Map<String, Object> RowJson4 : aList) {
if (RowJson4.get("userMap") != null) {
Map<String, Object> map = (Map<String, Object>) RowJson4.get("userMap");
if (map.get("id") != null) {
for (Map<String, Object> RowJson3 : aList) {
if (RowJson3.get("orgType").toString().equals("3") && RowJson4.get("pId").toString().equals(RowJson3.get("id"))) {
for (Map<String, Object> RowJson2 : aList) {
if (RowJson2.get("orgType").toString().equals("2") && RowJson3.get("pId").toString().equals(RowJson2.get("id"))) {
for (Map<String, Object> RowJson1 : aList) {
if (RowJson1.get("orgType").toString().equals("1") && RowJson2.get("pId").toString().equals(RowJson1.get("id"))) {
bo = new BO();
bo.set("COMPANY_ID", RowJson1.get("id"));// 公司ID
bo.set("COMPANY_NAME", RowJson1.get("name"));// 公司
bo.set("DEPT_ID", RowJson2.get("id"));// 部门ID
bo.set("DEPT_NAME", RowJson2.get("name"));//
bo.set("POST_ID", RowJson4.get("id"));// 岗位ID
bo.set("POST_NAME", RowJson4.get("name"));//
bo.set("USER_ID", map.get("empNo"));// 人员账号
bo.set("USER_NAME", map.get("name"));
bos.add(bo);
}
}
}
}
}
}
}
}
}
System.out.println(bos);
if (bos != null && bos.size() > 0) {
SDK.getBOAPI().createDataBO("BO_EU_ORG_INTERFACE", bos, UserContext.fromUID("admin"));
}
}
return jsonArray.toString();
} @SuppressWarnings("unchecked")
public void getTestDataKpi() throws JSONException {
String URL = "http://192.168.1.240:8080/honghu/synchronizInterfaceController.do?getKpi";
net.sf.json.JSONArray jsonArray = null;
webService = new WebService();
Map<String, Object> userData = webService.request(URL, "{\"mainData\": \"测试指标\"}");
List<BO> bos = new java.util.ArrayList<BO>();
if (!UtilString.isEmpty(userData.get("response"))) {
DBSql.update("DELETE FROM BO_EU_WEIGHT_INTERFACE");
String response = userData.get("response").toString();
Object parse = com.alibaba.fastjson.JSON.parse(response);
System.out.println("parse的类型::::::"+parse.getClass());
System.out.println(parse);
jsonArray = net.sf.json.JSONArray.fromObject(parse);
System.out.println(jsonArray);
List<Map<String, Object>> aList = (List<Map<String, Object>>) jsonArray;
BO bo = null;
for (Map<String, Object> RowJson4 : aList)
if ((!UtilString.isEmpty(RowJson4.get("type"))) && RowJson4.get("type").toString().equals("4")) {
for (Map<String, Object> RowJson3 : aList) {
if ((!UtilString.isEmpty(RowJson3.get("type"))) && RowJson3.get("type").toString().equals("3")
&& RowJson4.get("parentId").toString().equals(RowJson3.get("id"))) {
for (Map<String, Object> RowJson2 : aList) {
if ((!UtilString.isEmpty(RowJson2.get("type"))) && RowJson2.get("type").toString().equals("2")
&& RowJson3.get("parentId").toString().equals(RowJson2.get("id"))) {
for (Map<String, Object> RowJson1 : aList) {
if ((!UtilString.isEmpty(RowJson1.get("type"))) && RowJson1.get("type").toString().equals("1")
&& RowJson2.get("parentId").toString().equals(RowJson1.get("id"))) {
bo = new BO();
bo.set("WID", RowJson4.get("id"));// 指标ID
// bo.set("FIRSTTYPE", RowJson1.get("firstType"));//一级指标
bo.set("FIRSTTYPE", RowJson1.get("projectName"));// 一级指标
bo.set("FIRST_CODE", RowJson1.get("projectCode"));
// bo.set("MAXTYPE", RowJson2.get("maxType"));//二级指标
bo.set("MAXTYPE", RowJson2.get("projectName"));// 二级指标
bo.set("MAXTCODE", RowJson2.get("projectCode"));
// bo.set("MINTYPE", RowJson3.get("minType"));//三级指标
bo.set("MINTYPE", RowJson3.get("projectName"));// 三级指标
bo.set("MINCODE", RowJson3.get("projectCode"));
bo.set("PROJECTNAME", RowJson4.get("projectName"));// 四级指标
bo.set("PROJECTCODE", RowJson4.get("projectCode"));
bo.set("NO", RowJson4.get("no"));// 排序序号
bo.set("REMAK", RowJson4.get("remak"));// 备注
bo.set("AFFILIATIONDPTNAME", RowJson4.get("affiliationDptName"));// 归属部门
bo.set("DUTYDPTNAME", RowJson4.get("dutyDptName"));// 责任部门
bos.add(bo);
}
}
}
}
}
}
}
}
System.out.println(bos);
if (bos != null && bos.size() > 0) {
SDK.getBOAPI().createDataBO("BO_EU_WEIGHT_INTERFACE", bos, UserContext.fromUID("admin"));
}
} }

Java中JSON之全的更多相关文章

  1. Java中JSON字符串与java对象的互换实例详解

    这篇文章主要介绍了在java中,JSON字符串与java对象的相互转换实例详解,非常不错,具有参考借鉴价值,需要的朋友可以参考下 在开发过程中,经常需要和别的系统交换数据,数据交换的格式有XML.JS ...

  2. java中 json和bean list map之间的互相转换总结

    JSON 与 对象 .集合 之间的转换 JSON字符串和java对象的互转[json-lib]   在开发过程中,经常需要和别的系统交换数据,数据交换的格式有XML.JSON等,JSON作为一个轻量级 ...

  3. (转)Java中JSON字符串与java对象的互换实例详解

    在开发过程中,经常需要和别的系统交换数据,数据交换的格式有XML.JSON等,JSON作为一个轻量级的数据格式比xml效率要高,XML需要很多的标签,这无疑占据了网络流量,JSON在这方面则做的很好, ...

  4. Java中JSON字符串与java对象的互换实例详解(转)

    http://www.jb51.net/article/90914.htm 在开发过程中,经常需要和别的系统交换数据,数据交换的格式有XML.JSON等,JSON作为一个轻量级的数据格式比xml效率要 ...

  5. Java中json的构造和解析

    什么是 Json? JSON(JvaScript Object Notation)(官网网站:http://www.json.org/)是 一种轻量级的数据交换格式.  易于人阅读和编写.同时也易于机 ...

  6. Java中json工具对比分析

    Java中几个json工具分析 1, 环境 JDK1.6+IDE(IntelliJ IDEA)+windowsXP+GBK编码 2,分析对象 jackson1.8.2 http://jackson.c ...

  7. java中json和字符串互转及日期转换 练习

    一:以下是用到的jar名称: commons-beanutils-1.6.jar commons-collections-3.2.1.jar commons-lang-2.6.jar commons- ...

  8. Java中 Json的使用

    转自:http://huyan.couplecoders.tech/%E5%BC%80%E5%8F%91%E8%80%85%E6%89%8B%E5%86%8C/2018/11/02/Java%E4%B ...

  9. java中json包的使用以及字符串,map,list,自定义对象之间的相互转换

    做一个map和字符串的转换,需要导入这些jar包,这是最基本的一些jar包. 经过多方尝试得出结论入下: 首先导入基本包:json-lib-2.2.3-jdk15.jar 如果没有这个jar包,程序是 ...

随机推荐

  1. java面试记录

    怎么确保一个集合不能被修改   ArrayList<String> list = new ArrayList<>();list.add("x");Colle ...

  2. log4j日志框架的使用

    java.util.logging.Logger——java 中提供的日志类 实际开发 90% 都是使用 log4j 记录日志,而 Log4j 底层就是 java.util.logging.Logge ...

  3. 升级SCCM 2012R2 SP1故障解决

    故障一: 上周7月5号进行升级sccm至2012 R2 SP1的操作,执行升级程序splash.hta,在最后核心程序安装步骤失败,关闭升级程序,打开SCCM控制台报错如下: Configuratio ...

  4. tomcat,httpd 日志格式说明

    tomcat 日志说明 配置文件server.xml 默认日志格式为 pattern="%h %l %u %t "%r" %s %b" 推荐使用 pattern ...

  5. SQL高级查询基础

    1.UNION,EXCEPT,INTERSECT运算符 A,UNION 运算符 UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表. ...

  6. Postgresql数据库部署之:Postgresql 存在session 会话不能删除数据库

    SELECT pg_terminate_backend(pid) FROM pg_stat_activity WHERE datname='数据库名' AND pid<>pg_backen ...

  7. Mysql--alter命令小特点

    以下命令均在mysql命令行下执行.1. 修改表名称有2种方法,mysql命令行,没有区分大小写,方法1:mysql>ALTER TABLE 表名l RENAME TO 表名2; 方法2:mys ...

  8. Windows -- 使用批处理文件.bat删除旧文件

    Windows  --  写一个批处理文件.bat删除旧文件 1. 批处理文件 del_old_file.bat rem 删除D:\temp目录下7天前的文件 Forfiles /p D:\temp ...

  9. 将Windows Server 2016 打造成工作站(20161030更新)

    将Windows Server 2016 打造成工作站(20161030更新) 一.基础设置 1.1.关闭自动弹窗:   「开始菜单」 - 「服务器管理器」 - 「仪表板」(或 Win + R或CMD ...

  10. Vue-cli在webpack内使用雪碧图(响应式)

    先执行install cnpm install webpack-spritesmith 文件位置 build\webpack.dev.conf.js 添加内容: const SpritesmithPl ...