Blame view

src/com/fh/controller/sunvote/teacher/TeacherController.java 12.3 KB
57330ff4   孙向锦   添加一些模块信息
1
2
3
4
5
6
7
8
9
10
  package com.fh.controller.sunvote.teacher;
  
  import java.io.PrintWriter;
  import java.text.DateFormat;
  import java.text.SimpleDateFormat;
  import java.util.ArrayList;
  import java.util.Date;
  import java.util.HashMap;
  import java.util.List;
  import java.util.Map;
8ee66e91   孙向锦   更新链接
11
  
57330ff4   孙向锦   添加一些模块信息
12
  import javax.annotation.Resource;
8ee66e91   孙向锦   更新链接
13
  
bed6e1fc   孙向锦   添加其他功能
14
  import org.apache.shiro.crypto.hash.SimpleHash;
57330ff4   孙向锦   添加一些模块信息
15
16
17
18
19
20
21
  import org.springframework.beans.propertyeditors.CustomDateEditor;
  import org.springframework.stereotype.Controller;
  import org.springframework.web.bind.WebDataBinder;
  import org.springframework.web.bind.annotation.InitBinder;
  import org.springframework.web.bind.annotation.RequestMapping;
  import org.springframework.web.bind.annotation.ResponseBody;
  import org.springframework.web.servlet.ModelAndView;
8ee66e91   孙向锦   更新链接
22
  
c617106f   孙向锦   添加即时测功能
23
  import com.fh.controller.api.ResponseGson;
57330ff4   孙向锦   添加一些模块信息
24
25
  import com.fh.controller.base.BaseController;
  import com.fh.entity.Page;
c617106f   孙向锦   添加即时测功能
26
  import com.fh.service.api.V1Manager;
bed6e1fc   孙向锦   添加其他功能
27
28
29
30
  import com.fh.service.sunvote.school.SchoolManager;
  import com.fh.service.sunvote.teacher.TeacherManager;
  import com.fh.service.system.fhlog.FHlogManager;
  import com.fh.service.system.user.UserManager;
57330ff4   孙向锦   添加一些模块信息
31
  import com.fh.util.AppUtil;
bed6e1fc   孙向锦   添加其他功能
32
  import com.fh.util.Jurisdiction;
57330ff4   孙向锦   添加一些模块信息
33
34
  import com.fh.util.ObjectExcelView;
  import com.fh.util.PageData;
c617106f   孙向锦   添加即时测功能
35
  import com.fh.util.Tools;
57330ff4   孙向锦   添加一些模块信息
36
  
c617106f   孙向锦   添加即时测功能
37
38
  /**
   * 说明:教师 创建人:Elvis 创建时间:2018-04-26
57330ff4   孙向锦   添加一些模块信息
39
40
   */
  @Controller
c617106f   孙向锦   添加即时测功能
41
  @RequestMapping(value = "/teacher")
57330ff4   孙向锦   添加一些模块信息
42
  public class TeacherController extends BaseController {
c617106f   孙向锦   添加即时测功能
43
44
45
  
  	String menuUrl = "teacher/list.do"; // 菜单地址(权限用)
  	@Resource(name = "teacherService")
57330ff4   孙向锦   添加一些模块信息
46
  	private TeacherManager teacherService;
c617106f   孙向锦   添加即时测功能
47
48
  
  	@Resource(name = "schoolService")
8ee66e91   孙向锦   更新链接
49
  	private SchoolManager schoolService;
c617106f   孙向锦   添加即时测功能
50
51
  
  	@Resource(name = "userService")
bed6e1fc   孙向锦   添加其他功能
52
  	private UserManager userService;
c617106f   孙向锦   添加即时测功能
53
54
  
  	@Resource(name = "fhlogService")
bed6e1fc   孙向锦   添加其他功能
55
56
  	private FHlogManager FHLOG;
  	
c617106f   孙向锦   添加即时测功能
57
58
59
60
61
62
  	@Resource(name = "v1Service")
  	private V1Manager v1Service;
  
  	/**
  	 * 保存
  	 * 
57330ff4   孙向锦   添加一些模块信息
63
64
65
  	 * @param
  	 * @throws Exception
  	 */
c617106f   孙向锦   添加即时测功能
66
67
68
69
70
71
  	@RequestMapping(value = "/save")
  	public ModelAndView save() throws Exception {
  		logBefore(logger, Jurisdiction.getUsername() + "新增Teacher");
  		if (!Jurisdiction.buttonJurisdiction(menuUrl, "add")) {
  			return null;
  		} // 校验权限
57330ff4   孙向锦   添加一些模块信息
72
73
  		ModelAndView mv = this.getModelAndView();
  		PageData pd = new PageData();
57330ff4   孙向锦   添加一些模块信息
74
  		pd = this.getPageData();
a51b67cf   孙向锦   交互第一个版本
75
  		pd.put("ID", this.get32UUID());
57330ff4   孙向锦   添加一些模块信息
76
  		teacherService.save(pd);
c617106f   孙向锦   添加即时测功能
77
78
79
80
81
  
  		pd.put("USER_ID", pd.getString("ID")); // ID 主键
  		pd.put("LAST_LOGIN", ""); // 最后登录时间
  		pd.put("IP", ""); // IP
  		pd.put("STATUS", "0"); // 状态
bed6e1fc   孙向锦   添加其他功能
82
  		pd.put("SKIN", "default");
c617106f   孙向锦   添加即时测功能
83
  		pd.put("RIGHTS", "");
bed6e1fc   孙向锦   添加其他功能
84
  		pd.put("USERNAME", pd.getString("ACCOUT"));
c617106f   孙向锦   添加即时测功能
85
86
87
88
89
90
91
92
93
  		pd.put("ROLE_ID", "57bb1e6f138247a0b05cc721a5da1b64");
  		pd.put("PASSWORD",
  				new SimpleHash("SHA-1", pd.getString("ACCOUT"), pd
  						.getString("PASSWORD")).toString()); // 密码加密
  
  		if (null == userService.findByUsername(pd)) { // 判断用户名是否存在
  			userService.saveU(pd); // 执行保存
  			FHLOG.save(Jurisdiction.getUsername(),
  					"新增系统用户:" + pd.getString("USERNAME"));
bed6e1fc   孙向锦   添加其他功能
94
  		}
c617106f   孙向锦   添加即时测功能
95
96
  
  		mv.addObject("msg", "success");
57330ff4   孙向锦   添加一些模块信息
97
98
99
  		mv.setViewName("save_result");
  		return mv;
  	}
c617106f   孙向锦   添加即时测功能
100
101
102
103
  
  	/**
  	 * 删除
  	 * 
57330ff4   孙向锦   添加一些模块信息
104
105
106
  	 * @param out
  	 * @throws Exception
  	 */
c617106f   孙向锦   添加即时测功能
107
108
109
110
111
112
  	@RequestMapping(value = "/delete")
  	public void delete(PrintWriter out) throws Exception {
  		logBefore(logger, Jurisdiction.getUsername() + "删除Teacher");
  		if (!Jurisdiction.buttonJurisdiction(menuUrl, "del")) {
  			return;
  		} // 校验权限
57330ff4   孙向锦   添加一些模块信息
113
114
  		PageData pd = new PageData();
  		pd = this.getPageData();
bed6e1fc   孙向锦   添加其他功能
115
  		pd.put("USER_ID", pd.get("ID"));
57330ff4   孙向锦   添加一些模块信息
116
  		teacherService.delete(pd);
bed6e1fc   孙向锦   添加其他功能
117
  		userService.deleteU(pd);
57330ff4   孙向锦   添加一些模块信息
118
119
120
  		out.write("success");
  		out.close();
  	}
c617106f   孙向锦   添加即时测功能
121
122
123
124
  
  	/**
  	 * 修改
  	 * 
57330ff4   孙向锦   添加一些模块信息
125
126
127
  	 * @param
  	 * @throws Exception
  	 */
c617106f   孙向锦   添加即时测功能
128
129
130
131
132
133
  	@RequestMapping(value = "/edit")
  	public ModelAndView edit() throws Exception {
  		logBefore(logger, Jurisdiction.getUsername() + "修改Teacher");
  		if (!Jurisdiction.buttonJurisdiction(menuUrl, "edit")) {
  			return null;
  		} // 校验权限
57330ff4   孙向锦   添加一些模块信息
134
135
136
137
  		ModelAndView mv = this.getModelAndView();
  		PageData pd = new PageData();
  		pd = this.getPageData();
  		teacherService.edit(pd);
c617106f   孙向锦   添加即时测功能
138
139
140
141
142
143
144
145
146
147
148
149
150
151
  
  		/*
  		 * pd.put("USER_ID", pd.getString("ID")); //ID 主键 pd.put("LAST_LOGIN",
  		 * ""); //最后登录时间 pd.put("IP", ""); //IP pd.put("STATUS", "0"); //状态
  		 * pd.put("SKIN", "default"); pd.put("RIGHTS", ""); pd.put("USERNAME",
  		 * pd.getString("ACCOUT")); pd.put("ROLE_ID",
  		 * "57bb1e6f138247a0b05cc721a5da1b64"); pd.put("PASSWORD", new
  		 * SimpleHash("SHA-1", pd.getString("ACCOUT"),
  		 * pd.getString("PASSWORD")).toString()); //密码加密
  		 * 
  		 * userService.saveU(pd);
  		 */
  
  		mv.addObject("msg", "success");
57330ff4   孙向锦   添加一些模块信息
152
153
154
  		mv.setViewName("save_result");
  		return mv;
  	}
c617106f   孙向锦   添加即时测功能
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
  
  	/**
  	 * 列表
  	 * 
  	 * @param page
  	 * @throws Exception
  	 */
  	@RequestMapping(value = "/teach_paper")
  	public ModelAndView teach_paper(Page page) throws Exception {
  		logBefore(logger, Jurisdiction.getUsername() + "列表Paper");
  		String userId = this.getUserID();
  		ModelAndView mv = this.getModelAndView();
  		PageData pd = new PageData();
  		pd = this.getPageData();
  		mv.setViewName("sunvote/teacher/teach_paper");
  		mv.addObject("pd", pd);
  		return mv;
  	}
57330ff4   孙向锦   添加一些模块信息
173
  	
c617106f   孙向锦   添加即时测功能
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
208
209
210
211
  	/**
  	 * 列表
  	 * 
  	 * @param page
  	 * @throws Exception
  	 */
  	@RequestMapping(value = "/paper_view")
  	public ModelAndView paper_view(Page page) throws Exception {
  		logBefore(logger, Jurisdiction.getUsername() + "列表Paper");
  		String userId = this.getUserID();
  		ModelAndView mv = this.getModelAndView();
  		PageData pd = new PageData();
  		pd = this.getPageData();
  		mv.setViewName("sunvote/teacher/paper_view");
  		mv.addObject("pd", pd);
  		return mv;
  	}
  
  	/**
  	 * 列表
  	 * 
  	 * @param page
  	 * @throws Exception
  	 */
  	@RequestMapping(value = "/set_question")
  	public ModelAndView set_question(Page page) throws Exception {
  		logBefore(logger, Jurisdiction.getUsername() + "列表Paper");
  		ModelAndView mv = this.getModelAndView();
  		PageData pd = new PageData();
  		pd = this.getPageData();
  		mv.setViewName("sunvote/teacher/set_question");
  		mv.addObject("pd", pd);
  		return mv;
  	}
  
  	/**
  	 * 列表
  	 * 
57330ff4   孙向锦   添加一些模块信息
212
213
214
  	 * @param page
  	 * @throws Exception
  	 */
c617106f   孙向锦   添加即时测功能
215
216
217
218
219
  	@RequestMapping(value = "/list")
  	public ModelAndView list(Page page) throws Exception {
  		logBefore(logger, Jurisdiction.getUsername() + "列表Teacher");
  		// if(!Jurisdiction.buttonJurisdiction(menuUrl, "cha")){return null;}
  		// //校验权限(无权查看时页面会有提示,如果不注释掉这句代码就无法进入列表页面,所以根据情况是否加入本句代码)
57330ff4   孙向锦   添加一些模块信息
220
221
222
  		ModelAndView mv = this.getModelAndView();
  		PageData pd = new PageData();
  		pd = this.getPageData();
c617106f   孙向锦   添加即时测功能
223
224
  		String keywords = pd.getString("keywords"); // 关键词检索条件
  		if (null != keywords && !"".equals(keywords)) {
57330ff4   孙向锦   添加一些模块信息
225
226
227
  			pd.put("keywords", keywords.trim());
  		}
  		page.setPd(pd);
c617106f   孙向锦   添加即时测功能
228
  		List<PageData> varList = teacherService.list(page); // 列出Teacher列表
57330ff4   孙向锦   添加一些模块信息
229
230
  		mv.setViewName("sunvote/teacher/teacher_list");
  		mv.addObject("varList", varList);
c617106f   孙向锦   添加即时测功能
231
  
b5cf92b7   孙向锦   批量上传学生名单
232
  		List<PageData> schools = schoolService.listAll(pd);
c617106f   孙向锦   添加即时测功能
233
234
  		mv.addObject("schools", schools);
  
57330ff4   孙向锦   添加一些模块信息
235
  		mv.addObject("pd", pd);
c617106f   孙向锦   添加即时测功能
236
  		mv.addObject("QX", Jurisdiction.getHC()); // 按钮权限
57330ff4   孙向锦   添加一些模块信息
237
238
  		return mv;
  	}
c617106f   孙向锦   添加即时测功能
239
240
241
242
  
  	/**
  	 * 去新增页面
  	 * 
57330ff4   孙向锦   添加一些模块信息
243
244
245
  	 * @param
  	 * @throws Exception
  	 */
c617106f   孙向锦   添加即时测功能
246
247
  	@RequestMapping(value = "/goAdd")
  	public ModelAndView goAdd() throws Exception {
57330ff4   孙向锦   添加一些模块信息
248
249
250
251
  		ModelAndView mv = this.getModelAndView();
  		PageData pd = new PageData();
  		pd = this.getPageData();
  		mv.setViewName("sunvote/teacher/teacher_edit");
c617106f   孙向锦   添加即时测功能
252
  
8ee66e91   孙向锦   更新链接
253
  		List<PageData> schools = schoolService.listAll(pd);
c617106f   孙向锦   添加即时测功能
254
255
  		mv.addObject("schools", schools);
  
57330ff4   孙向锦   添加一些模块信息
256
257
258
  		mv.addObject("msg", "save");
  		mv.addObject("pd", pd);
  		return mv;
c617106f   孙向锦   添加即时测功能
259
260
261
262
263
  	}
  
  	/**
  	 * 去修改页面
  	 * 
57330ff4   孙向锦   添加一些模块信息
264
265
266
  	 * @param
  	 * @throws Exception
  	 */
c617106f   孙向锦   添加即时测功能
267
268
  	@RequestMapping(value = "/goEdit")
  	public ModelAndView goEdit() throws Exception {
57330ff4   孙向锦   添加一些模块信息
269
270
271
  		ModelAndView mv = this.getModelAndView();
  		PageData pd = new PageData();
  		pd = this.getPageData();
c617106f   孙向锦   添加即时测功能
272
  		pd = teacherService.findById(pd); // 根据ID读取
57330ff4   孙向锦   添加一些模块信息
273
  		mv.setViewName("sunvote/teacher/teacher_edit");
8ee66e91   孙向锦   更新链接
274
  		List<PageData> schools = schoolService.listAll(pd);
c617106f   孙向锦   添加即时测功能
275
  		mv.addObject("schools", schools);
57330ff4   孙向锦   添加一些模块信息
276
277
278
  		mv.addObject("msg", "edit");
  		mv.addObject("pd", pd);
  		return mv;
c617106f   孙向锦   添加即时测功能
279
280
281
282
283
  	}
  
  	/**
  	 * 批量删除
  	 * 
57330ff4   孙向锦   添加一些模块信息
284
285
286
  	 * @param
  	 * @throws Exception
  	 */
c617106f   孙向锦   添加即时测功能
287
  	@RequestMapping(value = "/deleteAll")
57330ff4   孙向锦   添加一些模块信息
288
  	@ResponseBody
c617106f   孙向锦   添加即时测功能
289
290
291
292
293
294
295
  	public Object deleteAll() throws Exception {
  		logBefore(logger, Jurisdiction.getUsername() + "批量删除Teacher");
  		if (!Jurisdiction.buttonJurisdiction(menuUrl, "del")) {
  			return null;
  		} // 校验权限
  		PageData pd = new PageData();
  		Map<String, Object> map = new HashMap<String, Object>();
57330ff4   孙向锦   添加一些模块信息
296
297
298
  		pd = this.getPageData();
  		List<PageData> pdList = new ArrayList<PageData>();
  		String DATA_IDS = pd.getString("DATA_IDS");
c617106f   孙向锦   添加即时测功能
299
  		if (null != DATA_IDS && !"".equals(DATA_IDS)) {
57330ff4   孙向锦   添加一些模块信息
300
301
302
  			String ArrayDATA_IDS[] = DATA_IDS.split(",");
  			teacherService.deleteAll(ArrayDATA_IDS);
  			pd.put("msg", "ok");
c617106f   孙向锦   添加即时测功能
303
  		} else {
57330ff4   孙向锦   添加一些模块信息
304
305
306
307
308
309
  			pd.put("msg", "no");
  		}
  		pdList.add(pd);
  		map.put("list", pdList);
  		return AppUtil.returnObject(pd, map);
  	}
c617106f   孙向锦   添加即时测功能
310
311
312
313
  
  	/**
  	 * 导出到excel
  	 * 
57330ff4   孙向锦   添加一些模块信息
314
315
316
  	 * @param
  	 * @throws Exception
  	 */
c617106f   孙向锦   添加即时测功能
317
318
319
320
321
322
  	@RequestMapping(value = "/excel")
  	public ModelAndView exportExcel() throws Exception {
  		logBefore(logger, Jurisdiction.getUsername() + "导出Teacher到excel");
  		if (!Jurisdiction.buttonJurisdiction(menuUrl, "cha")) {
  			return null;
  		}
57330ff4   孙向锦   添加一些模块信息
323
324
325
  		ModelAndView mv = new ModelAndView();
  		PageData pd = new PageData();
  		pd = this.getPageData();
c617106f   孙向锦   添加即时测功能
326
  		Map<String, Object> dataMap = new HashMap<String, Object>();
57330ff4   孙向锦   添加一些模块信息
327
  		List<String> titles = new ArrayList<String>();
c617106f   孙向锦   添加即时测功能
328
329
330
331
332
333
334
335
336
337
  		titles.add("所在学校"); // 1
  		titles.add("姓名"); // 2
  		titles.add("电话"); // 3
  		titles.add("座机电话"); // 4
  		titles.add("证件号"); // 5
  		titles.add("账号"); // 6
  		titles.add("密码"); // 7
  		titles.add("性别"); // 8
  		titles.add("科目列表"); // 9
  		titles.add("教师卡编号"); // 10
57330ff4   孙向锦   添加一些模块信息
338
339
340
  		dataMap.put("titles", titles);
  		List<PageData> varOList = teacherService.listAll(pd);
  		List<PageData> varList = new ArrayList<PageData>();
c617106f   孙向锦   添加即时测功能
341
  		for (int i = 0; i < varOList.size(); i++) {
57330ff4   孙向锦   添加一些模块信息
342
  			PageData vpd = new PageData();
c617106f   孙向锦   添加即时测功能
343
344
345
346
347
348
349
350
351
352
  			vpd.put("var1", varOList.get(i).get("SCHOOL_ID").toString()); // 1
  			vpd.put("var2", varOList.get(i).getString("NAME")); // 2
  			vpd.put("var3", varOList.get(i).getString("PHONE")); // 3
  			vpd.put("var4", varOList.get(i).getString("SEAT_PHONE")); // 4
  			vpd.put("var5", varOList.get(i).getString("CARD_NO")); // 5
  			vpd.put("var6", varOList.get(i).getString("ACCOUT")); // 6
  			vpd.put("var7", varOList.get(i).getString("PASSWORD")); // 7
  			vpd.put("var8", varOList.get(i).get("SEX").toString()); // 8
  			vpd.put("var9", varOList.get(i).getString("SUBJECT_IDS")); // 9
  			vpd.put("var10", varOList.get(i).getString("KEYPAD_ID")); // 10
57330ff4   孙向锦   添加一些模块信息
353
354
355
356
  			varList.add(vpd);
  		}
  		dataMap.put("varList", varList);
  		ObjectExcelView erv = new ObjectExcelView();
c617106f   孙向锦   添加即时测功能
357
  		mv = new ModelAndView(erv, dataMap);
57330ff4   孙向锦   添加一些模块信息
358
359
  		return mv;
  	}
c617106f   孙向锦   添加即时测功能
360
  
57330ff4   孙向锦   添加一些模块信息
361
  	@InitBinder
c617106f   孙向锦   添加即时测功能
362
  	public void initBinder(WebDataBinder binder) {
57330ff4   孙向锦   添加一些模块信息
363
  		DateFormat format = new SimpleDateFormat("yyyy-MM-dd");
c617106f   孙向锦   添加即时测功能
364
365
  		binder.registerCustomEditor(Date.class, new CustomDateEditor(format,
  				true));
57330ff4   孙向锦   添加一些模块信息
366
  	}
c617106f   孙向锦   添加即时测功能
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
  
  	/**
  	 * 批量删除
  	 * 
  	 * @param
  	 * @throws Exception
  	 */
  	@RequestMapping(value = "/info", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public Object info() throws Exception {
  		PageData pd = this.getPageData();
  		ResponseGson<PageData> res = new ResponseGson();
  		pd.put("ID", this.geTeacherID());
  		PageData pageData = teacherService.findById(pd);
  		if (pageData != null && pageData.getString("ID") != null) {
  			pageData.put("PASSWORD", "");// 返回参数中不返回密码
  			PageData pt = new PageData();
  			pt.put("TEACHER_ID", pageData.get("ID"));
  			// 在任课表中查找老师教哪些班级,然后查出班级信息
  			List<PageData> classInfoList = v1Service
  					.getTeacherClassInfo(pt);
  			
  			pageData.put("classInfoList", classInfoList);
  			// 在认可表中查找老师教哪些科目,然后查出科目信息
  			List<PageData> subjectList = v1Service
  					.getTeacherSubjectInfo(pt);
  			// 一个sql语句完成。
  			pageData.put("subjectList", subjectList);
  			
  			pageData.remove("SUBJECT_IDS");
  			
  			PageData eventPd = new PageData();
  			eventPd.put("EVENT_ID", get32UUID());
  			eventPd.put("EVENT_NAME", "login");
  			eventPd.put("EVENT_USER", pageData.getString("ID"));
  			eventPd.put("EVENT_TYPE", "0");
  			eventPd.put("EVENT_START_TIME", Tools.date2Str(new Date()));
  			if (pd.getString("CLIENT_ID") != null) {
  				eventPd.put("CLIENT_ID", pd.getString("CLIENT_ID"));
  			} else {
  				eventPd.put("CLIENT_ID", "CLIENT");
  			}
  			res.setData(pageData);
  			// 填充数据到返回数据中
  		} else {
  			res.set1Error();
  		}
  		
  		return res.toJson();
  	}
  
57330ff4   孙向锦   添加一些模块信息
418
  }