Search in sources :

Example 6 with EvidenceMainInformationExample

use of com.itrus.portal.db.EvidenceMainInformationExample in project portal by ixinportal.

the class EvidenceSaveTask method saveFactor.

// 核验要素
private Map<String, Object> saveFactor(Map<String, Object> result, EvidenceSaveService evidenceSaveService, String evidenceSn, JSONObject jsonEvidenceContent, EvidenceBasicInformation basicInformation, RealNameAuthentication realNameAuthentication, RealNameAuthentication realNameAuthenticationOss, EvidenceServiceConfiguration serviceConfiguration, Boolean bl) throws Exception {
    try {
        List<Object> objs = new ArrayList<Object>();
        // 定义证据要素字段
        String saveFactor = null;
        // 证据存证的业务类型
        String type = null;
        String hapPrincipalName = null;
        // 定义主体身份
        // Map<String, EvidenceMainInformation> mapIdCache = new HashMap<String, EvidenceMainInformation>();
        // 得到业务基本信息要素配置
        String factorBusinessInfo = evidenceSaveService.getFactorBusinessInfo();
        JSONArray jsonBiArray = JSONArray.parseArray(factorBusinessInfo);
        // TODO : 核验事件认证
        if (jsonEvidenceContent.get("authEvent") != null) {
            // 可信身份缓存信息
            // List<EvidenceTrustedIdentity> tiCacheList = new ArrayList<>();
            JSONObject jsonAuthEvent = jsonEvidenceContent.getJSONObject("authEvent");
            // 判断是否为补交信息
            if (bl) {
                basicInformation.setEvidenceType(2);
                // 核验基础信息
                for (int i = 0; i < jsonBiArray.size(); i++) {
                    JSONObject object = jsonBiArray.getJSONObject(i);
                    String name = object.getString("name");
                    String content = jsonAuthEvent.getString(name);
                    JSONObject jsonContent;
                    switch(i) {
                        // 事件发生平台
                        case 0:
                            jsonContent = JSONObject.parseObject(content);
                            hapPrincipalName = jsonContent.getString("hapPrincipalName");
                            // 判断是否接收
                            if (object.getBooleanValue("b_isReception") && StringUtils.isEmpty(basicInformation.getCompanyName())) {
                                // 判断是否必填
                                if (bl && object.getBooleanValue("b_isRequired") && StringUtils.isEmpty(jsonContent.getString("hapPlatformDomain"))) {
                                    result.put("status", 0);
                                    result.put("message", "提交的参数信息不完整,缺少事件发生平台必要参数值");
                                    return result;
                                }
                                if (StringUtils.isEmpty(saveFactor) || !saveFactor.contains("基本信息"))
                                    saveFactor = EvidenceSaveServiceApi.mergeFactor(saveFactor, "基本信息");
                                basicInformation.setCompanyName(hapPrincipalName);
                                basicInformation.setEventPlatformName(jsonContent.getString("hapPlatformName"));
                                basicInformation.setDomainName(jsonContent.getString("hapPlatformDomain"));
                            }
                            break;
                        // 业务类型
                        case 1:
                            // 判断是否接收
                            if (object.getBooleanValue("b_isReception") && StringUtils.isEmpty(basicInformation.getType())) {
                                // 判断是否必填
                                if (bl && object.getBooleanValue("b_isRequired") && StringUtils.isEmpty(content)) {
                                    result.put("status", 0);
                                    result.put("message", "提交的参数信息不完整,缺少业务类型参数值");
                                    return result;
                                }
                                if (StringUtils.isEmpty(saveFactor) || !saveFactor.contains("基本信息"))
                                    saveFactor = EvidenceSaveServiceApi.mergeFactor(saveFactor, "基本信息");
                                basicInformation.setType(content);
                                type = object.getString("b_category");
                            }
                            break;
                        // 业务描述
                        case 2:
                            // 判断是否接收
                            if (object.getBooleanValue("b_isReception") && StringUtils.isEmpty(basicInformation.getDescription())) {
                                if (StringUtils.isEmpty(saveFactor) || !saveFactor.contains("基本信息"))
                                    saveFactor = EvidenceSaveServiceApi.mergeFactor(saveFactor, "基本信息");
                                basicInformation.setDescription(content);
                            }
                            break;
                        // 业务单号
                        case 3:
                            // 判断是否接收
                            if (object.getBooleanValue("b_isReception") && StringUtils.isEmpty(basicInformation.getServiceNumber())) {
                                if (StringUtils.isEmpty(saveFactor) || !saveFactor.contains("基本信息"))
                                    saveFactor = EvidenceSaveServiceApi.mergeFactor(saveFactor, "基本信息");
                                basicInformation.setServiceNumber(content);
                            }
                            break;
                    }
                }
            // if(basicInformation.getId() == null) {
            // // 存储证据基本信息
            // long beginTime = System.currentTimeMillis();//1、开始时间
            // sqlSession.insert("com.itrus.portal.db.EvidenceBasicInformationMapper.insert", basicInformation);
            // sqlSession.flushStatements();
            // log.error("证据表耗时:{}", System.currentTimeMillis() - beginTime);
            // } else {
            // sqlSession.update("com.itrus.portal.db.EvidenceBasicInformationMapper.updateByPrimaryKey", basicInformation);
            // sqlSession.flushStatements();
            // log.debug("Size : " + basicInformation.getEvidenceSize());
            // }
            } else {
                sqlSession.update("com.itrus.portal.db.EvidenceBasicInformationMapper.updateByPrimaryKey", basicInformation);
                sqlSession.flushStatements();
                // 核验基础信息
                for (int i = 0; i < jsonBiArray.size(); i++) {
                    JSONObject object = jsonBiArray.getJSONObject(i);
                    if (i == 1) {
                        type = object.getString("b_category");
                    }
                }
            }
            // 得到身份认证要素配置
            String factorIdVerify = evidenceSaveService.getFactorIdVerify();
            JSONArray jsonIdArray = JSONArray.parseArray(factorIdVerify);
            Map<String, Object> cacheSubjectIdentity = new HashMap<String, Object>();
            // 得到证据包中的事件认证数据中的事件对象认证
            for (int i = 0; i < jsonIdArray.size(); i++) {
                JSONObject object = jsonIdArray.getJSONObject(i);
                /**
                 ***********************************************     《合同摘要数据》和《图片摘要数据》, 《信息摘要数据》获取主体    start      *******************************************
                 */
                if ("合同摘要数据".equals(type) || "图片摘要数据".equals(type) || "信息摘要数据".equals(type)) {
                    // 得到事件包信息数据
                    JSONArray jsonContentArray = jsonAuthEvent.getJSONArray("principalId");
                    if (i == 0 && object.getBooleanValue("i_isReception")) {
                        // 循环主体
                        for (int j = 0; j < jsonContentArray.size(); j++) {
                            JSONObject jsonContent = jsonContentArray.getJSONObject(j);
                            // 判断是否必填
                            if (object.getBooleanValue("i_isRequired") && (StringUtils.isEmpty(jsonContent.getString("type")) || StringUtils.isEmpty(jsonContent.getString("name")) || StringUtils.isEmpty(jsonContent.getString("dataId")))) {
                                result.put("status", 0);
                                result.put("message", "提交的参数信息不完整,缺少主体身份参数值");
                                return result;
                            }
                            // 判断主体是否存在
                            // String idCacheKey = jsonContent.getString("name") + jsonContent.getString("dataId");
                            EvidenceMainInformation mainInformation = null;
                            // EvidenceBasicInformation basicInformation2 = null;
                            EvidenceMainInformationExample mainInformationExample = new EvidenceMainInformationExample();
                            EvidenceMainInformationExample.Criteria mainExampleCriteria = mainInformationExample.createCriteria();
                            mainExampleCriteria.andSubjectNameEqualTo(jsonContent.getString("name").trim());
                            mainExampleCriteria.andIdentificationEqualTo(jsonContent.getString("dataId").trim());
                            mainExampleCriteria.andMainTypeEqualTo(jsonContent.getString("type"));
                            List<EvidenceMainInformation> mainInformationList = sqlSession.selectList("com.itrus.portal.db.EvidenceMainInformationMapper.selectByExample", mainInformationExample);
                            if (!mainInformationList.isEmpty()) {
                                mainInformation = mainInformationList.get(0);
                            }
                            // 当主体为空时 添加主体信息
                            if (mainInformation == null) {
                                mainInformation = new EvidenceMainInformation();
                                mainInformation.setSubjectName(jsonContent.getString("name").trim());
                                mainInformation.setIdentification(jsonContent.getString("dataId").trim());
                                mainInformation.setMainType(jsonContent.getString("type"));
                                mainInformation.setCreateTime(new Date());
                                mainInformation.setId(basicInformation.getId());
                                // queueThread.putObjectQueue(mainInformation);
                                objs.add(mainInformation);
                            // queueThread.putMap(mainInformation.getSubjectName() + mainInformation.getIdentification());
                            }
                            // else {
                            // // 判断基础信息表 和 主体表是否存在关联
                            // EvidenceSubjectIdentityExample subjectIdentityExampleExist = new EvidenceSubjectIdentityExample();
                            // EvidenceSubjectIdentityExample.Criteria iece = subjectIdentityExampleExist.createCriteria();
                            // iece.andBasicInformationEqualTo(evidenceSn!=null?evidenceSn:genSn);
                            // iece.andMainInformationEqualTo(mainInformation.getIdentification());
                            // EvidenceSubjectIdentity subjectIdentityExist = sqlSession
                            // .selectOne("com.itrus.portal.db.EvidenceSubjectIdentityMapper.selectByExample", subjectIdentityExampleExist);
                            // if(subjectIdentityExist == null) {
                            // EvidenceSubjectIdentity subjectIdentity1 = new EvidenceSubjectIdentity();
                            // subjectIdentity1.setBasicInformation(evidenceSn!=null?evidenceSn:genSn);
                            // subjectIdentity1.setMainInformation(mainInformation.getIdentification());
                            // queueThread.putObjectQueue(subjectIdentity1);
                            // //        								sqlSession.insert("com.itrus.portal.db.EvidenceSubjectIdentityMapper.insert", subjectIdentity1);
                            // }
                            // }
                            String key = evidenceSn + jsonContent.getString("name").trim() + jsonContent.getString("dataId").trim();
                            if (cacheSubjectIdentity.get(key) == null) {
                                EvidenceSubjectIdentity subjectIdentity1 = new EvidenceSubjectIdentity();
                                subjectIdentity1.setBasicInformation(evidenceSn);
                                subjectIdentity1.setMainInformation(jsonContent.getString("dataId").trim());
                                subjectIdentity1.setMainName(jsonContent.getString("name").trim());
                                subjectIdentity1.setMainType(jsonContent.getShort("type"));
                                subjectIdentity1.setCreateTime(new Date());
                                // queueThread.putObjectQueue(subjectIdentity1);
                                objs.add(subjectIdentity1);
                                cacheSubjectIdentity.put(key, subjectIdentity1);
                            }
                            // 遍历 mapIdCache 的key值 判断是否存在   不存在则添加
                            // for(String key:mapIdCache.keySet()) {
                            // if(!idCacheKey.equals(key)) {
                            // mapIdCache.put(mainInformation.getSubjectName() + mainInformation.getIdentification(), mainInformation);
                            // }
                            // }
                            mainInformation = null;
                            mainInformationExample = null;
                        }
                    }
                }
            /**
             ***********************************************     《合同摘要数据》和《图片摘要数据》 , 《信息摘要数据》获取主体    end      *******************************************
             */
            }
            // 得到事件认证要素配置
            String factorEventVerify = evidenceSaveService.getFactorEventVerify();
            JSONArray jsonEvArray = JSONArray.parseArray(factorEventVerify);
            // 得到证据包中的事件认证数据中的事件对象认证
            // for(int i=0;i<jsonEvArray.size();i++) {
            // JSONObject object = jsonEvArray.getJSONObject(i);
            // // 可信身份标识
            // // 判断是否接收
            // if(i == 3 && object.getBooleanValue("e_isReception")) {
            // if("电子合同PDF".equals(type)) {
            // /*************************************************     《电子合同PDF》 获取事件发生主体    start      ********************************************/
            // // 得到事件包信息数据
            // JSONArray jsonContentArray = jsonAuthEvent.getJSONArray("event");
            // for(int j=0;j<jsonContentArray.size();j++) {
            // JSONObject jsonContent = jsonContentArray.getJSONObject(j).getJSONObject("idIdentify");
            // // 判断是否必填
            // if(object.getBooleanValue("e_isRequired") && (StringUtils.isEmpty(jsonContent.getString("type"))
            // ||  StringUtils.isEmpty(jsonContent.getString("certSn"))
            // ||  StringUtils.isEmpty(jsonContent.getString("name"))
            // ||  StringUtils.isEmpty(jsonContent.getString("dataId")))
            // ) {
            // result.put("status", 0);
            // result.put("message", "提交的参数信息不完整,缺少可信身份标识参数值");
            // return;
            // }
            // // 判断主体是否存在
            // String idCacheKey = jsonContent.getString("name") + jsonContent.getString("dataId");
            // EvidenceMainInformation mainInformation = null;
            // EvidenceBasicInformation basicInformation2 = null;
            // EvidenceMainInformationExample mainInformationExample = new EvidenceMainInformationExample();
            // EvidenceMainInformationExample.Criteria mainExampleCriteria = mainInformationExample.createCriteria();
            // mainExampleCriteria.andSubjectNameEqualTo(jsonContent.getString("name"));
            // mainExampleCriteria.andIdentificationEqualTo(jsonContent.getString("dataId"));
            // mainExampleCriteria.andMainTypeEqualTo(jsonContent.getString("type"));
            // List<EvidenceMainInformation> mainInformationList = sqlSession
            // .selectList("com.itrus.portal.db.EvidenceMainInformationMapper.selectByExample", mainInformationExample);
            // if(!mainInformationList.isEmpty()) {
            // mainInformation = mainInformationList.get(0);
            // }
            // // 当主体为空时 添加主体信息
            // if(mainInformation == null) {
            // mainInformation = new EvidenceMainInformation();
            // mainInformation.setSubjectName(jsonContent.getString("name"));
            // mainInformation.setIdentification(jsonContent.getString("dataId"));
            // mainInformation.setMainType(jsonContent.getString("type"));
            // mainInformation.setCreateTime(new Date());
            // sqlSession.insert("com.itrus.portal.db.EvidenceMainInformationMapper.insert", mainInformation);
            // sqlSession.flushStatements();
            // }
            // // 遍历 mapIdCache 的key值 判断是否存在   不存在则添加
            // for(String key:mapIdCache.keySet()) {
            // if(!idCacheKey.equals(key)) {
            // mapIdCache.put(mainInformation.getSubjectName() + mainInformation.getIdentification(), mainInformation);
            // }
            // }
            // // 判断基础信息表 和 主体表是否存在关联
            // EvidenceSubjectIdentityExample subjectIdentityExampleExist = new EvidenceSubjectIdentityExample();
            // EvidenceSubjectIdentityExample.Criteria iece = subjectIdentityExampleExist.createCriteria();
            // iece.andBasicInformationEqualTo(evidenceSn!=null?evidenceSn:genSn);
            // iece.andMainInformationEqualTo(mainInformation.getIdentification());
            // EvidenceSubjectIdentity subjectIdentityExist = sqlSession
            // .selectOne("com.itrus.portal.db.EvidenceSubjectIdentityMapper.selectByExample", subjectIdentityExampleExist);
            // if(subjectIdentityExist == null) {
            // EvidenceSubjectIdentity subjectIdentity1 = new EvidenceSubjectIdentity();
            // subjectIdentity1.setBasicInformation(evidenceSn!=null?evidenceSn:genSn);
            // subjectIdentity1.setMainInformation(mainInformation.getIdentification());
            // sqlSession.insert("com.itrus.portal.db.EvidenceSubjectIdentityMapper.insert", subjectIdentity1);
            // }
            // // 判断是否需要关联身份证据
            // if(StringUtils.isNotEmpty(jsonContent.getString("evidenceSn"))) {
            // basicInformation2 = informationServiceImpl.getInformationBySn(jsonContent.getString("evidenceSn"), 1);
            // if(basicInformation2 != null) {
            // EvidenceSubjectIdentityExample subjectIdentityExample = new EvidenceSubjectIdentityExample();
            // EvidenceSubjectIdentityExample.Criteria iec = subjectIdentityExample.createCriteria();
            // iec.andBasicInformationEqualTo(evidenceSn!=null?evidenceSn:genSn);
            // iec.andMainInformationEqualTo(mainInformation.getIdentification());
            // EvidenceSubjectIdentity subjectIdentity = sqlSession
            // .selectOne("com.itrus.portal.db.EvidenceSubjectIdentityMapper.selectByExample", subjectIdentityExample);
            // if(subjectIdentity == null) {
            // result.put("status", 0);
            // result.put("message", "证据编码:" + jsonContent.getString("evidenceSn") + "与主体:"
            // + jsonContent.getString("name") + "," + jsonContent.getString("dataId") + "不存在关联");
            // return;
            // }
            // } else {
            // result.put("status", 0);
            // result.put("message", "证据编码:" + jsonContent.getString("evidenceSn") + "与主体:"
            // + jsonContent.getString("name") + "," + jsonContent.getString("dataId") + "不存在关联");
            // return;
            // }
            // }
            // EvidenceTrustedIdentity trustedIdentity = new EvidenceTrustedIdentity();
            // // 判断是否为补交信息
            // if(!bl && jsonContent.getString("certSn") != null) {
            // EvidenceTrustedIdentityExample trustedIdentityExample = new EvidenceTrustedIdentityExample();
            // EvidenceTrustedIdentityExample.Criteria tec = trustedIdentityExample.createCriteria();
            // tec.andBasicInformationEqualTo(basicInformation.getId());
            // tec.andCertSerialnumberEqualTo(jsonContent.getString("certSn"));
            // List<EvidenceTrustedIdentity> trustedIdentities = sqlSession
            // .selectList("com.itrus.portal.db.EvidenceTrustedIdentityMapper.selectByExample", trustedIdentityExample);
            // // 补交主体后判断 事件对象不为空则修改事件对象关联的主体
            // if(!trustedIdentities.isEmpty()) {
            // EvidenceTrustedIdentity ti = trustedIdentities.get(0);
            // Long oldMainId = ti.getMainInformation();
            // ti.setMainInformation(mainInformation.getId());
            // sqlSession.update("com.itrus.portal.db.EvidenceTrustedIdentityMapper.updateByPrimaryKey", ti);
            // // 给可信身份赋值
            // trustedIdentity.setCertSerialnumber(ti.getCertSerialnumber());
            // trustedIdentity.setSubjectdn(ti.getSubjectdn());
            // trustedIdentity.setIssuerdn(ti.getIssuerdn());
            // trustedIdentity.setIssuer(ti.getIssuer());
            // trustedIdentity.setEvidenceBuf(ti.getEvidenceBuf());
            // trustedIdentity.setStartTime(ti.getStartTime());
            // trustedIdentity.setEndTime(ti.getEndTime());
            // // 修改事件时间关联的主体信息
            // EvidenceEventTimeExample timeExample = new EvidenceEventTimeExample();
            // EvidenceEventTimeExample.Criteria timeEc = timeExample.createCriteria();
            // timeEc.andMainInformationEqualTo(oldMainId);
            // timeEc.andEventContentEqualTo(ti.getEventContent());
            // List<EvidenceEventTime> times = sqlSession
            // .selectList("com.itrus.portal.db.EvidenceEventTimeMapper.selectByExample", timeExample);
            // for(EvidenceEventTime time:times) {
            // time.setMainInformation(mainInformation.getId());
            // sqlSession.update("com.itrus.portal.db.EvidenceEventTimeMapper.updateByPrimaryKey", time);
            // }
            // // 修改事件行为关联的主体信息
            // EvidenceEventBehaviorExample behaviorExample = new EvidenceEventBehaviorExample();
            // EvidenceEventBehaviorExample.Criteria behaviorEc = behaviorExample.createCriteria();
            // behaviorEc.andMainInformationEqualTo(oldMainId);
            // behaviorEc.andEventContentEqualTo(ti.getEventContent());
            // List<EvidenceEventBehavior> behaviors = sqlSession
            // .selectList("com.itrus.portal.db.EvidenceEventBehaviorMapper.selectByExample", behaviorExample);
            // for(EvidenceEventBehavior behavior:behaviors) {
            // behavior.setMainInformation(mainInformation.getId());
            // sqlSession.update("com.itrus.portal.db.EvidenceEventBehaviorMapper.updateByPrimaryKey", behavior);
            // }
            // sqlSession.flushStatements();
            // } else {
            // continue;
            // }
            // }
            // // 判断证据base64 字段是否为空
            // //								if(StringUtils.isNotEmpty(jsonContent.getString("certBase64"))) {
            // //									trustedIdentity.setCertBase64(jsonContent.getString("certBase64"));
            // //									// 解析证书Base64
            // //									UserCert userCert = CertUtil.getCertFromBase64(jsonContent.getString("certBase64"));
            // //									trustedIdentity.setCertSerialnumber(userCert.getCertSn());
            // //									trustedIdentity.setSubjectdn(userCert.getCertDn());
            // //									trustedIdentity.setIssuerdn(userCert.getIssuerDn());
            // //									trustedIdentity.setIssuer(EvidenceSaveServiceApi.getCertCn(userCert.getIssuerDn()));
            // //									if(userCert.getCertBuf() != null) {
            // //										trustedIdentity.setEvidenceBuf(userCert.getCertBuf().toString());
            // //									}
            // //									trustedIdentity.setStartTime(userCert.getCertStartTime());
            // //									trustedIdentity.setEndTime(userCert.getCertEndTime());
            // //								}
            // ////								trustedIdentity.setCertSerialnumber(jsonContent.getString("certSn"));
            // //								trustedIdentity.setIdentiType(jsonContent.getString("type"));
            // //								trustedIdentity.setBasicInformation(basicInformation.getId());
            // //								trustedIdentity.setEvidenceEnclosure(enclosure.getId());
            // //								if(StringUtils.isNotEmpty(jsonContent.getString("evidenceSn")))
            // //									trustedIdentity.setEvidenceSn(jsonContent.getString("evidenceSn"));
            // //								trustedIdentity.setCreateTime(new Date());
            // //								if(mainInformation != null && !"".equals(mainInformation))
            // //									trustedIdentity.setMainInformation(mainInformation.getId());
            // //								sqlSession.insert("com.itrus.portal.db.EvidenceTrustedIdentityMapper.insert", trustedIdentity);
            // //								sqlSession.flushStatements();
            // tiCacheList.add(trustedIdentity);
            // }
            // if(jsonContentArray.size() != 0) {
            // saveFactor = EvidenceSaveServiceApi.mergeFactor(saveFactor, object.getString("i_factor"));
            // }
            // }
            // /*************************************************     《电子合同PDF》 获取事件发生主体    end      ********************************************/
            // }
            // }
            // 得到事件包信息数据
            // JSONArray jsonContentArray = jsonAuthEvent.getJSONArray("event");
            // for(int j=0;j<jsonContentArray.size();j++) {
            // JSONObject jsonContent = jsonContentArray.getJSONObject(j).getJSONObject("idIdentify");
            // // 判断是否必填
            // if(object.getBooleanValue("i_isRequired") && ( StringUtils.isEmpty(jsonContent.getString("type"))
            // || (("1".equals(type) && StringUtils.isEmpty(jsonContent.getString("certSn")))
            // || (!"1".equals(type) && StringUtils.isEmpty(jsonContent.getString("certBase64")))))) {
            // result.put("status", 0);
            // result.put("message", "提交的参数信息不完整,缺少可信身份标识参数值");
            // return;
            // }
            // // 判断主体是否存在
            // String idCacheKey = jsonContent.getString("name") + jsonContent.getString("dataId");
            // EvidenceMainInformation mainInformation = null;
            // EvidenceBasicInformation basicInformation2 = null;
            // EvidenceMainInformationExample mainInformationExample = new EvidenceMainInformationExample();
            // EvidenceMainInformationExample.Criteria mainExampleCriteria = mainInformationExample.createCriteria();
            // mainExampleCriteria.andSubjectNameEqualTo(jsonContent.getString("name"));
            // mainExampleCriteria.andIdentificationEqualTo(jsonContent.getString("dataId"));
            // mainExampleCriteria.andMainTypeEqualTo(jsonContent.getString("type"));
            // List<EvidenceMainInformation> mainInformationList = sqlSession
            // .selectList("com.itrus.portal.db.EvidenceMainInformationMapper.selectByExample", mainInformationExample);
            // if(!mainInformationList.isEmpty()) {
            // mainInformation = mainInformationList.get(0);
            // }
            // // 当主体为空时 添加主体信息
            // if(mainInformation == null) {
            // mainInformation = new EvidenceMainInformation();
            // mainInformation.setSubjectName(jsonContent.getString("name"));
            // mainInformation.setIdentification(jsonContent.getString("dataId"));
            // mainInformation.setMainType(jsonContent.getString("type"));
            // mainInformation.setCreateTime(new Date());
            // sqlSession.insert("com.itrus.portal.db.EvidenceMainInformationMapper.insert", mainInformation);
            // sqlSession.flushStatements();
            // }
            // // 遍历 mapIdCache 的key值 判断是否存在   不存在则添加
            // for(String key:mapIdCache.keySet()) {
            // if(!idCacheKey.equals(key)) {
            // mapIdCache.put(mainInformation.getSubjectName() + mainInformation.getIdentification(), mainInformation);
            // }
            // }
            // // 判断基础信息表 和 主体表是否存在关联
            // EvidenceSubjectIdentityExample subjectIdentityExampleExist = new EvidenceSubjectIdentityExample();
            // EvidenceSubjectIdentityExample.Criteria iece = subjectIdentityExampleExist.createCriteria();
            // iece.andBasicInformationEqualTo(basicInformation.getId());
            // iece.andMainInformationEqualTo(mainInformation.getId());
            // EvidenceSubjectIdentity subjectIdentityExist = sqlSession
            // .selectOne("com.itrus.portal.db.EvidenceSubjectIdentityMapper.selectByExample", subjectIdentityExampleExist);
            // if(subjectIdentityExist == null) {
            // EvidenceSubjectIdentity subjectIdentity1 = new EvidenceSubjectIdentity();
            // subjectIdentity1.setBasicInformation(basicInformation.getId());
            // subjectIdentity1.setMainInformation(mainInformation.getId());
            // sqlSession.insert("com.itrus.portal.db.EvidenceSubjectIdentityMapper.insert", subjectIdentity1);
            // }
            // // 判断是否需要关联身份证据
            // if(StringUtils.isNotEmpty(jsonContent.getString("evidenceSn"))) {
            // basicInformation2 = informationServiceImpl.getInformationBySn(jsonContent.getString("evidenceSn"), 1);
            // if(basicInformation2 != null) {
            // EvidenceSubjectIdentityExample subjectIdentityExample = new EvidenceSubjectIdentityExample();
            // EvidenceSubjectIdentityExample.Criteria iec = subjectIdentityExample.createCriteria();
            // iec.andBasicInformationEqualTo(basicInformation2.getId());
            // iec.andMainInformationEqualTo(mainInformation.getId());
            // EvidenceSubjectIdentity subjectIdentity = sqlSession
            // .selectOne("com.itrus.portal.db.EvidenceSubjectIdentityMapper.selectByExample", subjectIdentityExample);
            // if(subjectIdentity == null) {
            // result.put("status", 0);
            // result.put("message", "证据编码:" + jsonContent.getString("evidenceSn") + "与主体:"
            // + jsonContent.getString("name") + "," + jsonContent.getString("dataId") + "不存在关联");
            // return;
            // }
            // } else {
            // result.put("status", 0);
            // result.put("message", "证据编码:" + jsonContent.getString("evidenceSn") + "与主体:"
            // + jsonContent.getString("name") + "," + jsonContent.getString("dataId") + "不存在关联");
            // return;
            // }
            // }
            // EvidenceTrustedIdentity trustedIdentity = new EvidenceTrustedIdentity();
            // // 判断是否为补交信息
            // if(!bl && jsonContent.getString("certSn") != null) {
            // EvidenceTrustedIdentityExample trustedIdentityExample = new EvidenceTrustedIdentityExample();
            // EvidenceTrustedIdentityExample.Criteria tec = trustedIdentityExample.createCriteria();
            // tec.andBasicInformationEqualTo(basicInformation.getId());
            // tec.andCertSerialnumberEqualTo(jsonContent.getString("certSn"));
            // List<EvidenceTrustedIdentity> trustedIdentities = sqlSession
            // .selectList("com.itrus.portal.db.EvidenceTrustedIdentityMapper.selectByExample", trustedIdentityExample);
            // // 补交主体后判断 事件对象不为空则修改事件对象关联的主体
            // if(!trustedIdentities.isEmpty()) {
            // EvidenceTrustedIdentity ti = trustedIdentities.get(0);
            // Long oldMainId = ti.getMainInformation();
            // ti.setMainInformation(mainInformation.getId());
            // sqlSession.update("com.itrus.portal.db.EvidenceTrustedIdentityMapper.updateByPrimaryKey", ti);
            // // 给可信身份赋值
            // trustedIdentity.setCertSerialnumber(ti.getCertSerialnumber());
            // trustedIdentity.setSubjectdn(ti.getSubjectdn());
            // trustedIdentity.setIssuerdn(ti.getIssuerdn());
            // trustedIdentity.setIssuer(ti.getIssuer());
            // trustedIdentity.setEvidenceBuf(ti.getEvidenceBuf());
            // trustedIdentity.setStartTime(ti.getStartTime());
            // trustedIdentity.setEndTime(ti.getEndTime());
            // // 修改事件时间关联的主体信息
            // EvidenceEventTimeExample timeExample = new EvidenceEventTimeExample();
            // EvidenceEventTimeExample.Criteria timeEc = timeExample.createCriteria();
            // timeEc.andMainInformationEqualTo(oldMainId);
            // timeEc.andEventContentEqualTo(ti.getEventContent());
            // List<EvidenceEventTime> times = sqlSession
            // .selectList("com.itrus.portal.db.EvidenceEventTimeMapper.selectByExample", timeExample);
            // for(EvidenceEventTime time:times) {
            // time.setMainInformation(mainInformation.getId());
            // sqlSession.update("com.itrus.portal.db.EvidenceEventTimeMapper.updateByPrimaryKey", time);
            // }
            // // 修改事件行为关联的主体信息
            // EvidenceEventBehaviorExample behaviorExample = new EvidenceEventBehaviorExample();
            // EvidenceEventBehaviorExample.Criteria behaviorEc = behaviorExample.createCriteria();
            // behaviorEc.andMainInformationEqualTo(oldMainId);
            // behaviorEc.andEventContentEqualTo(ti.getEventContent());
            // List<EvidenceEventBehavior> behaviors = sqlSession
            // .selectList("com.itrus.portal.db.EvidenceEventBehaviorMapper.selectByExample", behaviorExample);
            // for(EvidenceEventBehavior behavior:behaviors) {
            // behavior.setMainInformation(mainInformation.getId());
            // sqlSession.update("com.itrus.portal.db.EvidenceEventBehaviorMapper.updateByPrimaryKey", behavior);
            // }
            // sqlSession.flushStatements();
            // } else {
            // continue;
            // }
            // }
            // 
            // // 判断是否为电子合同
            // if("1".equals(type)) {
            // // 判断是否需要关联身份证据
            // if(StringUtils.isNotEmpty(jsonContent.getString("evidenceSn"))) {
            // basicInformation2 = informationServiceImpl.getInformationBySn(jsonContent.getString("evidenceSn"), 1);
            // if(basicInformation2 != null) {
            // EvidenceSubjectIdentityExample subjectIdentityExample = new EvidenceSubjectIdentityExample();
            // EvidenceSubjectIdentityExample.Criteria iec = subjectIdentityExample.createCriteria();
            // iec.andBasicInformationEqualTo(basicInformation2.getId());
            // iec.andMainInformationEqualTo(mainInformation.getId());
            // EvidenceSubjectIdentity subjectIdentity = sqlSession
            // .selectOne("com.itrus.portal.db.EvidenceSubjectIdentityMapper.selectByExample", subjectIdentityExample);
            // if(subjectIdentity == null) {
            // result.put("status", 0);
            // result.put("message", "证据编码:" + jsonContent.getString("evidenceSn") + "与主体:"
            // + jsonContent.getString("name") + "," + jsonContent.getString("dataId") + "不存在关联");
            // return;
            // }
            // } else {
            // result.put("status", 0);
            // result.put("message", "证据编码:" + jsonContent.getString("evidenceSn") + "与主体:"
            // + jsonContent.getString("name") + "," + jsonContent.getString("dataId") + "不存在关联");
            // return;
            // }
            // }
            // EvidenceTrustedIdentity trustedIdentity = new EvidenceTrustedIdentity();
            // // 判断是否为补交信息
            // if(!bl && jsonContent.getString("certSn") != null) {
            // EvidenceTrustedIdentityExample trustedIdentityExample = new EvidenceTrustedIdentityExample();
            // EvidenceTrustedIdentityExample.Criteria tec = trustedIdentityExample.createCriteria();
            // tec.andBasicInformationEqualTo(basicInformation.getId());
            // tec.andCertSerialnumberEqualTo(jsonContent.getString("certSn"));
            // List<EvidenceTrustedIdentity> trustedIdentities = sqlSession
            // .selectList("com.itrus.portal.db.EvidenceTrustedIdentityMapper.selectByExample", trustedIdentityExample);
            // // 补交主体后判断 事件对象不为空则修改事件对象关联的主体
            // if(!trustedIdentities.isEmpty()) {
            // EvidenceTrustedIdentity ti = trustedIdentities.get(0);
            // Long oldMainId = ti.getMainInformation();
            // ti.setMainInformation(mainInformation.getId());
            // sqlSession.update("com.itrus.portal.db.EvidenceTrustedIdentityMapper.updateByPrimaryKey", ti);
            // // 给可信身份赋值
            // trustedIdentity.setCertSerialnumber(ti.getCertSerialnumber());
            // trustedIdentity.setSubjectdn(ti.getSubjectdn());
            // trustedIdentity.setIssuerdn(ti.getIssuerdn());
            // trustedIdentity.setIssuer(ti.getIssuer());
            // trustedIdentity.setEvidenceBuf(ti.getEvidenceBuf());
            // trustedIdentity.setStartTime(ti.getStartTime());
            // trustedIdentity.setEndTime(ti.getEndTime());
            // // 修改事件时间关联的主体信息
            // EvidenceEventTimeExample timeExample = new EvidenceEventTimeExample();
            // EvidenceEventTimeExample.Criteria timeEc = timeExample.createCriteria();
            // timeEc.andMainInformationEqualTo(oldMainId);
            // timeEc.andEventContentEqualTo(ti.getEventContent());
            // List<EvidenceEventTime> times = sqlSession
            // .selectList("com.itrus.portal.db.EvidenceEventTimeMapper.selectByExample", timeExample);
            // for(EvidenceEventTime time:times) {
            // time.setMainInformation(mainInformation.getId());
            // sqlSession.update("com.itrus.portal.db.EvidenceEventTimeMapper.updateByPrimaryKey", time);
            // }
            // // 修改事件行为关联的主体信息
            // EvidenceEventBehaviorExample behaviorExample = new EvidenceEventBehaviorExample();
            // EvidenceEventBehaviorExample.Criteria behaviorEc = behaviorExample.createCriteria();
            // behaviorEc.andMainInformationEqualTo(oldMainId);
            // behaviorEc.andEventContentEqualTo(ti.getEventContent());
            // List<EvidenceEventBehavior> behaviors = sqlSession
            // .selectList("com.itrus.portal.db.EvidenceEventBehaviorMapper.selectByExample", behaviorExample);
            // for(EvidenceEventBehavior behavior:behaviors) {
            // behavior.setMainInformation(mainInformation.getId());
            // sqlSession.update("com.itrus.portal.db.EvidenceEventBehaviorMapper.updateByPrimaryKey", behavior);
            // }
            // sqlSession.flushStatements();
            // } else {
            // continue;
            // }
            // }
            // // 判断证据base64 字段是否为空
            // if(StringUtils.isNotEmpty(jsonContent.getString("certBase64"))) {
            // trustedIdentity.setCertBase64(jsonContent.getString("certBase64"));
            // // 解析证书Base64
            // UserCert userCert = CertUtil.getCertFromBase64(jsonContent.getString("certBase64"));
            // trustedIdentity.setCertSerialnumber(userCert.getCertSn());
            // trustedIdentity.setSubjectdn(userCert.getCertDn());
            // trustedIdentity.setIssuerdn(userCert.getIssuerDn());
            // trustedIdentity.setIssuer(EvidenceSaveServiceApi.getCertCn(userCert.getIssuerDn()));
            // if(userCert.getCertBuf() != null) {
            // trustedIdentity.setEvidenceBuf(userCert.getCertBuf().toString());
            // }
            // trustedIdentity.setStartTime(userCert.getCertStartTime());
            // trustedIdentity.setEndTime(userCert.getCertEndTime());
            // }
            // trustedIdentity.setCertSerialnumber(jsonContent.getString("certSn"));
            // trustedIdentity.setIdentiType(jsonContent.getString("type"));
            // trustedIdentity.setBasicInformation(basicInformation.getId());
            // trustedIdentity.setEvidenceEnclosure(enclosure.getId());
            // if(StringUtils.isNotEmpty(jsonContent.getString("evidenceSn")))
            // trustedIdentity.setEvidenceSn(jsonContent.getString("evidenceSn"));
            // trustedIdentity.setCreateTime(new Date());
            // if(mainInformation != null && !"".equals(mainInformation))
            // trustedIdentity.setMainInformation(mainInformation.getId());
            // sqlSession.insert("com.itrus.portal.db.EvidenceTrustedIdentityMapper.insert", trustedIdentity);
            // sqlSession.flushStatements();
            // tiCacheList.add(trustedIdentity);
            // }
            // if(jsonContentArray.size() != 0) {
            // saveFactor = EvidenceSaveServiceApi.mergeFactor(saveFactor, object.getString("i_factor"));
            // }
            // }
            EvidenceEventContent eventContent = new EvidenceEventContent();
            // 判断 补交不接收
            if (bl) {
                // 得到证据包中的事件数据
                for (int i = 0; i < jsonEvArray.size(); i++) {
                    JSONObject object = jsonEvArray.getJSONObject(i);
                    String name = object.getString("name");
                    switch(i) {
                        // 事件认证
                        case 0:
                            // 判断合同类型
                            if ("电子合同PDF".equals(type)) {
                            // 电子合同
                            // // 判断是否接收
                            // if(object.getBooleanValue("e_isReception")) {
                            // // 得到事件内容中的信息
                            // JSONObject jsonEventContent = jsonAuthEvent.getJSONObject(name);
                            // // 判断必填
                            // if(object.getBooleanValue("e_isRequired") && (StringUtils.isEmpty(jsonEventContent.getString("contCode"))
                            // || StringUtils.isEmpty(jsonEventContent.getString("title"))
                            // || StringUtils.isEmpty(jsonEventContent.getString("size"))
                            // || StringUtils.isEmpty(jsonEventContent.getString("page"))
                            // || StringUtils.isEmpty(jsonEventContent.getString("eventVerifierType")))) {
                            // result.put("status", 0);
                            // result.put("message", "提交的参数信息不完整,缺少事件内容认证参数值");
                            // return;
                            // }
                            // String eventVerifier = getAuthenticator(Integer.parseInt(jsonEventContent.getString("eventVerifierType")),
                            // hapPrincipalName, jsonEventContent.getString("eventVerifier"));
                            // if(StringUtils.isEmpty(eventVerifier)) {
                            // result.put("status", 0);
                            // result.put("message", "提交的参数信息不完整,缺少事件认证参数值");
                            // return;
                            // }
                            // // 存储事件内容信息
                            // eventContent.setEventVerifierType(jsonEventContent.getString("eventVerifierType"));
                            // eventContent.setEventVerifier(eventVerifier);
                            // eventContent.setIsPdf(true);
                            // eventContent.setContractTitle(jsonEventContent.getString("title"));
                            // eventContent.setContractNumber(jsonEventContent.getString("code"));
                            // eventContent.setValidStartTime(jsonEventContent.getDate("validStartTime"));
                            // eventContent.setValidEndTime(jsonEventContent.getDate("validEndTime"));
                            // eventContent.setDataFormat(jsonEventContent.getString("dataFormat"));
                            // eventContent.setEventSize(jsonEventContent.getString("size"));
                            // eventContent.setThePages(jsonEventContent.getInteger("page"));
                            // eventContent.setCreateTime(new Date());
                            // eventContent.setBasicInformation(basicInformation.getId());
                            // //            						eventContent.setEvidenceEnclosure(enclosure.getId());
                            // if (StringUtils.isNotEmpty(evidenceSn))
                            // eventContent.setEvidenceSn(evidenceSn);
                            // else
                            // eventContent.setEvidenceSn(genSn);
                            // sqlSession.insert("com.itrus.portal.db.EvidenceEventContentMapper.insert", eventContent);
                            // 
                            // // 定义存储路径和存储名称
                            // //        							String bucketName = realNameAuthenticationOss.getKeyCode();
                            // String pdfName = evidenceSn + "UserUp.pdf";
                            // // 得到加密证书别名
                            // //                                          String encryptionAlias = secretKeyService.getAliasByCertId((long)serviceConfiguration.getEncryptionCertificate());
                            // // 存储contCode 到原子服务
                            // //        							String retSave = EvidenceSaveServiceApi.storageSave("ST_O", bucketName, pdfName, "CT_MESSAGE",
                            // //        									jsonEventContent.get("contCode").toString(), null, null, null, null, null, false, null,
                            // //        									realNameAuthentication.getRealNameddress());
                            // //        							JSONObject jsonRetSave = JSONObject.parseObject(retSave);
                            // //        							if(jsonRetSave.getIntValue("code") != 0) {
                            // //                                          result.put("status", 0);
                            // //                                          result.put("message", "存储用户contCode失败");
                            // ////                                              throw new Exception("存储用户contCode失败");
                            // //                                          return;
                            // //                                      } else {
                            // //                                    	  String pdfSaveFile = systemConfigService.getpdfurl()+ File.separator + bucketName + File.separator + evidenceSn;
                            // // pdf存储到本地
                            // String pdfSaveFile = systemConfigService.getpdfurl()+  File.separator + evidenceSn;
                            // File filePathStr = new File(pdfSaveFile, pdfName);
                            // // 判断目录是否存在
                            // File fileUrl = new File(pdfSaveFile);
                            // if(!fileUrl.exists()) {
                            // fileUrl.mkdir();
                            // }
                            // // 用户contCode转pdf存储到本地
                            // boolean pdfSaveBl = Base64Util.genFileFromBase64(jsonEventContent.getString("contCode"), filePathStr.getPath());
                            // //          								  boolean blStr = false;
                            // //          							      if(StringUtils.isNotEmpty(jsonEventContent.getString("contCode"))) {
                            // //          								      blStr = true;
                            // //          								  }
                            // //                                          if(pdfSaveBl) {
                            // //                                        	  EvidenceEnclosure evidenceEnclosure = new EvidenceEnclosure();
                            // //                                        	  evidenceEnclosure.setEvidenceSn(evidenceSn);
                            // //                                        	  evidenceEnclosure.setBuid(jsonRetSave.getString("buid"));
                            // //                                        	  evidenceEnclosure.setPdfType("2");
                            // //                                        	  evidenceEnclosure.setType("ST_O");
                            // //                                        	  evidenceEnclosure.setContentType("CT_MESSAGE");
                            // //                                        	  evidenceEnclosure.setBucketName(bucketName);
                            // //                                        	  evidenceEnclosure.setObjectName(pdfName);
                            // ////                                            	  evidenceEnclosure.setAlias(encryptionAlias);
                            // //                                        	  evidenceEnclosure.setApplicationTime(new Date());
                            // //                                        	  evidenceEnclosure.setFixationTime(new Date());
                            // //                                        	  evidenceEnclosure.setCreateTime(new Date());
                            // //                                        	  evidenceEnclosure.setBasicInformation(basicInformation.getId());
                            // //                                        	  sqlSession.insert("com.itrus.portal.db.EvidenceEnclosureMapper.insert", evidenceEnclosure);
                            // //                                          }
                            // //                                      }
                            // // 调用pdf验章接口
                            // Map<String, Object> mapPdfVerify = new HashMap<String, Object>();
                            // String urlPdfVerify = realNameAuthentication.getRealNameddress() + PDF_VERIFY;
                            // mapPdfVerify.put("pdfContent", jsonEventContent.get("contCode"));
                            // String rep_pdf_verify = HttpClientUtil.postForm(urlPdfVerify, AuthService.getHeader(), mapPdfVerify);
                            // JSONObject jsonPdfVerify = JSONObject.parseObject(rep_pdf_verify);
                            // if(jsonPdfVerify.getInteger("code") == 0){
                            // eventContent.setEventStatus(1);
                            // } else {
                            // eventContent.setEventStatus(0);
                            // eventContent.setFailureReason(jsonPdfVerify.getString("message"));
                            // basicInformation.setEvidenceStatus(0);
                            // if(StringUtils.isEmpty(basicInformation.getFailureReason())) {
                            // basicInformation.setFailureReason(jsonPdfVerify.getString("message"));
                            // } else {
                            // basicInformation.setFailureReason(basicInformation.getFailureReason() + "," + jsonPdfVerify.getString("message"));
                            // }
                            // sqlSession.update("com.itrus.portal.db.EvidenceBasicInformationMapper.updateByPrimaryKey", basicInformation);
                            // }
                            // String retVerifyTi = null;
                            // String retVerifyBehavior = null;
                            // String retVerifyTime = null;
                            // if(StringUtils.isNotEmpty(rep_pdf_verify)
                            // && StringUtils.isNotEmpty(jsonPdfVerify.getString("signInfos"))) {
                            // // 解析pdf验章返回信息
                            // JSONArray jsonArraySignInfos = jsonPdfVerify.getJSONArray("signInfos");
                            // List<String> listStr = new ArrayList<>();
                            // int noId = 0;
                            // for(int k=0;k<jsonArraySignInfos.size();k++) {
                            // // 循环得到pdf验章返回数据
                            // JSONObject json = jsonArraySignInfos.getJSONObject(k);
                            // // 对应可信身份
                            // EvidenceTrustedIdentity trustedIdentity1 = null;
                            // 
                            // // 判断验章是否包含证书
                            // if(StringUtils.isNotEmpty(json.getString("signerCert"))) {
                            // // 解析签名者证书base64编码
                            // UserCert userCert1 = CertUtil.getCertFromBase64(json.getString("signerCert"));
                            // boolean blt = true;
                            // // 循环已经存在的证书序列号   判断证书序列号是否存在
                            // for(String strCertSn:listStr){
                            // if(userCert1 != null && strCertSn.equals(userCert1.getCertSn())){
                            // blt = false;
                            // }
                            // }
                            // // 循环可信身份list缓存  判断证书序列号是否相同
                            // if(!tiCacheList.isEmpty() && tiCacheList != null){
                            // for(EvidenceTrustedIdentity identity:tiCacheList) {
                            // if(identity.getCertSerialnumber().equals(userCert1.getCertSn())){
                            // trustedIdentity1 = identity;
                            // }
                            // }
                            // }
                            // if(trustedIdentity1 == null) {
                            // noId--;
                            // }
                            // if(blt) {
                            // // 事件对象定义
                            // EvidenceTrustedIdentity trustedIdentity = new EvidenceTrustedIdentity();
                            // trustedIdentity.setBasicInformation(basicInformation.getId());
                            // trustedIdentity.setEventContent(eventContent.getId());
                            // trustedIdentity.setEvidenceSn(evidenceSn);
                            // if(trustedIdentity1 != null){
                            // trustedIdentity.setMainInformation(trustedIdentity1.getMainInformation());
                            // // 整合证书信息存储到对应可信身份表
                            // trustedIdentity1.setCertBase64(json.getString("signerCert"));
                            // trustedIdentity1.setSubjectdn(userCert1.getCertDn());
                            // trustedIdentity1.setIssuerdn(userCert1.getIssuerDn());
                            // trustedIdentity1.setIssuer(EvidenceSaveServiceApi.getCertCn(userCert1.getIssuerDn()));
                            // if(userCert1.getCertBuf() != null){
                            // trustedIdentity1.setEvidenceBuf(userCert1.getCertBuf().toString());
                            // }
                            // trustedIdentity1.setStartTime(userCert1.getCertStartTime());
                            // trustedIdentity1.setEndTime(userCert1.getCertEndTime());
                            // sqlSession.update("com.itrus.portal.db.EvidenceTrustedIdentityMapper.updateByPrimaryKey",
                            // trustedIdentity1);
                            // } else {
                            // trustedIdentity.setMainInformation((long)noId);
                            // }
                            // trustedIdentity.setCertBase64(json.getString("signerCert"));
                            // trustedIdentity.setCreateTime(new Date());
                            // trustedIdentity.setCertSerialnumber(userCert1.getCertSn());
                            // trustedIdentity.setSubjectdn(userCert1.getCertDn());
                            // trustedIdentity.setIssuerdn(userCert1.getIssuerDn());
                            // trustedIdentity.setIdentiType("1");
                            // trustedIdentity.setIssuer(EvidenceSaveServiceApi.getCertCn(userCert1.getIssuerDn()));
                            // if(userCert1.getCertBuf() != null){
                            // trustedIdentity.setEvidenceBuf(userCert1.getCertBuf().toString());
                            // }
                            // trustedIdentity.setStartTime(userCert1.getCertStartTime());
                            // trustedIdentity.setEndTime(userCert1.getCertEndTime());
                            // 
                            // // 事件对象核验结果
                            // trustedIdentity.setCheckTime(new Date());
                            // if(json.getIntValue("vcResult") == 0) {
                            // trustedIdentity.setCheckStatus("1");
                            // trustedIdentity.setCheckSuccessTime(new Date());
                            // } else {
                            // if(StringUtils.isEmpty(retVerifyTi))
                            // retVerifyTi = "事件对象核验失败";
                            // trustedIdentity.setCheckStatus("0");
                            // if(json.getIntValue("vcResult") == 30006)
                            // trustedIdentity.setUnreason("未找到对应的受信任CA证书");
                            // else if(json.getIntValue("vcResult") == 30007)
                            // trustedIdentity.setUnreason("证书已吊销");
                            // else if(json.getIntValue("vcResult") == 30008)
                            // trustedIdentity.setUnreason("证书不在有效期内");
                            // else if(json.getIntValue("vcResult") == 30009)
                            // trustedIdentity.setUnreason("无效的证书签名");
                            // else if(json.getIntValue("vcResult") == 300010)
                            // trustedIdentity.setUnreason("其他证书验证错误");
                            // else
                            // trustedIdentity.setUnreason("非正常其他证书验证错误");
                            // }
                            // trustedIdentity.setVewestCheckTime(new Date());
                            // trustedIdentity.setCheckContent("1.验证证书有效期/n2.验证证书颁发者签名/n3.验证证书是否吊销");
                            // sqlSession.insert("com.itrus.portal.db.EvidenceTrustedIdentityMapper.insert", trustedIdentity);
                            // }
                            // listStr.add(userCert1.getCertSn());
                            // } else {
                            // retVerifyTi = "事件对象核验失败";
                            // }
                            // // 事件行为定义
                            // EvidenceEventBehavior eventBehavior = new EvidenceEventBehavior();
                            // // 判断时间戳是否存在
                            // if(StringUtils.isNotEmpty(json.getString("timeStamp"))
                            // && !json.getString("timeStamp").equals("{}")) {
                            // // 验证时间戳
                            // EvidenceEventTime eventTime = new EvidenceEventTime();
                            // if(trustedIdentity1 != null){
                            // eventTime.setMainInformation(trustedIdentity1.getMainInformation());
                            // } else {
                            // eventTime.setMainInformation((long)noId);
                            // }
                            // eventTime.setIdentiType("1");
                            // eventTime.setEventContent(eventContent.getId());
                            // eventTime.setCertificate(json.getJSONObject("timeStamp").getString("signature"));
                            // eventTime.setHashAlgorithm(json.getJSONObject("timeStamp").getString("hashAlg"));
                            // eventTime.setHashvalue(json.getJSONObject("timeStamp").getString("hashData"));
                            // eventTime.setCertBase64(json.getJSONObject("timeStamp").getString("tsCert"));
                            // if(StringUtils.isNotEmpty(json.getJSONObject("timeStamp").getString("time"))) {
                            // eventTime.setSignatureTime(json.getJSONObject("timeStamp").getDate("time"));
                            // } else {
                            // eventTime.setSignatureTime(json.getDate("stampTime"));
                            // }
                            // eventTime.setCreateTime(new Date());
                            // // 解析时间戳证书 Base64
                            // if(json.getJSONObject("timeStamp").getString("tsCert") != null) {
                            // UserCert userCert = CertUtil.getCertFromBase64(json.getJSONObject("timeStamp").getString("tsCert"));
                            // eventTime.setCertificateDn(userCert.getCertDn());
                            // eventTime.setIssuerdn(userCert.getIssuerDn());
                            // }
                            // // 时间核验结果
                            // eventTime.setCheckTime(new Date());
                            // if(json.getIntValue("vtsResult") == 0) {
                            // eventTime.setCheckStatus("1");
                            // eventTime.setCheckSuccessTime(new Date());
                            // } else {
                            // if(StringUtils.isEmpty(retVerifyTime)) {
                            // retVerifyTime = "事件时间核验失败";
                            // }
                            // eventTime.setCheckStatus("0");
                            // if(json.getIntValue("vtsResult") == 60002) {
                            // eventTime.setUnreason("验证时戳失败");
                            // } else {
                            // eventTime.setUnreason("其他验证时戳错误");
                            // }
                            // }
                            // eventTime.setVewestCheckTime(new Date());
                            // eventTime.setCheckContent("签名原文完整、真实、是否被篡改");
                            // sqlSession.insert("com.itrus.portal.db.EvidenceEventTimeMapper.insert", eventTime);
                            // } else {
                            // eventBehavior.setVerificationTime(json.getDate("stampTime"));
                            // }
                            // // 判断事件行为是否返回为空
                            // if(StringUtils.isNotEmpty(json.getString("signature"))) {
                            // eventBehavior.setHashAlgorithm(json.getString("hashAlg"));
                            // eventBehavior.setSignaturevalue(json.getString("signature"));
                            // eventBehavior.setHashBackSigning(json.getString("msgDigest"));
                            // eventBehavior.setEventContent(eventContent.getId());
                            // eventBehavior.setIdentiType("1");
                            // if(trustedIdentity1 != null){
                            // eventBehavior.setMainInformation(trustedIdentity1.getMainInformation());
                            // } else {
                            // eventBehavior.setMainInformation((long)noId);
                            // }
                            // // 事件行为核验结果
                            // eventBehavior.setCheckTime(new Date());
                            // if(json.getIntValue("vdsResult") == 0) {
                            // eventBehavior.setCheckStatus("1");
                            // eventBehavior.setCheckSuccessTime(new Date());
                            // } else {
                            // if(StringUtils.isEmpty(retVerifyBehavior)) {
                            // retVerifyBehavior = "事件行为核验失败";
                            // }
                            // eventBehavior.setCheckStatus("0");
                            // if(json.getIntValue("vdsResult") == 40002) {
                            // eventBehavior.setUnreason("验证签名失败");
                            // } else {
                            // eventBehavior.setUnreason("其他验证签名错误");
                            // }
                            // }
                            // eventBehavior.setVewestCheckTime(new Date());
                            // eventBehavior.setCheckContent("签名原文完整、真实、是否被篡改");
                            // sqlSession.insert("com.itrus.portal.db.EvidenceEventBehaviorMapper.insert", eventBehavior);
                            // } else {
                            // retVerifyBehavior = "事件行为核验失败";
                            // }
                            // }
                            // if(jsonArraySignInfos.size() == 0) {
                            // eventContent.setEventStatus(0);
                            // if(StringUtils.isNotEmpty(eventContent.getFailureReason())) {
                            // eventContent.setFailureReason(eventContent.getFailureReason() + ",pdf签章失败:返回集合为空。");
                            // } else {
                            // eventContent.setFailureReason("pdf签章失败:返回集合为空。");
                            // }
                            // }
                            // // 整合错误信息
                            // //       	if(StringUtils.isNotEmpty(eventContent.getFailureReason())) {
                            // //          	eventContent.setFailureReason(eventContent.getFailureReason());
                            // //       	}
                            // if(StringUtils.isNotEmpty(retVerifyTi)) {
                            // if(StringUtils.isNotEmpty(eventContent.getFailureReason()))
                            // eventContent.setFailureReason(eventContent.getFailureReason() + "," + retVerifyTi);
                            // else
                            // eventContent.setFailureReason(retVerifyTi);
                            // }
                            // if(StringUtils.isNotEmpty(retVerifyBehavior)) {
                            // if(StringUtils.isNotEmpty(eventContent.getFailureReason()))
                            // eventContent.setFailureReason(retVerifyBehavior);
                            // else
                            // eventContent.setFailureReason(eventContent.getFailureReason() + "," + retVerifyBehavior);
                            // }
                            // if(StringUtils.isNotEmpty(retVerifyTime)) {
                            // if(StringUtils.isNotEmpty(eventContent.getFailureReason()))
                            // eventContent.setFailureReason(retVerifyTime);
                            // else
                            // eventContent.setFailureReason(eventContent.getFailureReason() + "," + retVerifyTime);
                            // }
                            // sqlSession.update("com.itrus.portal.db.EvidenceEventContentMapper.updateByPrimaryKey", eventContent);
                            // if(eventContent.getEventStatus() == 0) {
                            // if(StringUtils.isNotEmpty(basicInformation.getFailureReason())) {
                            // basicInformation.setFailureReason(basicInformation.getFailureReason() + "," + eventContent.getFailureReason());
                            // } else {
                            // basicInformation.setEvidenceStatus(0);
                            // basicInformation.setFailureReason(eventContent.getFailureReason());
                            // }
                            // sqlSession.update("com.itrus.portal.db.EvidenceBasicInformationMapper.updateByPrimaryKey", basicInformation);
                            // }
                            // }
                            // saveFactor = EvidenceSaveServiceApi.mergeFactor(saveFactor, object.getString("e_factor"));
                            // }
                            /**
                             ***********************************************     《电子合同PDF》 获取事件内容    end      *******************************************
                             */
                            } else if ("合同摘要数据".equals(type) || "图片摘要数据".equals(type) || "信息摘要数据".equals(type)) {
                                // 判断是否接收
                                if (object.getBooleanValue("e_isReception")) {
                                    // 得到事件内容中的信息
                                    JSONObject jsonEventContent = jsonAuthEvent.getJSONObject(name);
                                    // 判断必填
                                    if (object.getBooleanValue("e_isRequired") && (StringUtils.isEmpty(jsonEventContent.getString("contCode")) || StringUtils.isEmpty(jsonEventContent.getString("dataFormat")))) {
                                        result.put("status", 0);
                                        result.put("message", "提交的参数信息不完整,缺少事件内容认证参数值");
                                        return result;
                                    }
                                    // 存储事件内容信息
                                    eventContent.setIsPdf(false);
                                    eventContent.setContractTitle(jsonEventContent.getString("title"));
                                    eventContent.setCreateTime(new Date());
                                    eventContent.setBasicInformation(basicInformation.getId());
                                    eventContent.setEvidenceSn(evidenceSn);
                                    eventContent.setContCode(jsonEventContent.getString("contCode"));
                                    if ("合同摘要数据".equals(type) || "信息摘要数据".equals(type)) {
                                        eventContent.setValidStartTime(jsonEventContent.getDate("validStartTime"));
                                        eventContent.setValidEndTime(jsonEventContent.getDate("validEndTime"));
                                        eventContent.setDataFormat(jsonEventContent.getString("dataFormat"));
                                    } else {
                                        eventContent.setDataFormatImg(jsonEventContent.getString("dataFormat"));
                                    }
                                    // queueThread.putObjectQueue(eventContent);
                                    objs.add(eventContent);
                                    eventContent = null;
                                    saveFactor = EvidenceSaveServiceApi.mergeFactor(saveFactor, object.getString("e_factor"));
                                }
                            /**
                             ***********************************************     《合同摘要数据》 和 《图片摘要数据》 获取事件内容    end      *******************************************
                             */
                            }
                            break;
                    }
                }
            } else {
                // 补交信息得到事件内容
                EvidenceEventContentExample contentExample = new EvidenceEventContentExample();
                EvidenceEventContentExample.Criteria cec = contentExample.createCriteria();
                cec.andBasicInformationEqualTo(basicInformation.getId());
                List<EvidenceEventContent> eventContents = sqlSession.selectList("com.itrus.portal.db.EvidenceEventContentMapper.selectByExample", contentExample);
                if (!eventContents.isEmpty()) {
                    eventContent = eventContents.get(0);
                }
            }
        /*if(StringUtils.isNotEmpty(jsonAuthEvent.getString("event"))) {
    				
    				JSONArray jsonContentArray = jsonAuthEvent.getJSONArray("event");
    				for(int i=0;i<jsonContentArray.size();i++) {
        				// 得到对应的主体信息
        				JSONObject jsonContent = jsonContentArray.getJSONObject(i);
        				JSONObject jsonIdIdentify = jsonContentArray.getJSONObject(i).getJSONObject("idIdentify");
    					// 判断主体是否存在
    					String idCacheKey = jsonIdIdentify.getString("name") + jsonIdIdentify.getString("dataId");
    					EvidenceMainInformation mainInformation = null;	
    					if(mapIdCache.get(idCacheKey) == null || "".equals(mapIdCache.get(idCacheKey))) {
    						EvidenceMainInformationExample mainInformationExample = new EvidenceMainInformationExample();
    						EvidenceMainInformationExample.Criteria mainExampleCriteria = mainInformationExample.createCriteria();
    						mainExampleCriteria.andSubjectNameEqualTo(jsonIdIdentify.getString("name"));
    						mainExampleCriteria.andIdentificationEqualTo(jsonIdIdentify.getString("dataId"));
    						List<EvidenceMainInformation> mainInformationList = sqlSession.selectList("com.itrus.portal.db.EvidenceMainInformationMapper.selectByExample", mainInformationExample);
    						if(!mainInformationList.isEmpty()) {
    							mainInformation = mainInformationList.get(0);
    							mapIdCache.put(mainInformation.getSubjectName() + mainInformation.getIdentification(), mainInformation);
    						}
    					} else {
    						mainInformation = mapIdCache.get(idCacheKey);
    					}
    					if(mainInformation == null || "".equals(mainInformation)) {
    						result.put("status", 0);
    						result.put("message", "判断主体为空");
    						return;
    					}
    					
    					// 核验事件认证
    					// 得到证据包中的事件数据
    	    			for(int j=0;j<jsonEvArray.size();j++) {
    	    				JSONObject object = jsonEvArray.getJSONObject(j);
    	    				String name = object.getString("name");
    	    				switch (j) {
    	    				// 事件意愿认证
    	    				case 2:
    	                        if(!bl) {
    	                        	// 查询信息是否已经存证
    	                            EvidenceEventDesireExample ede = new EvidenceEventDesireExample();
    	                            EvidenceEventDesireExample.Criteria edec = ede.createCriteria();
    	                            edec.andEventContenteEqualTo(eventContent.getId());
    	                            edec.andMainInformationEqualTo(mainInformation.getId());
    	                            List<EvidenceEventDesire> eventDesires = sqlSession
    	                                    .selectList("com.itrus.portal.db.EvidenceEventDesireMapper.selectByExample", ede);
    	                            if(!eventDesires.isEmpty()) {
    	                            	break;
    	                            }
    	                        }
    	                        // 判断是否接收
    	                        if(object.getJSONObject("e_isReception").getBooleanValue("e_isReception_1")
    	                                || object.getJSONObject("e_isReception").getBooleanValue("e_isReception_2")) {
    	                        	JSONObject jsonWill = jsonContent.getJSONObject(name);
                                    
                                    if(bl && object.getBooleanValue("e_isRequired") && (
                                            StringUtils.isEmpty(jsonWill.getString("authenticatorThenType"))
                                            ||	(jsonWill.getString("authenticatorThenType").equals("3") 
                                            		&& StringUtils.isEmpty(jsonWill.getString("authenticatorThen")))
                                            ||	StringUtils.isEmpty(jsonWill.getString("way")))) {
                                        result.put("status", 0);
                                        result.put("message", "提交的参数信息不完整,缺少事件意愿认证参数值");
                                        return;
                                    }
                                    EvidenceEventDesire eventDesire = new EvidenceEventDesire();
                                    // 1.证书授权 2.短信验证
                                    if(jsonWill.getIntValue("way") == 1) {
                                        JSONObject jsonCertContent = jsonWill.getJSONObject("certAccreditContent");
                                        if(bl && object.getBooleanValue("e_isRequired") && (
                                                StringUtils.isEmpty(jsonCertContent.getString("certBase64"))
                                                        ||	StringUtils.isEmpty(jsonCertContent.getString("challengeCode"))
                                                        ||	StringUtils.isEmpty(jsonCertContent.getString("answerCode"))
                                                        ||	StringUtils.isEmpty(jsonCertContent.getString("verifyTime")))) {
                                            result.put("status", 0);
                                            result.put("message", "提交的参数信息不完整,缺少事件意愿认证参数值");
                                            return;
                                        }
                                        // 验证证书
                                        String urlCertVerify = realNameAuthentication.getRealNameddress() + CERT_VERIFY;
                                        Map<String, Object> mapCertVerify = new HashMap<String, Object>();
                                        mapCertVerify.put("cert", jsonCertContent.getString("certBase64"));
                                        mapCertVerify.put("verifyFlag", "7");
                                        String rep_cert_verify = HttpClientUtil.postForm(urlCertVerify, AuthService.getHeader(), mapCertVerify);
                                        JSONObject jsonCertVerify = JSONObject.parseObject(rep_cert_verify);
                                        if(StringUtils.isNotEmpty(rep_cert_verify) && jsonCertVerify.getIntValue("code") == 0) {
                                            // 解析证书Base64
                                            UserCert userCert = CertUtil.getCertFromBase64(jsonCertVerify.getString("certBase64"));
                                            eventDesire.setCertSerialnumber(userCert.getCertSn());
                                            eventDesire.setSubjectdn(userCert.getCertDn());
                                            eventDesire.setIssuerdn(userCert.getIssuerDn());
                                            eventDesire.setEvidenceBuf(userCert.getCertBuf().toString());
                                            eventDesire.setStartTime(userCert.getCertStartTime());
                                            eventDesire.setEndTime(userCert.getCertEndTime());
                                        } else {
                                            result.put("status", 0);
                                            result.put("message", "验证证书失败");
                                            return;
                                        }
                                        eventDesire.setChallengeCode(jsonCertContent.getString("challengeCode"));
                                        eventDesire.setAnswerCode(jsonCertContent.getString("answerCode"));
                                        eventDesire.setClientDevice(jsonCertContent.getString("clientFacility"));
                                        eventDesire.setVerificationTime(jsonCertContent.getDate("verifyTime"));
                                        eventDesire.setWaysExpression(jsonWill.getString("way"));
                                    } else if(jsonWill.getIntValue("way") == 2) {
                                        JSONObject jsonSmsContent = jsonWill.getJSONObject("verifySmsContent");
                                        if(bl && object.getBooleanValue("e_isRequired") && (
                                                StringUtils.isEmpty(jsonSmsContent.getString("phone"))
                                                        ||	StringUtils.isEmpty(jsonSmsContent.getString("sendTime"))
                                                        ||	StringUtils.isEmpty(jsonSmsContent.getString("smsContent"))
                                                        ||	StringUtils.isEmpty(jsonSmsContent.getString("verifyCode"))
                                                        ||	StringUtils.isEmpty(jsonSmsContent.getString("verifyTime")))) {
                                            result.put("status", 0);
                                            result.put("message", "提交的参数信息不完整,缺少事件意愿认证参数值");
                                            return;
                                        }
                                        eventDesire.setPhone(jsonSmsContent.getString("phone"));
                                        eventDesire.setSmsContent(jsonSmsContent.getString("smsContent"));
                                        eventDesire.setVerificationCode(jsonSmsContent.getString("verifyCode"));
                                        eventDesire.setSendOutTime(jsonSmsContent.getDate("sendTime"));
                                        eventDesire.setVerificationTime(jsonSmsContent.getDate("verifyTime"));
                                        eventDesire.setWaysExpression(jsonWill.getString("way"));
                                    }
                                    String eventVerifier = getAuthenticator(Integer.parseInt(jsonWill.getString("authenticatorThenType")),
                                            hapPrincipalName, jsonWill.getString("authenticatorThen"));
                                    if(StringUtils.isEmpty(eventVerifier)) {
                                        result.put("status", 0);
                                        result.put("message", "提交的参数信息不完整,缺少身份意愿鉴别参数值");
                                        return;
                                    }
                                    eventDesire.setMainInformation(mainInformation.getId());
                                    eventDesire.setEventContente(eventContent.getId());
                                    eventDesire.setCreateTime(new Date());
                                    eventDesire.setEventVerifierType(jsonWill.getString("authenticatorThenType"));
                                    eventDesire.setEventVerifier(eventVerifier);
                                    eventDesire.setVerificationResult(jsonWill.getString("verifyResult"));
                                    sqlSession.insert("com.itrus.portal.db.EvidenceEventDesireMapper.insert", eventDesire);
    	                            
                                    saveFactor = EvidenceSaveServiceApi.mergeFactor(saveFactor, object.getString("e_factor"));
    	                        }
    	                        break;
    	                    // 事件地点认证
    	    				case 4:
    	    					if(!bl) {
    	    						// 查询信息是否已经存证
    	    						EvidenceEventNetworkAddressExample nae = new EvidenceEventNetworkAddressExample();
    	    						EvidenceEventNetworkAddressExample.Criteria naec = nae.createCriteria();
    	    						naec.andEventContentEqualTo(eventContent.getId());
    	    						naec.andMainInformationEqualTo(mainInformation.getId());
    	    						List<EvidenceEventNetworkAddress> eventNetworkAddresses = sqlSession
    	    								.selectList("com.itrus.portal.db.EvidenceEventNetworkAddressMapper.selectByExample", nae);
    	    						if(!eventNetworkAddresses.isEmpty()) {
    	    							break;
    	    						}
    	    					}
    	    					// 判断是否接收
    	    					if(object.getBooleanValue("e_isReception")) {
        							JSONObject jsonAddress = jsonContent.getJSONObject("netAddress");
        							// 定义事件网络地址对象
        							EvidenceEventNetworkAddress eventNetworkAddress = new EvidenceEventNetworkAddress();
        							// 整合数据 存储
        							eventNetworkAddress.setEventContent(eventContent.getId());
        							eventNetworkAddress.setMainInformation(mainInformation.getId());
        							eventNetworkAddress.setCreateTime(new Date());
        							if(jsonAddress.getBooleanValue("typeReg")) {
        								JSONObject jsonContentReg = jsonAddress.getJSONObject("content");
        								eventNetworkAddress.setType("1");
        								eventNetworkAddress.setAccountNumber(jsonContentReg.getString("code"));
        								eventNetworkAddress.setIpAddress(jsonContentReg.getString("ipAddress"));
        								eventNetworkAddress.setSigninTime(jsonContentReg.getDate("time"));
        							} else {
        								eventNetworkAddress.setType("0");
        							}
        							if(jsonAddress.getBooleanValue("typeSign")) {
        								JSONObject jsonContentSign = jsonAddress.getJSONObject("content1");
        								eventNetworkAddress.setSigninNumber(jsonContentSign.getString("code"));
        								eventNetworkAddress.setSigninipAddress(jsonContentSign.getString("ipAddress"));
        								eventNetworkAddress.setSendOutTime(jsonContentSign.getDate("time"));
        								eventNetworkAddress.setSigninType("1");
        							} else {
        								eventNetworkAddress.setSigninType("0");
        							}
        							sqlSession.insert("com.itrus.portal.db.EvidenceEventNetworkAddressMapper.insert", eventNetworkAddress);
    	    						
    	    						saveFactor = EvidenceSaveServiceApi.mergeFactor(saveFactor, object.getString("e_factor"));
    	    					}
    	    					break;
    	    				}
    	    			}
        			}
    			}*/
        }
        result.put("saveFactor", saveFactor);
        result.put("basicInformation", basicInformation);
        result.put("objs", objs);
        return result;
    } catch (Exception e) {
        e.printStackTrace();
        StackTraceElement stackTraceElement = e.getStackTrace()[e.getStackTrace().length - 5];
        String info = stackTraceElement.getClassName() + stackTraceElement.getLineNumber() + e.toString();
        LogUtil.evidencelog(sqlSession, evidenceSn, "存证接口", "存证失败,证据编号:" + evidenceSn + ", 失败原因:" + info);
        result.put("status", -5);
        result.put("message", "系统服务错误,请联系管理员");
        return result;
    }
}
Also used : HashMap(java.util.HashMap) ArrayList(java.util.ArrayList) JSONArray(com.alibaba.fastjson.JSONArray) EvidenceSubjectIdentity(com.itrus.portal.db.EvidenceSubjectIdentity) EvidenceMainInformation(com.itrus.portal.db.EvidenceMainInformation) Date(java.util.Date) EvidenceEventContentExample(com.itrus.portal.db.EvidenceEventContentExample) JSONObject(com.alibaba.fastjson.JSONObject) JSONObject(com.alibaba.fastjson.JSONObject) EvidenceMainInformationExample(com.itrus.portal.db.EvidenceMainInformationExample) EvidenceEventContent(com.itrus.portal.db.EvidenceEventContent)

Example 7 with EvidenceMainInformationExample

use of com.itrus.portal.db.EvidenceMainInformationExample in project portal by ixinportal.

the class BasicInformationController method show1.

/**
 * 查看详细内容(事件详细)
 *
 * @param id
 * @param type
 * @param uiModel
 * @return
 */
@RequestMapping(value = "show1/{id}/{mid}/{type}", produces = "text/html")
public String show1(@PathVariable("id") Long id, @PathVariable("mid") Long mid, @PathVariable("type") int type, Model uiModel) {
    /*
		 * if (type == 1) {// 身份意愿鉴别信息 EvidenceDesireIdentify desire =
		 * sqlSession .selectOne(
		 * "com.itrus.portal.db.EvidenceDesireIdentifyMapper.selectByPrimaryKey",
		 * id); EvidenceMainInformation mainInfo = sqlSession.selectOne(
		 * "com.itrus.portal.db.EvidenceMainInformationMapper.selectByPrimaryKey",
		 * desire.getMainInformation()); uiModel.addAttribute("desire", desire);
		 * uiModel.addAttribute("mainInfo", mainInfo); return
		 * "basicinformation/desireIdentify"; } else if (type == 2) {// 获取实名认证信息
		 * EvidenceCompaniesSubmit companiesSubmit = sqlSession .selectOne(
		 * "com.itrus.portal.db.EvidenceCompaniesSubmitMapper.selectByPrimaryKey",
		 * id); String cid = companiesSubmit.getId().toString(); int evid =
		 * Integer.parseInt(cid); EvidenceRealNameExample realnameE = new
		 * EvidenceRealNameExample(); EvidenceRealNameExample.Criteria
		 * realnameEx = realnameE.createCriteria();
		 * realnameEx.andCompaniesSubmitEqualTo(evid); EvidenceRealName
		 * erealname = sqlSession .selectOne(
		 * "com.itrus.portal.db.EvidenceRealNameMapper.selectByExample",
		 * realnameE); EvidenceMainInformation mainInfo = sqlSession.selectOne(
		 * "com.itrus.portal.db.EvidenceMainInformationMapper.selectByPrimaryKey",
		 * erealname.getMainInformation()); if
		 * (companiesSubmit.getRepresentative() != null) {// 法定代表人
		 * EvidenceRepresentative representative = sqlSession.selectOne(
		 * "com.itrus.portal.db.EvidenceRepresentativeMapper.selectByPrimaryKey",
		 * companiesSubmit.getRepresentative());
		 * uiModel.addAttribute("representative", representative); } if
		 * (companiesSubmit.getTheAgent() != null) {// 代理人 EvidenceTheAgent
		 * theagent = sqlSession.selectOne(
		 * "com.itrus.portal.db.EvidenceTheAgentMapper.selectByPrimaryKey",
		 * companiesSubmit.getTheAgent()); uiModel.addAttribute("theagent",
		 * theagent); } uiModel.addAttribute("erealname", erealname);
		 * uiModel.addAttribute("companiesSubmit", companiesSubmit);
		 * uiModel.addAttribute("mainInfo", mainInfo); return
		 * "basicinformation/companiesSubmit";
		 * 
		 * } else
		 */
    if (type == 3) {
        // 可信身份标识
        // EvidenceTrustedIdentity trusted = sqlSession
        // .selectOne("com.itrus.portal.db.EvidenceTrustedIdentityMapper.selectByPrimaryKey", id);
        // EvidenceMainInformation mainInfo = sqlSession.selectOne(
        // "com.itrus.portal.db.EvidenceMainInformationMapper.selectByPrimaryKey",
        // trusted.getMainInformation());
        // uiModel.addAttribute("trusted", trusted);
        // uiModel.addAttribute("mainInfo", mainInfo);
        EvidenceTrustedIdentity trusted = sqlSession.selectOne("com.itrus.portal.db.EvidenceTrustedIdentityMapper.selectByPrimaryKey", id);
        String idCode = trusted.getMainInformation().split(";")[1];
        String idName = trusted.getMainInformation().split(";")[0];
        EvidenceMainInformationExample maininfor = new EvidenceMainInformationExample();
        EvidenceMainInformationExample.Criteria mation = maininfor.createCriteria();
        mation.andIdentificationEqualTo(idCode);
        mation.andSubjectNameEqualTo(idName);
        List<EvidenceMainInformation> mainInfo = sqlSession.selectList("com.itrus.portal.db.EvidenceMainInformationMapper.selectByExample", maininfor);
        uiModel.addAttribute("trusted", trusted);
        /*EvidenceCertExample basicEx = new EvidenceCertExample();
			EvidenceCertExample.Criteria information = basicEx.createCriteria();
			information.andCertSerialnumberEqualTo(trusted.getCertSerialnumber().trim());
			EvidenceCert cert = sqlSession.selectOne("com.itrus.portal.db.EvidenceCertMapper.selectByExample", basicEx);
			uiModel.addAttribute("cert", cert); 
			if(cert!=null && cert.getIssuerdn()!=null){
				
				uiModel.addAttribute("Issuerdn", EvidenceSaveServiceApi.getCertCn(cert.getIssuerdn()));
			}*/
        uiModel.addAttribute("mainInfo", mainInfo.get(0));
        return "basicinformation/trustedIdentity";
    } else if (type == 4) {
        // 事件内容
        EvidenceEventContent mevencontent = sqlSession.selectOne("com.itrus.portal.db.EvidenceEventContentMapper.selectByPrimaryKey", id);
        // 得到基本信息
        /*EvidenceBasicInformation basicinfor = sqlSession
					.selectOne("com.itrus.portal.db.EvidenceBasicInformationMapper.selectByPrimaryKey", mevencontent.getBasicInformation());*/
        EvidenceBasicInformationExample basicEx = new EvidenceBasicInformationExample();
        EvidenceBasicInformationExample.Criteria information = basicEx.createCriteria();
        information.andEvidenceSnEqualTo(mevencontent.getEvidenceSn());
        EvidenceBasicInformation basicinfor = sqlSession.selectOne("com.itrus.portal.db.EvidenceBasicInformationMapper.selectByExample", basicEx);
        // 得到服务表信息
        AppService appservice = appService.selectById(basicinfor.getAppService());
        EvidenceSaveServiceExample save = new EvidenceSaveServiceExample();
        EvidenceSaveServiceExample.Criteria saveEx = save.createCriteria();
        saveEx.andAppServiceEqualTo(appservice.getId());
        EvidenceSaveService evidenceSave = sqlSession.selectOne("com.itrus.portal.db.EvidenceSaveServiceMapper.selectByExample", save);
        // String js = evidenceSave.getFactorBusinessInfo();
        String evidenceType = null;
        try {
            JSONArray jsonArray = new JSONArray(evidenceSave.getFactorBusinessInfo());
            for (int i = 0; i < jsonArray.length(); i++) {
                JSONObject jsob = JSONObject.parseObject(jsonArray.get(i).toString());
                if ("业务类型".equals(jsob.getString("b_factor"))) {
                    evidenceType = jsob.getString("b_category");
                }
            }
            if ("电子合同PDF".equals(evidenceType)) {
                // 判断图片是否存在
                if (mevencontent.getIsimg() == null) {
                    // EvidenceBasicInformation basic = sqlSession.selectOne(
                    // "com.itrus.portal.db.EvidenceBasicInformationMapper.selectByPrimaryKey",
                    // mevencontent.getEvidenceSn());
                    // 得到证据附件表,用于获取信息
                    EvidenceEnclosureExample envlosureE = new EvidenceEnclosureExample();
                    EvidenceEnclosureExample.Criteria envlosureEx = envlosureE.createCriteria();
                    envlosureEx.andEvidenceSnEqualTo(basicinfor.getEvidenceSn());
                    envlosureEx.andPdfTypeEqualTo("1");
                    EvidenceEnclosure envlosure = sqlSession.selectOne("com.itrus.portal.db.EvidenceEnclosureMapper.selectByExample", envlosureE);
                    RealNameAuthentication realNameAuthentication = CacheCustomer.getAUTH_CONFIG_MAP().get(2);
                    if (realNameAuthentication == null) {
                        try {
                            realNameAuthentication = realNameAuthenticationSerivce.getRealNameAuthenticationByTwo();
                        } catch (Exception e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        }
                    }
                    String pdfbase64 = null;
                    String urlAgent = realNameAuthentication.getRealNameddress();
                    if (envlosure != null && envlosure.getBuid() != null) {
                        log.error("Buid======" + envlosure.getBuid());
                        pdfbase64 = EvidenceSaveServiceApi.decryptedAndDownload(sqlSession, envlosure.getBuid(), urlAgent);
                    }
                    if (pdfbase64 != null) {
                        log.error("*******pdfbase64不为空*********");
                        // 得到证据包的json
                        JSONObject jsonEvidenceContent = JSONObject.parseObject(pdfbase64);
                        String authEvent = jsonEvidenceContent.getString("authEvent");
                        JSONObject authEvent1 = JSONObject.parseObject(authEvent);
                        String jsonpdf = authEvent1.getString("eventContent");
                        JSONObject jsonpdf1 = JSONObject.parseObject(jsonpdf);
                        // 得到pdf的base64编码
                        String jsonbase64 = jsonpdf1.getString("contCode");
                        BufferedInputStream bin = null;
                        FileOutputStream fout = null;
                        BufferedOutputStream bout = null;
                        try {
                            BASE64Decoder decoder = new sun.misc.BASE64Decoder();
                            // 将base64编码的字符串解码成字节数组
                            byte[] bytes = decoder.decodeBuffer(jsonbase64);
                            // apache公司的API
                            // byte[] bytes = Base64.decodeBase64(base64sString);
                            // 创建一个将bytes作为其缓冲区的ByteArrayInputStream对象
                            ByteArrayInputStream bais = new ByteArrayInputStream(bytes);
                            // 创建从底层输入流中读取数据的缓冲输入流对象
                            bin = new BufferedInputStream(bais);
                            // 指定输出的文件
                            log.error("路径地址=" + systemConfigService.getpdfurl() + File.separator + envlosure.getBucketName() + File.separator + envlosure.getEvidenceSn() + ".pdf");
                            File file = new File(systemConfigService.getpdfurl() + File.separator + envlosure.getBucketName() + File.separator + envlosure.getEvidenceSn() + ".pdf");
                            // 创建到指定文件的输出流
                            fout = new FileOutputStream(file);
                            // 为文件输出流对接缓冲输出流对象
                            bout = new BufferedOutputStream(fout);
                            byte[] buffers = new byte[1024];
                            int len = bin.read(buffers);
                            while (len != -1) {
                                bout.write(buffers, 0, len);
                                len = bin.read(buffers);
                            }
                            // 刷新此输出流并强制写出所有缓冲的输出字节,必须这行代码,否则有可能有问题
                            bout.flush();
                        } catch (IOException e) {
                            e.printStackTrace();
                        } finally {
                            try {
                                if (bin != null) {
                                    bin.close();
                                }
                                if (fout != null) {
                                    fout.close();
                                }
                                if (bout != null) {
                                    bout.close();
                                }
                            } catch (IOException e) {
                                e.printStackTrace();
                            }
                        }
                        // 判断是否为用户上传pdf
                        if (envlosure != null) {
                            String urlFile = systemConfigService.getpdfurl() + File.separator + envlosure.getBucketName();
                            File filePathStr = new File(urlFile, envlosure.getEvidenceSn() + ".pdf");
                            log.error("***********filePathStr=" + filePathStr.getPath());
                            int pdfToPng = 0;
                            if (filePathStr != null && filePathStr.getPath() != null) {
                                try {
                                    pdfToPng = Pdf.pdf2png(filePathStr.getPath());
                                } catch (Exception e) {
                                    e.printStackTrace();
                                }
                            }
                            log.error("是否生成,数量****pdfToPng=" + pdfToPng);
                            // 判断生成图片是否成功
                            if (pdfToPng > 0) {
                                // 修改内容表信息,表示生成图片
                                mevencontent.setIsimg(1);
                                mevencontent.setImgCount(pdfToPng);
                                sqlSession.update("com.itrus.portal.db.EvidenceEventContentMapper.updateByPrimaryKey", mevencontent);
                                String oper = "原文图片生成成功";
                                String info = "图片地址:" + urlFile;
                                LogUtil.evidencelog(sqlSession, null, oper, info);
                            } else {
                                String oper = "原文图片生成失败";
                                String info = "失败原因:" + systemConfigService.getpdfurl() + File.separator + envlosure.getBucketName();
                                LogUtil.evidencelog(sqlSession, null, oper, info);
                            }
                        }
                    }
                }
                uiModel.addAttribute("selectType", 1);
            } else if ("合同摘要数据".equals(evidenceType)) {
                uiModel.addAttribute("selectType", 2);
            } else if ("图片摘要数据".equals(evidenceType)) {
                uiModel.addAttribute("selectType", 3);
            } else if ("信息摘要数据".equals(evidenceType)) {
                uiModel.addAttribute("selectType", 4);
            }
        } catch (JSONException e1) {
            // TODO Auto-generated catch block
            e1.printStackTrace();
        }
        uiModel.addAttribute("mevencontent", mevencontent);
        return "basicinformation/evenconrent";
    } else if (type == 5) {
        // 事件详细
        EvidenceEventContent mevencontent = sqlSession.selectOne("com.itrus.portal.db.EvidenceEventContentMapper.selectByPrimaryKey", id);
        // EvidenceBasicInformation basicInformation = basicInformationimpl.selectById(mevencontent.getEvidenceSn());
        EvidenceBasicInformationExample basicEx = new EvidenceBasicInformationExample();
        EvidenceBasicInformationExample.Criteria information = basicEx.createCriteria();
        information.andEvidenceSnEqualTo(mevencontent.getEvidenceSn());
        EvidenceBasicInformation basicInformation = sqlSession.selectOne("com.itrus.portal.db.EvidenceBasicInformationMapper.selectByExample", basicEx);
        EvidenceMainInformation mainInfo = new EvidenceMainInformation();
        // 事件对象
        EvidenceTrustedIdentityExample trustenid = new EvidenceTrustedIdentityExample();
        EvidenceTrustedIdentityExample.Criteria identitye = trustenid.createCriteria();
        // identitye.andBasicInformationEqualTo(mevencontent.getEvidenceSn());// 获取事件对象
        identitye.andEventContentEqualTo(mevencontent.getIdCode());
        // identitye.andMainInformationEqualTo(mid);
        EvidenceTrustedIdentity trusted = sqlSession.selectOne("com.itrus.portal.db.EvidenceTrustedIdentityMapper.selectByExample", trustenid);
        if (trusted != null) {
            String mainName = trusted.getMainInformation().split(";")[0];
            String mainIdentity = trusted.getMainInformation().split(";")[1];
            // 证据主体信息
            EvidenceMainInformationExample infomationE = new EvidenceMainInformationExample();
            EvidenceMainInformationExample.Criteria tionE = infomationE.createCriteria();
            tionE.andIdentificationEqualTo(mainIdentity);
            if (mainName != null) {
                tionE.andSubjectNameEqualTo(mainName);
            }
            List<EvidenceMainInformation> ainInfo = sqlSession.selectList("com.itrus.portal.db.EvidenceMainInformationMapper.selectByExample", infomationE);
            mainInfo = ainInfo.get(0);
        /*mainInfo = sqlSession.selectOne("com.itrus.portal.db.EvidenceMainInformationMapper.selectByPrimaryKey",
						trusted.getMainInformation());*/
        }
        // 事件行为
        EvidenceEventBehaviorExample eventbehaciorEx = new EvidenceEventBehaviorExample();
        EvidenceEventBehaviorExample.Criteria eventbe = eventbehaciorEx.createCriteria();
        eventbe.andEventContentEqualTo(mevencontent.getIdCode());
        // eventbe.andMainInformationEqualTo(mid);
        List<EvidenceEventBehavior> elist = sqlSession.selectList("com.itrus.portal.db.EvidenceEventBehaviorMapper.selectByExample", eventbehaciorEx);
        // 事件时间
        EvidenceEventTimeExample eventime = new EvidenceEventTimeExample();
        EvidenceEventTimeExample.Criteria eventimeEx = eventime.createCriteria();
        eventimeEx.andEventContentEqualTo(mevencontent.getIdCode());
        // eventimeEx.andMainInformationEqualTo(mid);
        List<EvidenceEventTime> meventime = sqlSession.selectList("com.itrus.portal.db.EvidenceEventTimeMapper.selectByExample", eventime);
        // 事件意愿
        EvidenceEventDesireExample desireEx = new EvidenceEventDesireExample();
        EvidenceEventDesireExample.Criteria eventdesire = desireEx.createCriteria();
        eventdesire.andEventContenteEqualTo(mevencontent.getIdCode());
        // eventdesire.andMainInformationEqualTo(mid);
        EvidenceEventDesire meventdesire = sqlSession.selectOne("com.itrus.portal.db.EvidenceEventDesireMapper.selectByExample", desireEx);
        // 事件网络地址
        EvidenceEventNetworkAddressExample network = new EvidenceEventNetworkAddressExample();
        EvidenceEventNetworkAddressExample.Criteria address = network.createCriteria();
        address.andEventContentEqualTo(mevencontent.getIdCode());
        // address.andMainInformationEqualTo(mid);
        EvidenceEventNetworkAddress networkaddress = sqlSession.selectOne("com.itrus.portal.db.EvidenceEventNetworkAddressMapper.selectByExample", network);
        uiModel.addAttribute("mevencontent", mevencontent);
        uiModel.addAttribute("meventdesire", meventdesire);
        uiModel.addAttribute("networkaddress", networkaddress);
        uiModel.addAttribute("basicInformation", basicInformation);
        uiModel.addAttribute("trusted", trusted);
        uiModel.addAttribute("mainInfo", mainInfo);
        uiModel.addAttribute("elist", elist);
        uiModel.addAttribute("meventime", meventime);
        return "basicinformation/certificationdetails";
    } else if (type == 6) {
        // 服务委托人签名信息
        EvidenceClientSignature cliensig = sqlSession.selectOne("com.itrus.portal.db.EvidenceClientSignatureMapper.selectByPrimaryKey", id);
        EvidenceEnclosureExample enclo = new EvidenceEnclosureExample();
        EvidenceEnclosureExample.Criteria enclosureEx = enclo.createCriteria();
        enclosureEx.andEvidenceSnEqualTo(cliensig.getEvidenceSn());
        enclosureEx.andPdfTypeEqualTo("1");
        EvidenceEnclosure enclosure = sqlSession.selectOne("com.itrus.portal.db.EvidenceEnclosureMapper.selectByExample", enclo);
        // 天威签名信息
        EvidenceClientSignatureExample cilentsign = new EvidenceClientSignatureExample();
        EvidenceClientSignatureExample.Criteria signature = cilentsign.createCriteria();
        signature.andEvidenceSnEqualTo(enclosure.getEvidenceSn());
        signature.andNameEqualTo("1");
        EvidenceClientSignature cilentsignature = sqlSession.selectOne("com.itrus.portal.db.EvidenceClientSignatureMapper.selectByExample", cilentsign);
        EvidenceCert oneCert = new EvidenceCert();
        EvidenceCheck oneCheck = new EvidenceCheck();
        if (cilentsignature != null) {
            // 天威证书信息
            /*EvidenceCertExample certE = new EvidenceCertExample();
				EvidenceCertExample.Criteria evidenceCertE = certE.createCriteria();
				evidenceCertE.andClientSignatureEqualTo(cilentsignature.getId());
				oneCert = sqlSession.selectOne("com.itrus.portal.db.EvidenceCertMapper.selectByExample",certE);*/
            oneCert = sqlSession.selectOne("com.itrus.portal.db.EvidenceCertMapper.selectByPrimaryKey", cilentsignature.getCertId());
            // 天威核验信息
            EvidenceCheckExample checkE = new EvidenceCheckExample();
            EvidenceCheckExample.Criteria evidenceCheckE = checkE.createCriteria();
            evidenceCheckE.andClientSignatureEqualTo(cilentsignature.getId());
            oneCheck = sqlSession.selectOne("com.itrus.portal.db.EvidenceCheckMapper.selectByExample", checkE);
        }
        // 服务委托人时间戳信息
        EvidenceClientTimeStampExample clientTime = new EvidenceClientTimeStampExample();
        EvidenceClientTimeStampExample.Criteria stamp = clientTime.createCriteria();
        stamp.andEvidenceSnEqualTo(enclosure.getEvidenceSn());
        stamp.andNameEqualTo("0");
        EvidenceClientTimeStamp clientTimestamp = sqlSession.selectOne("com.itrus.portal.db.EvidenceClientTimeStampMapper.selectByExample", clientTime);
        // 天威时间戳信息
        EvidenceClientTimeStampExample tclientTime = new EvidenceClientTimeStampExample();
        EvidenceClientTimeStampExample.Criteria tstamp = tclientTime.createCriteria();
        tstamp.andEvidenceSnEqualTo(enclosure.getEvidenceSn());
        tstamp.andNameEqualTo("1");
        EvidenceClientTimeStamp tclientTimestamp = sqlSession.selectOne("com.itrus.portal.db.EvidenceClientTimeStampMapper.selectByExample", tclientTime);
        // 服务委托人证书信息
        /*EvidenceCertExample certEx = new EvidenceCertExample();
			EvidenceCertExample.Criteria evidenceCert = certEx.createCriteria();
			evidenceCert.andClientSignatureEqualTo(cliensig.getId());
			List<EvidenceCert> listCert = sqlSession
					.selectList("com.itrus.portal.db.EvidenceCertMapper.selectByExample", certEx);*/
        List<EvidenceCert> listCert = sqlSession.selectList("com.itrus.portal.db.EvidenceCertMapper.selectByPrimaryKey", cliensig.getCertId());
        // 服务委托人核验信息
        EvidenceCheckExample checkEx = new EvidenceCheckExample();
        EvidenceCheckExample.Criteria evidenceCheck = checkEx.createCriteria();
        evidenceCheck.andClientSignatureEqualTo(cliensig.getId());
        EvidenceCheck listCheck = sqlSession.selectOne("com.itrus.portal.db.EvidenceCheckMapper.selectByExample", checkEx);
        Map<Long, EvidenceCheck> mapCheck = new HashMap<Long, EvidenceCheck>();
        // 服务委托人证书核验信息
        for (EvidenceCert c : listCert) {
            EvidenceCheckExample certcheckEx = new EvidenceCheckExample();
            EvidenceCheckExample.Criteria certCheck = certcheckEx.createCriteria();
            certCheck.andEvidenceCertEqualTo(c.getId());
            EvidenceCheck listCertCheck = sqlSession.selectOne("com.itrus.portal.db.EvidenceCheckMapper.selectByExample", certcheckEx);
            mapCheck.put(c.getId(), listCertCheck);
        }
        // 服务委托人证书信息
        uiModel.addAttribute("listCert", listCert);
        // 服务委托人核验信息
        uiModel.addAttribute("listCheck", listCheck);
        // 天威证书信息
        uiModel.addAttribute("oneCert", oneCert);
        // 天威核验信息
        uiModel.addAttribute("oneCheck", oneCheck);
        // 服务委托人证书核验信息
        uiModel.addAttribute("mapCheck", mapCheck);
        // 服务委托人签名信息
        uiModel.addAttribute("cliensig", cliensig);
        // 天威签名信息
        uiModel.addAttribute("cilentsignature", cilentsignature);
        // 服务委托人时间戳信息
        uiModel.addAttribute("clientTimestamp", clientTimestamp);
        // 天威时间戳信息
        uiModel.addAttribute("tclientTimestamp", tclientTimestamp);
        return "basicinformation/evidenceexists";
    }
    /*
			 * else if (type == 7) { EvidenceIndividual indiv = sqlSession
			 * .selectOne(
			 * "com.itrus.portal.db.EvidenceIndividualMapper.selectByPrimaryKey",
			 * id); String cid = indiv.getId().toString(); int evid =
			 * Integer.parseInt(cid); EvidenceRealNameExample realnameE = new
			 * EvidenceRealNameExample(); EvidenceRealNameExample.Criteria
			 * realnameEx = realnameE.createCriteria();
			 * realnameEx.andIndividualEqualTo(evid); EvidenceRealName erealname
			 * = sqlSession .selectOne(
			 * "com.itrus.portal.db.EvidenceRealNameMapper.selectByExample",
			 * realnameE); EvidenceMainInformation mainInfo =
			 * sqlSession.selectOne(
			 * "com.itrus.portal.db.EvidenceMainInformationMapper.selectByPrimaryKey",
			 * erealname.getMainInformation()); uiModel.addAttribute("indiv",
			 * indiv); uiModel.addAttribute("mainInfo", mainInfo); return
			 * "basicinformation/ineividual"; }
			 */
    return null;
}
Also used : EvidenceClientTimeStamp(com.itrus.portal.db.EvidenceClientTimeStamp) RealNameAuthentication(com.itrus.portal.db.RealNameAuthentication) EvidenceClientTimeStampExample(com.itrus.portal.db.EvidenceClientTimeStampExample) BufferedInputStream(java.io.BufferedInputStream) BASE64Decoder(sun.misc.BASE64Decoder) ArrayList(java.util.ArrayList) List(java.util.List) EvidenceEventDesire(com.itrus.portal.db.EvidenceEventDesire) EvidenceEventNetworkAddressExample(com.itrus.portal.db.EvidenceEventNetworkAddressExample) EvidenceEventBehaviorExample(com.itrus.portal.db.EvidenceEventBehaviorExample) EvidenceEnclosureExample(com.itrus.portal.db.EvidenceEnclosureExample) EvidenceCheckExample(com.itrus.portal.db.EvidenceCheckExample) EvidenceSaveServiceExample(com.itrus.portal.db.EvidenceSaveServiceExample) EvidenceCert(com.itrus.portal.db.EvidenceCert) JSONObject(com.alibaba.fastjson.JSONObject) ByteArrayInputStream(java.io.ByteArrayInputStream) FileOutputStream(java.io.FileOutputStream) EvidenceEventTime(com.itrus.portal.db.EvidenceEventTime) File(java.io.File) EvidenceEventNetworkAddress(com.itrus.portal.db.EvidenceEventNetworkAddress) Map(java.util.Map) HashMap(java.util.HashMap) EvidenceBasicInformation(com.itrus.portal.db.EvidenceBasicInformation) EvidenceSaveService(com.itrus.portal.db.EvidenceSaveService) EvidenceEnclosure(com.itrus.portal.db.EvidenceEnclosure) EvidenceMainInformation(com.itrus.portal.db.EvidenceMainInformation) EvidenceEventDesireExample(com.itrus.portal.db.EvidenceEventDesireExample) EvidenceEventTimeExample(com.itrus.portal.db.EvidenceEventTimeExample) BufferedOutputStream(java.io.BufferedOutputStream) BASE64Decoder(sun.misc.BASE64Decoder) EvidenceEventContent(com.itrus.portal.db.EvidenceEventContent) EvidenceClientSignature(com.itrus.portal.db.EvidenceClientSignature) AppService(com.itrus.portal.db.AppService) EvidenceCheck(com.itrus.portal.db.EvidenceCheck) JSONArray(org.json.JSONArray) JSONException(org.json.JSONException) IOException(java.io.IOException) EvidenceClientSignatureExample(com.itrus.portal.db.EvidenceClientSignatureExample) JSONException(org.json.JSONException) IOException(java.io.IOException) EvidenceBasicInformationExample(com.itrus.portal.db.EvidenceBasicInformationExample) EvidenceEventBehavior(com.itrus.portal.db.EvidenceEventBehavior) EvidenceTrustedIdentity(com.itrus.portal.db.EvidenceTrustedIdentity) EvidenceMainInformationExample(com.itrus.portal.db.EvidenceMainInformationExample) EvidenceTrustedIdentityExample(com.itrus.portal.db.EvidenceTrustedIdentityExample) RequestMapping(org.springframework.web.bind.annotation.RequestMapping)

Example 8 with EvidenceMainInformationExample

use of com.itrus.portal.db.EvidenceMainInformationExample in project portal by ixinportal.

the class BasicInformationController method show1.

/**
 * 身份认证详情
 *
 * @param id
 * @param uiModel
 * @return
 */
@RequestMapping(value = "/identity/{id}", produces = "text/html")
public String show1(@PathVariable("id") Long id, Model uiModel) {
    // 得到证据详情
    EvidenceBasicInformation basicinfor = sqlSession.selectOne("com.itrus.portal.db.EvidenceBasicInformationMapper.selectByPrimaryKey", id);
    List<EvidenceMainInformation> mlist = new ArrayList<EvidenceMainInformation>();
    // 得到主体身份信息
    EvidenceSubjectIdentityExample subjectExample = new EvidenceSubjectIdentityExample();
    EvidenceSubjectIdentityExample.Criteria identity = subjectExample.createCriteria();
    identity.andBasicInformationEqualTo(basicinfor.getEvidenceSn());
    List<EvidenceSubjectIdentity> subjectIdentity = sqlSession.selectList("com.itrus.portal.db.EvidenceSubjectIdentityMapper.selectByExample", subjectExample);
    for (int i = 0; i < subjectIdentity.size(); i++) {
        // 得到主体信息
        /*List<EvidenceMainInformation> mainInfo = sqlSession.selectList(
					"com.itrus.portal.db.EvidenceMainInformationMapper.selectByPrimaryKey",
					subjectIdentity.get(i).getMainInformation());*/
        EvidenceMainInformationExample infomationE = new EvidenceMainInformationExample();
        EvidenceMainInformationExample.Criteria tionE = infomationE.createCriteria();
        tionE.andIdentificationEqualTo(subjectIdentity.get(i).getMainInformation());
        // infomationE.isDistinct();
        if (subjectIdentity.get(i).getMainName() != null) {
            tionE.andSubjectNameEqualTo(subjectIdentity.get(i).getMainName());
        }
        List<EvidenceMainInformation> mainInfo = sqlSession.selectList("com.itrus.portal.db.EvidenceMainInformationMapper.selectByExample", infomationE);
        if (mainInfo.size() != 0) {
            mlist.add(mainInfo.get(0));
        }
    // mlist.add(mainInfo);
    }
    // 得到身份意愿鉴别
    EvidenceDesireIdentifyExample desireid = new EvidenceDesireIdentifyExample();
    EvidenceDesireIdentifyExample.Criteria desireidentitfy = desireid.createCriteria();
    desireidentitfy.andEvidenceSnEqualTo(basicinfor.getEvidenceSn());
    EvidenceDesireIdentify desire = sqlSession.selectOne("com.itrus.portal.db.EvidenceDesireIdentifyMapper.selectByExample", desireid);
    // 得到证据附件信息,用于查询服务委托人等信息
    EvidenceEnclosureExample enclou = new EvidenceEnclosureExample();
    EvidenceEnclosureExample.Criteria sure = enclou.createCriteria();
    // sure.andBasicInformationEqualTo(id);
    sure.andEvidenceSnEqualTo(basicinfor.getEvidenceSn());
    sure.andPdfTypeEqualTo("1");
    EvidenceEnclosure enclosure = sqlSession.selectOne("com.itrus.portal.db.EvidenceEnclosureMapper.selectByExample", enclou);
    if (enclosure != null) {
        // 服务委托人签名信息
        EvidenceClientSignatureExample client = new EvidenceClientSignatureExample();
        EvidenceClientSignatureExample.Criteria signat = client.createCriteria();
        signat.andEvidenceSnEqualTo(enclosure.getEvidenceSn());
        signat.andNameEqualTo("0");
        EvidenceClientSignature cliensig = sqlSession.selectOne("com.itrus.portal.db.EvidenceClientSignatureMapper.selectByExample", client);
        // 天威签名信息
        EvidenceClientSignatureExample cilentsign = new EvidenceClientSignatureExample();
        EvidenceClientSignatureExample.Criteria signature = cilentsign.createCriteria();
        signature.andEvidenceSnEqualTo(enclosure.getEvidenceSn());
        signature.andNameEqualTo("1");
        EvidenceClientSignature cilentsignature = sqlSession.selectOne("com.itrus.portal.db.EvidenceClientSignatureMapper.selectByExample", cilentsign);
        if (cilentsignature != null) {
            // 天威证书信息
            /*EvidenceCertExample certE = new EvidenceCertExample();
				EvidenceCertExample.Criteria evidenceCertE = certE.createCriteria();
				evidenceCertE.andClientSignatureEqualTo(cilentsignature.getId());*/
            EvidenceCert oneCert = sqlSession.selectOne("com.itrus.portal.db.EvidenceCertMapper.selectByPrimaryKey", cilentsignature.getCertId());
            // 天威核验信息
            EvidenceCheckExample checkE = new EvidenceCheckExample();
            EvidenceCheckExample.Criteria evidenceCheckE = checkE.createCriteria();
            evidenceCheckE.andClientSignatureEqualTo(cilentsignature.getId());
            EvidenceCheck oneCheck = sqlSession.selectOne("com.itrus.portal.db.EvidenceCheckMapper.selectByExample", checkE);
            // 天威证书信息
            uiModel.addAttribute("oneCert", oneCert);
            // 天威核验信息
            uiModel.addAttribute("oneCheck", oneCheck);
        }
        // 服务委托人时间戳信息
        EvidenceClientTimeStampExample clientTime = new EvidenceClientTimeStampExample();
        EvidenceClientTimeStampExample.Criteria stamp = clientTime.createCriteria();
        stamp.andEvidenceSnEqualTo(enclosure.getEvidenceSn());
        stamp.andNameEqualTo("0");
        EvidenceClientTimeStamp clientTimestamp = sqlSession.selectOne("com.itrus.portal.db.EvidenceClientTimeStampMapper.selectByExample", clientTime);
        // 天威时间戳信息
        EvidenceClientTimeStampExample tclientTime = new EvidenceClientTimeStampExample();
        EvidenceClientTimeStampExample.Criteria tstamp = tclientTime.createCriteria();
        tstamp.andEvidenceSnEqualTo(enclosure.getEvidenceSn());
        tstamp.andNameEqualTo("1");
        EvidenceClientTimeStamp tclientTimestamp = sqlSession.selectOne("com.itrus.portal.db.EvidenceClientTimeStampMapper.selectByExample", tclientTime);
        EvidenceCheck listCheck = new EvidenceCheck();
        List<EvidenceCert> listCert = new ArrayList<EvidenceCert>();
        if (cliensig != null && cliensig.getId() != null) {
            // 服务委托人证书信息
            /*EvidenceCertExample certEx = new EvidenceCertExample();
				EvidenceCertExample.Criteria evidenceCert = certEx.createCriteria();
				evidenceCert.andClientSignatureEqualTo(cliensig.getId());*/
            listCert = sqlSession.selectList("com.itrus.portal.db.EvidenceCertMapper.selectByPrimaryKey", cliensig.getCertId());
            // 服务委托人核验信息
            EvidenceCheckExample checkEx = new EvidenceCheckExample();
            EvidenceCheckExample.Criteria evidenceCheck = checkEx.createCriteria();
            evidenceCheck.andClientSignatureEqualTo(cliensig.getId());
            listCheck = sqlSession.selectOne("com.itrus.portal.db.EvidenceCheckMapper.selectByExample", checkEx);
        }
        Map<Long, EvidenceCheck> mapCheck = new HashMap<Long, EvidenceCheck>();
        // 服务委托人证书核验信息
        for (EvidenceCert c : listCert) {
            EvidenceCheckExample certcheckEx = new EvidenceCheckExample();
            EvidenceCheckExample.Criteria certCheck = certcheckEx.createCriteria();
            certCheck.andEvidenceCertEqualTo(c.getId());
            EvidenceCheck listCertCheck = sqlSession.selectOne("com.itrus.portal.db.EvidenceCheckMapper.selectByExample", certcheckEx);
            mapCheck.put(c.getId(), listCertCheck);
        }
        // 服务委托人证书信息
        uiModel.addAttribute("listCert", listCert);
        // 服务委托人核验信息
        uiModel.addAttribute("listCheck", listCheck);
        // 服务委托人证书核验信息
        uiModel.addAttribute("mapCheck", mapCheck);
        // 服务委托人签名信息
        uiModel.addAttribute("cliensig", cliensig);
        // 天威签名信息
        uiModel.addAttribute("cilentsignature", cilentsignature);
        // 服务委托人时间戳信息
        uiModel.addAttribute("clientTimestamp", clientTimestamp);
        // 天威时间戳信息
        uiModel.addAttribute("tclientTimestamp", tclientTimestamp);
    }
    // 身份实名认证信息
    EvidenceRealNameExample realnameE = new EvidenceRealNameExample();
    EvidenceRealNameExample.Criteria realnameEx = realnameE.createCriteria();
    // realnameEx.andMainInformationEqualTo(m.getId());
    // realnameEx.andBasicInformationEqualTo(id);
    realnameEx.andEvidenceSnEqualTo(basicinfor.getEvidenceSn());
    EvidenceRealName erealname = sqlSession.selectOne("com.itrus.portal.db.EvidenceRealNameMapper.selectByExample", realnameE);
    Map<Long, AppService> rappService = new HashMap<Long, AppService>();
    if (erealname != null) {
        uiModel.addAttribute("erealname", erealname);
        if ("2".equals(erealname.getEventVerifierType()) || "3".equals(erealname.getEventVerifierType())) {
            // 判断平台
            if ("1".equals(erealname.getType())) {
                EvidenceCompaniesSubmitExample evidenceCompanies = new EvidenceCompaniesSubmitExample();
                EvidenceCompaniesSubmitExample.Criteria submit = evidenceCompanies.createCriteria();
                submit.andIdCodeEqualTo(erealname.getCompaniesSubmit());
                EvidenceCompaniesSubmit companiesSubmit = sqlSession.selectOne("com.itrus.portal.db.EvidenceCompaniesSubmitMapper.selectByExample", evidenceCompanies);
                if (companiesSubmit != null && companiesSubmit.getRepresentative() != null) {
                    // 法定代表人
                    EvidenceRepresentativeExample representaioce = new EvidenceRepresentativeExample();
                    EvidenceRepresentativeExample.Criteria evidenceRepresent = representaioce.createCriteria();
                    evidenceRepresent.andIdCodeEqualTo(companiesSubmit.getRepresentative());
                    EvidenceRepresentative representative = sqlSession.selectOne("com.itrus.portal.db.EvidenceRepresentativeMapper.selectByExample", representaioce);
                    uiModel.addAttribute("representative", representative);
                }
                if (companiesSubmit != null && companiesSubmit.getTheAgent() != null) {
                    // 代理人
                    EvidenceTheAgentExample evidenceTheAgent = new EvidenceTheAgentExample();
                    EvidenceTheAgentExample.Criteria theAgentEx = evidenceTheAgent.createCriteria();
                    theAgentEx.andIdCodeEqualTo(companiesSubmit.getTheAgent());
                    EvidenceTheAgent theagent = sqlSession.selectOne("com.itrus.portal.db.EvidenceTheAgentMapper.selectByExample", evidenceTheAgent);
                    uiModel.addAttribute("theagent", theagent);
                }
                uiModel.addAttribute("companiesSubmit", companiesSubmit);
            } else {
                // 天威
                EvidenceIndividualExample evidenceIndividual = new EvidenceIndividualExample();
                EvidenceIndividualExample.Criteria individual = evidenceIndividual.createCriteria();
                individual.andIdCodeEqualTo(erealname.getIndividual());
                EvidenceIndividual indiv = sqlSession.selectOne("com.itrus.portal.db.EvidenceIndividualMapper.selectByExample", evidenceIndividual);
                uiModel.addAttribute("indiv", indiv);
            }
        } else if ("1".equals(erealname.getEventVerifierType())) {
            // 天威
            if ("1".equals(erealname.getType())) {
                // 获取流水号
                String serialnamber = erealname.getSerialnumber();
                // 将多个流水号以逗号分隔成一个数组
                String[] namber = serialnamber.split(",");
                // 声明一个list存储流水号
                List<String> listString = new ArrayList<String>();
                for (int i = 0; i < namber.length; i++) {
                    // 将数组中的流水号放入list中
                    listString.add(namber[i]);
                }
                // 查询实名认证信息
                RealNameRecordExample realname = new RealNameRecordExample();
                RealNameRecordExample.Criteria recor = realname.createCriteria();
                recor.andSerialnumberIn(listString);
                realname.setOrderByClause("returntime");
                listReal = sqlSession.selectList("com.itrus.portal.db.RealNameRecordMapper.selectByExample", realname);
                for (RealNameRecord real : listReal) {
                    AppServiceAuthentication authent = sqlSession.selectOne("com.itrus.portal.db.AppServiceAuthenticationMapper.selectByPrimaryKey", real.getAppServiceAuthentication());
                    // 得到服务编码
                    AppService appservice = appService.selectById(authent.getAppService());
                    rappService.put(real.getId(), appservice);
                }
            // realnameRecor.put(m.getId(), listReal);
            } else {
                String serialnamber = erealname.getSerialnumber();
                String[] namber = serialnamber.split(",");
                List<String> listString = new ArrayList<String>();
                for (int i = 0; i < namber.length; i++) {
                    listString.add(namber[i]);
                // listReal.add(realnameRecor1);
                }
                PersonalNameExample personal = new PersonalNameExample();
                PersonalNameExample.Criteria personalname = personal.createCriteria();
                personalname.andSerialnumberIn(listString);
                personal.setOrderByClause("returntime");
                listPersonal = sqlSession.selectList("com.itrus.portal.db.PersonalNameMapper.selectByExample", personal);
                uiModel.addAttribute("listPersonal", listPersonal);
            // personalName.put(m.getId(), listPersonal);
            }
        }
    }
    uiModel.addAttribute("enclosure", enclosure);
    uiModel.addAttribute("rappService", rappService);
    uiModel.addAttribute("listReal", listReal);
    uiModel.addAttribute("desire", desire);
    uiModel.addAttribute("mainInfo", mlist);
    uiModel.addAttribute("basicinfor", basicinfor);
    return "basicinformation/show1";
}
Also used : EvidenceIndividual(com.itrus.portal.db.EvidenceIndividual) EvidenceSubjectIdentityExample(com.itrus.portal.db.EvidenceSubjectIdentityExample) HashMap(java.util.HashMap) EvidenceClientTimeStamp(com.itrus.portal.db.EvidenceClientTimeStamp) PersonalNameExample(com.itrus.portal.db.PersonalNameExample) ArrayList(java.util.ArrayList) EvidenceRealName(com.itrus.portal.db.EvidenceRealName) EvidenceClientTimeStampExample(com.itrus.portal.db.EvidenceClientTimeStampExample) ArrayList(java.util.ArrayList) List(java.util.List) EvidenceCompaniesSubmitExample(com.itrus.portal.db.EvidenceCompaniesSubmitExample) EvidenceDesireIdentify(com.itrus.portal.db.EvidenceDesireIdentify) EvidenceSubjectIdentity(com.itrus.portal.db.EvidenceSubjectIdentity) EvidenceEnclosureExample(com.itrus.portal.db.EvidenceEnclosureExample) EvidenceCheckExample(com.itrus.portal.db.EvidenceCheckExample) RealNameRecord(com.itrus.portal.db.RealNameRecord) AppServiceAuthentication(com.itrus.portal.db.AppServiceAuthentication) EvidenceCert(com.itrus.portal.db.EvidenceCert) EvidenceRepresentative(com.itrus.portal.db.EvidenceRepresentative) EvidenceIndividualExample(com.itrus.portal.db.EvidenceIndividualExample) EvidenceRealNameExample(com.itrus.portal.db.EvidenceRealNameExample) EvidenceBasicInformation(com.itrus.portal.db.EvidenceBasicInformation) EvidenceEnclosure(com.itrus.portal.db.EvidenceEnclosure) EvidenceMainInformation(com.itrus.portal.db.EvidenceMainInformation) EvidenceTheAgent(com.itrus.portal.db.EvidenceTheAgent) EvidenceDesireIdentifyExample(com.itrus.portal.db.EvidenceDesireIdentifyExample) EvidenceCompaniesSubmit(com.itrus.portal.db.EvidenceCompaniesSubmit) EvidenceClientSignature(com.itrus.portal.db.EvidenceClientSignature) AppService(com.itrus.portal.db.AppService) EvidenceCheck(com.itrus.portal.db.EvidenceCheck) EvidenceClientSignatureExample(com.itrus.portal.db.EvidenceClientSignatureExample) EvidenceTheAgentExample(com.itrus.portal.db.EvidenceTheAgentExample) EvidenceRepresentativeExample(com.itrus.portal.db.EvidenceRepresentativeExample) EvidenceMainInformationExample(com.itrus.portal.db.EvidenceMainInformationExample) RealNameRecordExample(com.itrus.portal.db.RealNameRecordExample) RequestMapping(org.springframework.web.bind.annotation.RequestMapping)

Aggregations

EvidenceMainInformation (com.itrus.portal.db.EvidenceMainInformation)8 EvidenceMainInformationExample (com.itrus.portal.db.EvidenceMainInformationExample)8 ArrayList (java.util.ArrayList)7 HashMap (java.util.HashMap)7 EvidenceBasicInformation (com.itrus.portal.db.EvidenceBasicInformation)6 EvidenceSubjectIdentity (com.itrus.portal.db.EvidenceSubjectIdentity)6 EvidenceEnclosure (com.itrus.portal.db.EvidenceEnclosure)5 EvidenceEnclosureExample (com.itrus.portal.db.EvidenceEnclosureExample)5 EvidenceEventContent (com.itrus.portal.db.EvidenceEventContent)5 EvidenceTrustedIdentity (com.itrus.portal.db.EvidenceTrustedIdentity)5 List (java.util.List)5 RequestMapping (org.springframework.web.bind.annotation.RequestMapping)5 EvidenceCert (com.itrus.portal.db.EvidenceCert)4 EvidenceCheck (com.itrus.portal.db.EvidenceCheck)4 EvidenceCheckExample (com.itrus.portal.db.EvidenceCheckExample)4 EvidenceClientSignature (com.itrus.portal.db.EvidenceClientSignature)4 EvidenceClientTimeStamp (com.itrus.portal.db.EvidenceClientTimeStamp)4 EvidenceCompaniesSubmit (com.itrus.portal.db.EvidenceCompaniesSubmit)4 EvidenceDesireIdentify (com.itrus.portal.db.EvidenceDesireIdentify)4 EvidenceEventDesire (com.itrus.portal.db.EvidenceEventDesire)4