数据源导入人员和组织,该代码仅作为demo,请根据自己的业务进行修改

首先创建一个数据源,然后测试连接成功,添加完数据源需要重新启动应用才会生效


导入部门

  • 导入部门代码controller
 @Autowired
 DepartmentImportService departmentImportService;

@RequestMapping(value = {"/doImportDepartment"}, method = {RequestMethod.POST},
        produces = {"application/json; charset=utf-8"})
    @ResponseBody
    public BaseRespResult doImportDepartment(MethodArgument param) throws SQLException {
        //数据源的名称
        String dsName = param.getRequest().getParameter("dsName");
        //插入数据的表
        String tabelCode = param.getRequest().getParameter("tableCode");
        //自定义参数,可以在parser中获取
        JSONObject customParameters = new JSONObject();
        if (Strings.isNullOrEmpty(dsName)) {
            return BaseRespResult.errorResult("请指定数据源!");
        }
        DataSource departDataSource = null;
        if (departDataSource == null) {
            return BaseRespResult.errorResult("没有找到指定数据源!");
        }
        // 查询三方库的sql
        String sql = "SELECT * FROM JE_CORE_DEPARTMENT WHERE DEPTNAME!='ROOT'";
        DataSourceImportSource dataSourceImportSource = new DataSourceImportSource(departDataSource, sql, tabelCode);
        //创建自定义格式化parser,传入doImport中,进行导入
        DepartmentImportParser departmentImportParser = new DepartmentImportParser();
        //传入参数  dataSourceImportSource数据源 departmentImportParser格式化类 customParameters自定义参数json格式,可以在departmentImportParser中获取到
        departmentImportService.doImport(dataSourceImportSource, departmentImportParser, customParameters);
        return BaseRespResult.successResult("导入成功!");
    }
  • 导入部门代码service
/**
 * 该类继承AbstractDynaBeanImportService,实现自定义排序
 */
public class DepartmentImportService extends AbstractDynaBeanImportService {
    @Override
    public List<DynaBean> doSort(List<DynaBean> dynaBeans) {
        return dynaBeans;
    }
}
  • 部门格式化方法DepartmentImportParser
public class DepartmentImportParser extends AbstractDynaBeanImportParser {

    @Override
    public ParseVo parse(DynaBean deptMent, JSONObject customParameters) {
        MetaService metaService = SpringContextHolder.getBean(MetaServiceImpl.class);
        deptMent.setStr(BeanUtils.KEY_TABLE_CODE, "JE_CORE_DEPARTMENT");
        // 部门类型
        String rankName = deptMent.getStr("RANKNAME");
        DynaBean deptMentType = metaService.selectOne("JE_CORE_DICTIONARYITEM",
            ConditionsWrapper.builder().eq("DICTIONARYITEM_ITEMNAME", rankName).apply(
                " AND DICTIONARYITEM_DICTIONARY_ID=(select JE_CORE_DICTIONARY_ID from JE_CORE_DICTIONARY WHERE DICTIONARY_DDCODE='JE_GSJB')"),
            "DICTIONARYITEM_ITEMCODE");
        if (deptMentType == null) {
            deptMent.setStr("RANKCODE", "BM");
            deptMent.setStr("RANKNAME", "部门");
        } else {
            deptMent.setStr("RANKCODE", deptMentType.getStr("DICTIONARYITEM_ITEMCODE"));
        }
        String deptNames = deptMent.getStr("DEPTNAME");
        String[] names;
        if (deptNames.indexOf(";") >= 0) {
            String[] szDeptNames = deptNames.split(";");
            for (int i = 1; i < szDeptNames.length; i++) {
                DynaBean newDeptMent = deptMent.setStr("DEPTNAME", szDeptNames[i]);
                parse(newDeptMent, customParameters);
            }
            names = szDeptNames[0].split("/");
        } else {
            names = deptNames.split("/");
        }
        // 上级部门名称
        String parentDeptId = addParentDept(names);
        if (Strings.isNullOrEmpty(parentDeptId)) {
            parentDeptId = "ROOT";
        }
        DynaBean parentDept = metaService.selectOne("JE_CORE_DEPARTMENT",
            ConditionsWrapper.builder().eq("DEPTID", parentDeptId), "DEPTCODE,DEPTNAME,DEPTID,PATH,TREEORDERINDEX");
        if (parentDept == null) {
            parentDept = metaService.selectOne("JE_CORE_DEPARTMENT", ConditionsWrapper.builder().eq("DEPTID", "ROOT"),
                "DEPTCODE,DEPTNAME,DEPTID,PATH,TREEORDERINDEX");
        }
        deptMent.setStr("DEPTNAME", names[names.length - 1]);
        deptMent.setStr("DEPTID", JEUUID.uuid());
        deptMent.setStr("DEPTCODE", JEUUID.uuid());
        deptMent.setStr("PARENTCODE", parentDept.getStr("DEPTCODE"));
        deptMent.setStr("PARENTNAME", parentDept.getStr("DEPTNAME"));
        deptMent.setStr("PARENT", parentDept.getStr("DEPTID"));
        deptMent.setStr("PARENTPATH", parentDept.getStr("PATH"));
        deptMent.setStr("PATH", String.format("%s/%s", parentDept.getStr("PATH"), deptMent.getStr("DEPTID")));
        deptMent.setStr("NODETYPE", "LEAF");
        deptMent = buildDeptInfo(deptMent, parentDept);
        return new ParseVo(deptMent, false);
    }

    private static String addParentDept(String[] names) {
        String[] newNames = new String[names.length - 1];
        for (int i = 0; i < newNames.length; i++) {
            newNames[i] = names[i];
        }
        MetaService metaService = SpringContextHolder.getBean(MetaServiceImpl.class);
        String parentId = "ROOT";
        for (String name : newNames) {
            DynaBean dept = metaService.selectOne("JE_CORE_DEPARTMENT",
                ConditionsWrapper.builder().eq("DEPTNAME", name).like("PARENT", parentId),
                "DEPTCODE,DEPTNAME,DEPTID,PATH,TREEORDERINDEX");
            if (dept == null) {
                if (name.equals("北京科技学院")) {
                    parentId = "ROOT";
                }
                dept = new DynaBean("JE_CORE_DEPARTMENT", true);
                DynaBean parentDept = metaService.selectOne("JE_CORE_DEPARTMENT",
                    ConditionsWrapper.builder().eq("DEPTID", parentId), "DEPTCODE,DEPTNAME,DEPTID,PATH,TREEORDERINDEX");
                parentId = JEUUID.uuid();
                dept.setStr("DEPTNAME", name);
                dept.setStr("DEPTID", parentId);
                dept.setStr("DEPTCODE", parentId);
                dept.setStr("PARENTCODE", parentDept.getStr("DEPTCODE"));
                dept.setStr("PARENTNAME", parentDept.getStr("DEPTNAME"));
                dept.setStr("PARENT", parentDept.getStr("DEPTID"));
                dept.setStr("PARENTPATH", parentDept.getStr("PATH"));
                dept.setStr("PATH", String.format("%s/%s", parentDept.getStr("PATH"), dept.getStr("DEPTID")));
                dept.setStr("NODETYPE", "LEAF");
                dept = buildDeptInfo(dept, parentDept);
            }
            parentId = dept.getStr("DEPTID");
        }
        return parentId;
    }

    private static DynaBean buildDeptInfo(DynaBean deptMent, DynaBean parentDept) {
        MetaService metaService = SpringContextHolder.getBean(MetaServiceImpl.class);
        PCDynaServiceTemplate pcDynaServiceTemplate = SpringContextHolder.getBean(PCDynaServiceTemplate.class);
        RoleManager roleManager = SpringContextHolder.getBean(RoleManager.class);
        pcDynaServiceTemplate.buildModelCreateInfo(deptMent);
        EndUser endUser = SecurityUserHolder.getCurrentUser();
        deptMent.setStr("CREATEORG", endUser.getDeptCode());
        deptMent.setStr("CREATEORGNAME", endUser.getDeptName());
        deptMent.setStr("MODIFYTIME", deptMent.getStr("SY_CREATETIME"));
        deptMent.setStr("CREATETIME", deptMent.getStr("SY_CREATETIME"));
        deptMent.setStr("CREATEUSER", endUser.getUserCode());
        deptMent.setStr("CREATEUSER", endUser.getUsername());
        deptMent.setStr("JTGSMC", endUser.getJtgsMc());
        deptMent.setStr("JTGSDM", endUser.getJtgsDm());
        deptMent.setStr("JTGSID", endUser.getJtgsId());
        deptMent.setStr("GSBMID", endUser.getGsbmId());
        deptMent.setStr("RANKCODE", "BM");
        deptMent.setStr("RANKNAME", "部门");
        deptMent.setStr("ORDERINDEX", deptMent.getStr("DISPLAY_ORDER"));
        deptMent.setStr("ZHID", endUser.getZhId());
        deptMent.setStr("ZHMC", endUser.getZhMc());
        deptMent.setStr("CREATEORG", endUser.getDeptCode());
        deptMent.setStr("CREATEORGNAME", endUser.getDeptName());
        deptMent.setStr("STATUS", "1");
        deptMent.setStr("LAYER", "1");
        deptMent.set("TREEORDERINDEX", parentDept.get("TREEORDERINDEX"));
        roleManager.generateTreeOrderIndex(deptMent);
        metaService.insert(deptMent);
        if (parentDept.getStr("NODETYPE").equals("LEAF")) {
            parentDept.setStr("NODETYPE", "GENERAL");
            metaService.update(parentDept);
        }
        return deptMent;
    }

导入人员

  • 导入人员代码controller
 @Autowired
 UserImportService userImportService;

    @RequestMapping(value = {"/doImportUser"}, method = {RequestMethod.POST},
        produces = {"application/json; charset=utf-8"})
    @ResponseBody
    public BaseRespResult doImportUser(MethodArgument param) throws SQLException {
        //数据源名称
        String dsName = param.getRequest().getParameter("dsName");
        //导入数据的表明
        String tableCode = param.getRequest().getParameter("tableCode");
        JSONObject customParameters = new JSONObject();
        if (Strings.isNullOrEmpty(dsName)) {
            return BaseRespResult.errorResult("请指定数据源!");
        }
        DataSource departDataSource = SpringContextHolder.getBean(dsName);
        if (departDataSource == null) {
            return BaseRespResult.errorResult("没有找到指定数据源!");
        }
        //查询的sql
        String sql = "SELECT * FROM JE_CORE_ENDUSER  WHERE USERCODE!='admin'";
        DataSourceImportSource dataSourceImportSource = new DataSourceImportSource(departDataSource, sql, tableCode);
        //自定义格式化方法
        EndUserImportParser endUserImportParser = new EndUserImportParser();
        userImportService.doImport(dataSourceImportSource, endUserImportParser, customParameters);
        return BaseRespResult.successResult("导入成功!");
    }
  • 导入人员代码service
@Component
public class UserImportService extends AbstractDynaBeanImportService {

    @Override
    public List<DynaBean> doSort(List<DynaBean> dynaBeans) {
        return dynaBeans;
    }

}
  • 人员格式化方法EndUserImportParser
@Override
    public ParseVo parse(DynaBean user, JSONObject customParameters) {
        MetaService metaService = SpringContextHolder.getBean(MetaService.class);
        user.setStr(BeanUtils.KEY_TABLE_CODE, "JE_CORE_ENDUSER");
        String userCode = user.getStr("USERCODE");
        // 处理登录名重复
        int count = metaService.select("JE_CORE_ENDUSER", ConditionsWrapper.builder().eq("USERCODE", userCode)).size();
        if (count > 0) {
            return new ParseVo(null, false);
        }
        user.setStr("BACKUSERCODE", userCode);
        user.setStr("USERCODE", userCode);
        String birthday = user.getStr("BIRTHDAY");
        if (Strings.isNullOrEmpty(birthday)) {
            birthday = DateUtils.formatDate(DateUtils.getDate(birthday, DateUtils.DAFAULT_DATE_FORMAT),
                DateUtils.DAFAULT_DATE_FORMAT);
            // 生日
            user.setStr("BIRTHDAY", birthday);
        }
        // 邮箱
        user.setStr("COMPANYEMAIL", user.getStr("COMPANYEMAIL"));
        // 固话
        String tel = user.getStr("PHONE");
        user.setStr("ZUOJI", tel);
        // 认证手机号
        String phone = user.getStr("PHONE");
        user.setStr("IDENTPHONE", phone);
        // 手机号
        user.setStr("PHONE", phone);
        // 性别
        if (!Strings.isNullOrEmpty(user.getStr("GENDER"))) {
            DynaBean genderInfos = metaService.selectOne("JE_CORE_DICTIONARYITEM",
                ConditionsWrapper.builder().eq("DICTIONARYITEM_ITEMNAME", user.getStr("GENDER")).apply(
                    " AND DICTIONARYITEM_DICTIONARY_ID=(select JE_CORE_DICTIONARY_ID from JE_CORE_DICTIONARY WHERE DICTIONARY_DDCODE='JE_SEX')"),
                "DICTIONARYITEM_ITEMCODE");
            user.setStr("GENDER", genderInfos.getStr("DICTIONARYITEM_ITEMCODE"));
        } else {
            user.setStr("GENDER", "MAN");
        }
        // 密码
        Md5PasswordEncoder md5 = new Md5PasswordEncoder();
        String defaulePassWord =
            md5.encodePassword(StringUtil.getDefaultValue(WebUtils.getSysVar("JE_SYS_PASSWORD"), "123456"), null);
        user.set("PASSWORD", defaulePassWord);
        //
        user.set("ISMANAGER", "0");
        buildUserDeptInfo(user, metaService);
        // buildUserRoleInfo(user, metaService);
        // true 插入 false不插入
        return new ParseVo(user, false);
    }

    /**
     * 部门信息
     *
     * @param user
     */
    private void buildUserDeptInfo(DynaBean user, MetaService metaService) {
        String deptName = user.getStr("DEPTNAME");
        String[] deptAllNames = deptName.split(";");
        for(String deptAllName : deptAllNames){
            user.setStr("USERID",JEUUID.uuid());
            String[] deptNames = deptAllName.split("/");
            deptName = deptNames[deptNames.length - 1];
            DynaBean dept = null;
            List<DynaBean> depts =
                    metaService.select("JE_CORE_DEPARTMENT", ConditionsWrapper.builder().eq("DEPTNAME", deptName));
            if (depts.size() == 1) {
                dept = depts.get(0);
            } else if (depts.size() > 1) {
                String deptId = "";
                String parentDeptId = "";
                int i = 0;
                for (String str : deptNames) {
                    DynaBean addDept = new DynaBean();
                    if (i == 0) {
                        addDept =
                                metaService.selectOne("JE_CORE_DEPARTMENT", ConditionsWrapper.builder().eq("DEPTNAME", str));
                        parentDeptId = addDept.getStr("DEPTID");
                        deptId = addDept.getStr("DEPTID");
                    } else {
                        parentDeptId = metaService
                                .selectOne("JE_CORE_DEPARTMENT",
                                        ConditionsWrapper.builder().eq("DEPTNAME", str).eq("PARENT", parentDeptId))
                                .getStr("DEPTID");
                        deptId = parentDeptId;
                    }
                    i++;
                }
                dept = metaService.selectOne("JE_CORE_DEPARTMENT", ConditionsWrapper.builder().eq("DEPTID", deptId));
            }
            if (dept == null) {
                dept = metaService.selectOne("JE_CORE_DEPARTMENT", ConditionsWrapper.builder().eq("DEPTNAME", "系统管理部"));
            }
            user.setStr("DEPTCODE", dept.getStr("DEPTCODE"));
            user.setStr("DEPTNAME", dept.getStr("DEPTNAME"));
            user.setStr("DEPTID", dept.getStr("DEPTID"));
            user.setStr("DEPTORDERINDEX", dept.getStr("TREEORDERINDEX"));
            buildUserCreateInfo(user);
            metaService.insert(user);
        }
    }

    /**
     * 角色信息
     *
     * @param user
     */
    private void buildUserRoleInfo(DynaBean user, MetaService metaService) {
        String roleNames = user.getStr("ROLENAMES");
        List<String> roleNamesList = Arrays.asList(roleNames.split(","));
        List<DynaBean> role = metaService.select("JE_CORE_ROLE",
            ConditionsWrapper.builder().in("ROLENAME", roleNamesList).eq("ROLETYPE", "ROLE").groupBy("ROLENAME"));
        if (role.size() == 0) {
            throw new RuntimeException(roleNames + "角色没有找到数据异常!");
        }
        StringBuffer roleIds = new StringBuffer();
        StringBuffer roleNamesStr = new StringBuffer();
        StringBuffer roleCodes = new StringBuffer();
        for (DynaBean roleDynaBean : role) {
            DynaBean roleUser = new DynaBean("JE_CORE_ROLE_USER", true);
            roleUser.setStr("USERID", user.getStr("USERID"));
            roleUser.setStr("ROLEID", roleDynaBean.getStr("ROLEID"));
            metaService.insert(roleUser);
            if (Strings.isNullOrEmpty(roleIds.toString())) {
                roleIds.append(roleDynaBean.getStr("ROLEID"));
                roleNamesStr.append(roleDynaBean.getStr("ROLENAME"));
                roleCodes.append(roleDynaBean.getStr("ROLECODE"));
            } else {
                roleIds.append("," + roleDynaBean.getStr("ROLEID"));
                roleNamesStr.append("," + roleDynaBean.getStr("ROLENAME"));
                roleCodes.append("," + roleDynaBean.getStr("ROLECODE"));
            }
        }
        // 角色编码
        user.setStr("ROLECODES", roleCodes.toString());
        // 角色主键
        user.setStr("ROLEIDS", roleIds.toString());
        // 角色名称
        user.setStr("ROLENAMES", roleNamesStr.toString());
        metaService.update(user);
    }

    /**
     * 基础信息
     *
     * @param user
     */
    private void buildUserCreateInfo(DynaBean user) {
        user.setStr("ISSYSUSER", "1");
        user.setStr("FLAG", "1");
        String ORDERINDEX = user.getStr("DISPLAY_ORDER");
        user.set("USERORDER", ORDERINDEX);
        user.setStr("INITPASSWORD", "1");
        user.setStr("SENTRYCODES", "");
        user.setStr("MONITORDEPTCODE", "");
        user.setStr("MENUTYPE", "");
        user.setStr("LOGINLOCKED", "0");
        user.setStr("VALID", "1");
        user.setStr("STATUS", "1");
        PCDynaServiceTemplate pcDynaServiceTemplate = SpringContextHolder.getBean(PCDynaServiceTemplate.class);
        pcDynaServiceTemplate.buildModelCreateInfo(user);
        EndUser endUser = SecurityUserHolder.getCurrentUser();
        user.setStr("CREATEORG", endUser.getDeptCode());
        user.setStr("CREATEORGNAME", endUser.getDeptName());
        user.setStr("CREATETIME", user.getStr("SY_CREATETIME"));
        user.setStr("CREATEUSER", endUser.getUserCode());
        user.setStr("CREATEUSERNAME", endUser.getUsername());
        user.setStr("MODIFYUSER", endUser.getUserCode());
        user.setStr("MODIFYUSERNAME", endUser.getUsername());
        user.setStr("JTGSMC", endUser.getJtgsMc());
        user.setStr("JTGSDM", endUser.getJtgsDm());
        user.setStr("JTGSID", endUser.getJtgsId());
        user.setStr("GSBMID", endUser.getGsbmId());
        user.setStr("ZHID", endUser.getZhId());
        user.setStr("ZHMC", endUser.getZhMc());
    }
最后编辑: 呼丽华  文档更新时间: 2024-08-21 10:58   作者:呼丽华