地质所 沉降监测网建设项目
zmk
2024-05-15 9e3afc6d0fa514f986d3fea40fa23124e6fb5070
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
package com.javaweb.system.service.impl;
 
 
import com.javaweb.common.config.Global;
import com.javaweb.common.constant.UserConstants;
import com.javaweb.common.utils.StringUtils;
import com.javaweb.system.domain.ImportExcelResult;
import com.javaweb.system.domain.SysDept;
import com.javaweb.system.domain.SysUser;
import com.javaweb.system.service.IExcelImportService;
import com.javaweb.system.service.ISysDeptService;
import com.javaweb.system.service.ISysUserService;
import org.apache.commons.lang3.RandomUtils;
import org.apache.shiro.crypto.hash.Md5Hash;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
 
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
 
@Service
public class ExcelImportServiceImpl implements IExcelImportService {
 
    @Autowired
    private ISysDeptService deptService;
    @Autowired
    private ISysUserService userService;
 
    @Override
    @Transactional
    public ImportExcelResult saveData(List<Object> list, String importType, SysUser currentUser) {
        List<Map<String, String>> result = new ArrayList<Map<String, String>>();
        ImportExcelResult importExcelResult = new ImportExcelResult(0,result);
        for(int i=0;i<list.size();i++){
            switch (importType){
                case "1":
                    result.add(saveData((SysUser)list.get(i),i+1,importExcelResult,currentUser));
                    break;
                case "2":
                    result.add(saveData((SysDept)list.get(i),i+1,importExcelResult));
                    break;
                default:
                    throw new RuntimeException();
            }
        }
        return importExcelResult;
    }
 
    /**
     * 保存用户
     *
     * @param user
     * @param rowNum
     * @return
     */
    public Map<String, String> saveData(SysUser user, int rowNum, ImportExcelResult importExcelResult, SysUser currentUser) {
        StringBuilder msg = new StringBuilder("");
        //1.校验数据的合法性
        if(StringUtils.isEmpty(user.getLoginName())){
            msg.append("登录名称不能为空!");
        }
        if(StringUtils.isEmpty(user.getUserName())){
            msg.append("用户名称不能为空!");
        }
        if(StringUtils.isEmpty(user.getDept().getDeptName())){
            msg.append("部门名称不能为空!");
        }
        if(UserConstants.USER_NAME_NOT_UNIQUE.equals(userService.checkLoginNameUnique(user.getLoginName()))){
            msg.append("登录名称系统内已经存在!");
        }
        SysDept dept = getDeptByName(user.getDeptName());
        if(dept!=null){
            if(!dept.getDelFlag().equals("0")){
                msg.append("部门已被删除!");
            }
            if(!dept.getStatus().equals("0")){
                msg.append("部门已被停用!");
            }
        }else{
            msg.append("部门不存在!");
        }
        if(!StringUtils.isEmpty(msg.toString())){
            return importExcelResultMap(user.getLoginName(),1,msg.toString(),rowNum);
        }
        //2.初始化默认值
        user.setDeptId(dept.getDeptId());
        if(StringUtils.isEmpty(user.getSex())){
            user.setSex("2");
        }else if("男".equals(user.getSex())){
            user.setSex("0");
        }else if("女".equals(user.getSex())){
            user.setSex("1");
        }
        String str=RandomUtils.nextInt()+"000000";
        user.setSalt(str.substring(0,6));
        user.setPassword(new Md5Hash(user.getUserName() + user.getPassword() + user.getSalt()).toHex().toString());
        user.setCreateBy(currentUser.getLoginName());
        user.setRoleIds(new Long[]{Global.ROLE_ID_DEFAULT});
        user.setPostIds(new Long[]{});
        //3.保存
        userService.insertUser(user);
        importExcelResult.setSuccessNum(importExcelResult.getSuccessNum()+1);
        return importExcelResultMap(user.getLoginName(),0,"添加成功!",rowNum);
    }
 
    /**
     * 保存部门
     *
     * @param dept
     * @param rowNum
     * @return
     */
    public Map<String, String> saveData(SysDept dept, int rowNum, ImportExcelResult importExcelResult) {
        StringBuilder msg = new StringBuilder("");
        //1.校验数据的合法性
        SysDept tempDept = null;
        if(StringUtils.isEmpty(dept.getDeptName())){
            msg.append("部门名称不能为空!");
        }else{
            tempDept = getDeptByName(dept.getDeptName());
            if(tempDept!=null){
                msg.append("部门名称("+dept.getDeptName()+")已经存在!");
            }
        }
        if(StringUtils.isEmpty(dept.getParentName())){
            msg.append("上级部门名称不能为空!");
        }
        if(StringUtils.isEmpty(dept.getOrderNum())){
            msg.append("显示顺序不能为空!");
        }else if(!dept.getOrderNum().matches("\\d{1,4}")){
            msg.append("显示顺序必须是不超过4位的整数!");
        }
        tempDept = getDeptByName(dept.getParentName());
        if(tempDept==null){
            msg.append("上级部门(").append(dept.getParentName()).append(")不存在!");
        }else{
 
        }
        if(!StringUtils.isEmpty(msg.toString())){
            return importExcelResultMap(dept.getDeptName(),1,msg.toString(),rowNum);
        }
        //2.初始化默认值
        dept.setParentId(tempDept.getDeptId());
        //3.保存
        deptService.insertDept(dept);
        importExcelResult.setSuccessNum(importExcelResult.getSuccessNum()+1);
        return importExcelResultMap(dept.getDeptName(),0,"添加成功!",rowNum);
    }
 
    private SysDept getDeptByName(String deptName){
        SysDept dept = new SysDept();
        //按照名称精确查询该名称的部门
        dept.getParams().put("equalDeptName",deptName);
        List<SysDept> depts = deptService.selectDeptList(dept);
        if(depts == null || depts.isEmpty()){
            return null;
        }
        return depts.get(0);
    }
    /**
     * 每行导入结果
     * @param name
     * @param code
     * @param msg
     * @return
     */
    private Map<String,String> importExcelResultMap(String name,Integer code,String msg,Integer rowNum){
        Map<String,String> map = new HashMap<String, String>();
        map.put("name",name);
        map.put("code",code.toString());
        map.put("msg",msg);
        map.put("rowNum",rowNum.toString());
        return map;
    }
 
}