智慧保安后台管理-外网项目备份
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
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
package org.springblade.modules.dataSync;
 
 
import org.json.JSONArray;
import org.json.JSONObject;
import org.springblade.common.config.DataSyncConfig;
import org.springblade.common.utils.InvestigateUtil;
import org.springblade.modules.system.entity.User;
import org.springblade.modules.system.service.IUserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import javax.annotation.PostConstruct;
import java.io.File;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.util.Date;
 
@Component
public class MysqlCenlint {
 
    @Autowired
    private IUserService userService;
 
    //声明对象
    private static MysqlCenlint mysqlCenlint;
 
    /**
     * 初始化
     */
    @PostConstruct
    public void init(){
        mysqlCenlint = this;
        mysqlCenlint.userService = this.userService;
    }
 
    /**
     * sql 连接
     * @param sql
     */
    public static void sqlConnect(String sql,Integer type){
        String driver = DataSyncConfig.driver;
        //换成要连接的数据库信息
        String url = DataSyncConfig.url;
        String user = DataSyncConfig.username;
        String password = DataSyncConfig.password;
        Connection conn = null;
        PreparedStatement ps = null;
        try {
            Class.forName ( driver );
            conn = (Connection) DriverManager.getConnection ( url, user, password );
            if (!conn.isClosed ()) {
                System.out.println ( "数据库连接成功:" );
                String sqls = sql;
                ps = conn.prepareStatement ( sqls );
                //判断是否为修改,删除
                if (type==1){
                    //修改删除
                    ps.executeUpdate();
                }else {
                    //新增
                    ps.execute();
                }
            }
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            e.printStackTrace ();
        }finally {
            try {
                ps.close();
                conn.close();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }
    }
 
 
    /**
     * 连接mysql数据库 新增
     * @param sql
     */
    public static void inster(String sql) {
        sqlConnect(sql,2);
        try {
            Thread.sleep(300);
            //对比 sql 字符串,如果是是往用户表里插入保安员数据,则调用公安审查接口
            String insertUserSql = "insert into blade_user";
            if (sql.contains(insertUserSql)){
                //如果包含,调用公安接口进行保安员审查
                getMxaminationSecurityInfo(sql);
            }
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
 
    /**
     * 审查保安员
     * @param sqls 新增的sql 语句
     */
    private static void getMxaminationSecurityInfo(String sqls) {
        //解析sql,读取数据,取出角色,如果是保安员,则审查,如果不是就不审查
        //获取第一个 (  ) 的位置
        int a = sqls.indexOf("(");
        int b = sqls.indexOf(")");
        //获取第二个 ( )的位置
        a = sqls.indexOf("(",a+1);
        b = sqls.indexOf(")",b+1);
        //截取字符串
        String subSql = sqls.substring(a, b);
        String[] splitSql = subSql.split(",");
        //读取角色
        String roleId = splitSql[10];
        //去除单引号
        String subRoleId = roleId.substring(1, roleId.length() - 1);
        //如果是保安员
        if (subRoleId.equals("1412226235153731586")){
            //读取身份证号
            String cardid = splitSql[12];
            //去除单引号
            String subCardid = cardid.substring(1, cardid.length() - 1);
            User user = new User();
            String userId = splitSql[0].substring(2, splitSql[0].length() - 1);
            user.setId(Long.parseLong(userId));
            System.out.println("身份证:"+subCardid);
            //远程调用接口
            String body = InvestigateUtil.httpGetOne(subCardid);
            JSONObject jsonObject = new JSONObject(body);
            Object data = jsonObject.get("data");
            JSONObject jsonData = new JSONObject(data.toString());
            JSONArray res = jsonData.getJSONArray("res");
            //设置审核时间
            user.setAuditTime(new Date());
            if (res.length() == 0) {
                //没有数据正常
                user.setExaminationType("0");
            } else {
                int count = 0;
                user.setExaminationType("1");
                for (int i = 0; i < res.length(); i++) {
                    if (res.getJSONObject(i).get("zdrylbjh").toString() != null
                        && res.getJSONObject(i).get("zdrylbjh").toString() != ""
                        && res.getJSONObject(i).get("zdrylbjh").toString() != "null"
                    ) {
                        user.setExaminationMx(res.getJSONObject(i).get("zdrylbjh").toString());
                        //更新用户数据
                        mysqlCenlint.userService.updateById(user);
                        break;
                    }
                    if (res.getJSONObject(i).get("zdryxlmc").toString() != null
                        && res.getJSONObject(i).get("zdryxlmc").toString() != ""
                        && res.getJSONObject(i).get("zdryxlmc").toString() != "null"
                    ) {
                        user.setExaminationMx(res.getJSONObject(i).get("zdryxlmc").toString());
                        //更新用户数据
                        mysqlCenlint.userService.updateById(user);
                        break;
                    }
                    if (res.getJSONObject(i).get("ztrylx").toString() != null
                        && res.getJSONObject(i).get("ztrylx").toString() != ""
                        && res.getJSONObject(i).get("ztrylx").toString() != "null"
                    ) {
                        user.setExaminationMx(res.getJSONObject(i).get("ztrylx").toString());
                        //更新用户数据
                        mysqlCenlint.userService.updateById(user);
                        break;
                    }
//                        if (res.getJSONObject(i).get("ajlbmc").toString() != null
//                            && res.getJSONObject(i).get("ajlbmc").toString() != "") {
//                            user.setExaminationMx(res.getJSONObject(i).get("ajlbmc").toString());
//                            //更新用户数据
//                            userService.updateById(user);
//                            break;
//                        }
                    count++;
                    //条件中的数据都为空,则审查为正常
                    if (count==res.length()){
                        //更新用户数据,设为正常
                        user.setExaminationType("0");
                        mysqlCenlint.userService.updateById(user);
                    }
                }
            }
            //更新用户数据
            mysqlCenlint.userService.updateById(user);
        }
    }
 
    /**
     * 连接mysql数据库 修改
     * @param sql
     */
    public static void update(String sql) {
        sqlConnect(sql,1);
    }
 
    /**
     * 连接mysql数据库 删除
     * @param sql
     */
    public static void delete(String sql) {
        sqlConnect(sql,1);
    }
}