Blame view

src/com/fh/controller/api/V1.java 35.6 KB
bed6e1fc   孙向锦   添加其他功能
1
2
  package com.fh.controller.api;
  
338594c8   孙向锦   添加教师端页面
3
  import java.util.ArrayList;
bed6e1fc   孙向锦   添加其他功能
4
5
6
7
  import java.util.Date;
  import java.util.List;
  
  import javax.annotation.Resource;
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
8
  import javax.servlet.http.HttpServletRequest;
bed6e1fc   孙向锦   添加其他功能
9
  
338594c8   孙向锦   添加教师端页面
10
  import org.apache.commons.lang.StringUtils;
bed6e1fc   孙向锦   添加其他功能
11
  import org.springframework.stereotype.Controller;
bed6e1fc   孙向锦   添加其他功能
12
13
14
  import org.springframework.web.bind.annotation.RequestMapping;
  import org.springframework.web.bind.annotation.ResponseBody;
  
338594c8   孙向锦   添加教师端页面
15
16
  import com.fh.bean.Paper;
  import com.fh.bean.Question;
91a745c9   孙向锦   完善后台功能
17
18
19
  import com.fh.bean.StudentAnswer;
  import com.fh.bean.TestPaper;
  import com.fh.bean.TestPaperInfo;
bed6e1fc   孙向锦   添加其他功能
20
  import com.fh.controller.base.BaseController;
338594c8   孙向锦   添加教师端页面
21
  import com.fh.controller.sunvote.Myelfun;
bed6e1fc   孙向锦   添加其他功能
22
23
24
25
  import com.fh.entity.Page;
  import com.fh.service.api.V1Manager;
  import com.fh.service.feedback.feedback.FeedbackManager;
  import com.fh.service.feedback.problemphenomenon.ProblemPhenomenonManager;
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
26
  import com.fh.service.software.softwareversion.SoftwareVersionManager;
9f161055   孙向锦   修改高斯客户反馈
27
  import com.fh.service.sunvote.attachkeyboard.AttachKeyboardManager;
bed6e1fc   孙向锦   添加其他功能
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
  import com.fh.service.sunvote.basestation.BasestationManager;
  import com.fh.service.sunvote.chapter.ChapterManager;
  import com.fh.service.sunvote.classbasetation.ClassBasetationManager;
  import com.fh.service.sunvote.classroster.ClassRosterManager;
  import com.fh.service.sunvote.classtype.ClassTypeManager;
  import com.fh.service.sunvote.coursemanagement.CourseManagementManager;
  import com.fh.service.sunvote.grade.GradeManager;
  import com.fh.service.sunvote.keypad.KeypadManager;
  import com.fh.service.sunvote.keypadcheck.KeypadCheckManager;
  import com.fh.service.sunvote.knowledge.KnowledgeManager;
  import com.fh.service.sunvote.knowledgechapter.KnowledgeChapterManager;
  import com.fh.service.sunvote.paper.PaperManager;
  import com.fh.service.sunvote.paperclassteacher.PaperClassTeacherManager;
  import com.fh.service.sunvote.paperquestion.PaperQuestionManager;
  import com.fh.service.sunvote.papertype.PaperTypeManager;
  import com.fh.service.sunvote.question.QuestionManager;
  import com.fh.service.sunvote.questiontype.QuestionTypeManager;
  import com.fh.service.sunvote.school.SchoolManager;
  import com.fh.service.sunvote.schoolgradesubject.SchoolGradeSubjectManager;
  import com.fh.service.sunvote.sclass.SClassManager;
  import com.fh.service.sunvote.student.StudentManager;
91a745c9   孙向锦   完善后台功能
49
  import com.fh.service.sunvote.studenttest.StudentTestManager;
bed6e1fc   孙向锦   添加其他功能
50
51
  import com.fh.service.sunvote.subject.SubjectManager;
  import com.fh.service.sunvote.teacher.TeacherManager;
91a745c9   孙向锦   完善后台功能
52
  import com.fh.service.sunvote.testpaper.TestPaperManager;
bed6e1fc   孙向锦   添加其他功能
53
54
55
56
57
58
59
  import com.fh.service.sunvote.testpaperinfo.TestPaperInfoManager;
  import com.fh.util.PageData;
  import com.fh.util.Tools;
  
  @Controller
  @RequestMapping(value = "/api/v1")
  public class V1 extends BaseController {
91a745c9   孙向锦   完善后台功能
60
  
bed6e1fc   孙向锦   添加其他功能
61
62
63
64
65
  	@Resource(name = "schoolService")
  	private SchoolManager schoolService;
  
  	@Resource(name = "basestationService")
  	private BasestationManager basestationService;
91a745c9   孙向锦   完善后台功能
66
67
  
  	@Resource(name = "chapterService")
bed6e1fc   孙向锦   添加其他功能
68
  	private ChapterManager chapterService;
91a745c9   孙向锦   完善后台功能
69
70
  
  	@Resource(name = "classbasetationService")
bed6e1fc   孙向锦   添加其他功能
71
  	private ClassBasetationManager classbasetationService;
91a745c9   孙向锦   完善后台功能
72
73
  
  	@Resource(name = "classrosterService")
bed6e1fc   孙向锦   添加其他功能
74
  	private ClassRosterManager classrosterService;
91a745c9   孙向锦   完善后台功能
75
76
  
  	@Resource(name = "classtypeService")
bed6e1fc   孙向锦   添加其他功能
77
  	private ClassTypeManager classtypeService;
91a745c9   孙向锦   完善后台功能
78
79
  
  	@Resource(name = "gradeService")
bed6e1fc   孙向锦   添加其他功能
80
  	private GradeManager gradeService;
91a745c9   孙向锦   完善后台功能
81
82
  
  	@Resource(name = "coursemanagementService")
bed6e1fc   孙向锦   添加其他功能
83
84
85
86
  	private CourseManagementManager coursemanagementService;
  
  	@Resource(name = "keypadService")
  	private KeypadManager keypadService;
91a745c9   孙向锦   完善后台功能
87
88
  
  	@Resource(name = "keypadcheckService")
bed6e1fc   孙向锦   添加其他功能
89
  	private KeypadCheckManager keypadcheckService;
91a745c9   孙向锦   完善后台功能
90
91
  
  	@Resource(name = "knowledgeService")
bed6e1fc   孙向锦   添加其他功能
92
  	private KnowledgeManager knowledgeService;
91a745c9   孙向锦   完善后台功能
93
94
  
  	@Resource(name = "knowledgechapterService")
bed6e1fc   孙向锦   添加其他功能
95
  	private KnowledgeChapterManager knowledgechapterService;
91a745c9   孙向锦   完善后台功能
96
97
  
  	@Resource(name = "paperService")
bed6e1fc   孙向锦   添加其他功能
98
  	private PaperManager paperService;
91a745c9   孙向锦   完善后台功能
99
100
  
  	@Resource(name = "paperclassteacherService")
bed6e1fc   孙向锦   添加其他功能
101
  	private PaperClassTeacherManager paperclassteacherService;
91a745c9   孙向锦   完善后台功能
102
103
  
  	@Resource(name = "paperquestionService")
bed6e1fc   孙向锦   添加其他功能
104
  	private PaperQuestionManager paperquestionService;
91a745c9   孙向锦   完善后台功能
105
106
  
  	@Resource(name = "papertypeService")
bed6e1fc   孙向锦   添加其他功能
107
  	private PaperTypeManager papertypeService;
91a745c9   孙向锦   完善后台功能
108
109
  
  	@Resource(name = "questionService")
bed6e1fc   孙向锦   添加其他功能
110
  	private QuestionManager questionService;
91a745c9   孙向锦   完善后台功能
111
112
  
  	@Resource(name = "questiontypeService")
bed6e1fc   孙向锦   添加其他功能
113
  	private QuestionTypeManager questiontypeService;
91a745c9   孙向锦   完善后台功能
114
115
  
  	@Resource(name = "schoolgradesubjectService")
bed6e1fc   孙向锦   添加其他功能
116
  	private SchoolGradeSubjectManager schoolgradesubjectService;
91a745c9   孙向锦   完善后台功能
117
118
  
  	@Resource(name = "sclassService")
bed6e1fc   孙向锦   添加其他功能
119
  	private SClassManager sclassService;
91a745c9   孙向锦   完善后台功能
120
121
  
  	@Resource(name = "studentService")
bed6e1fc   孙向锦   添加其他功能
122
  	private StudentManager studentService;
91a745c9   孙向锦   完善后台功能
123
124
  
  	@Resource(name = "subjectService")
bed6e1fc   孙向锦   添加其他功能
125
  	private SubjectManager subjectService;
91a745c9   孙向锦   完善后台功能
126
127
  
  	@Resource(name = "teacherService")
bed6e1fc   孙向锦   添加其他功能
128
  	private TeacherManager teacherService;
91a745c9   孙向锦   完善后台功能
129
130
  
  	@Resource(name = "testpaperinfoService")
bed6e1fc   孙向锦   添加其他功能
131
132
  	private TestPaperInfoManager testpaperinfoService;
  
91a745c9   孙向锦   完善后台功能
133
134
135
136
137
138
  	@Resource(name = "testpaperService")
  	private TestPaperManager testpaperService;
  
  	@Resource(name = "studenttestService")
  	private StudentTestManager studenttestService;
  
bed6e1fc   孙向锦   添加其他功能
139
140
141
142
143
  	@Resource(name = "feedbackService")
  	private FeedbackManager feedbackService;
  
  	@Resource(name = "problemphenomenonService")
  	private ProblemPhenomenonManager problemphenomenonService;
91a745c9   孙向锦   完善后台功能
144
  
bed6e1fc   孙向锦   添加其他功能
145
  	@Resource(name = "v1Service")
91a745c9   孙向锦   完善后台功能
146
  	private V1Manager v1Service;
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
147
148
149
  	
  	@Resource(name="softwareversionService")
  	private SoftwareVersionManager softwareversionService;
9f161055   孙向锦   修改高斯客户反馈
150
151
152
  	
  	@Resource(name="attachkeyboardService")
  	private AttachKeyboardManager attachkeyboardService;
91a745c9   孙向锦   完善后台功能
153
  
bed6e1fc   孙向锦   添加其他功能
154
155
156
157
158
  	@RequestMapping(value = "/login", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public Object login() throws Exception {
  		PageData pd = this.getPageData();
  		ResponseGson<PageData> res = new ResponseGson();
91a745c9   孙向锦   完善后台功能
159
  		if (!pd.containsKey("ACCOUT")) {
bed6e1fc   孙向锦   添加其他功能
160
161
  			pd.put("ACCOUT", pd.get("USERNAME"));
  		}
b5cf92b7   孙向锦   批量上传学生名单
162
  		if (((pd.containsKey("USERNAME") || (pd.containsKey("ACCOUT") && pd.get("ACCOUT") != null)) && pd
91a745c9   孙向锦   完善后台功能
163
  				.containsKey("PASSWORD")) || pd.containsKey("KEYPAD_ID")) {
bed6e1fc   孙向锦   添加其他功能
164
  			PageData pageData = teacherService.getUserInfo(pd);
91a745c9   孙向锦   完善后台功能
165
166
  			if (pageData != null && pageData.getString("ID") != null) {
  				pageData.put("PASSWORD", "");// 返回参数中不返回密码
bed6e1fc   孙向锦   添加其他功能
167
168
169
  				PageData pt = new PageData();
  				pt.put("TEACHER_ID", pageData.get("ID"));
  				// 在任课表中查找老师教哪些班级,然后查出班级信息
91a745c9   孙向锦   完善后台功能
170
171
172
  				List<PageData> classInfoList = v1Service
  						.getTeacherClassInfo(pt);
  
bed6e1fc   孙向锦   添加其他功能
173
174
  				pageData.put("classInfoList", classInfoList);
  				// 在认可表中查找老师教哪些科目,然后查出科目信息
91a745c9   孙向锦   完善后台功能
175
176
  				List<PageData> subjectList = v1Service
  						.getTeacherSubjectInfo(pt);
bed6e1fc   孙向锦   添加其他功能
177
178
  				// 一个sql语句完成。
  				pageData.put("subjectList", subjectList);
91a745c9   孙向锦   完善后台功能
179
  
bed6e1fc   孙向锦   添加其他功能
180
  				pageData.remove("SUBJECT_IDS");
91a745c9   孙向锦   完善后台功能
181
  
bed6e1fc   孙向锦   添加其他功能
182
183
  				res.setData(pageData);
  				// 填充数据到返回数据中
91a745c9   孙向锦   完善后台功能
184
  			} else {
bed6e1fc   孙向锦   添加其他功能
185
186
  				res.set1Error();
  			}
91a745c9   孙向锦   完善后台功能
187
  		} else {
bed6e1fc   孙向锦   添加其他功能
188
189
  			res.set1Error();
  		}
91a745c9   孙向锦   完善后台功能
190
  
bed6e1fc   孙向锦   添加其他功能
191
192
  		return res.toJson();
  	}
91a745c9   孙向锦   完善后台功能
193
  
bed6e1fc   孙向锦   添加其他功能
194
195
196
  	@RequestMapping(value = "/class", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public Object sclass() throws Exception {
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
197
  		long cur = System.currentTimeMillis();
bed6e1fc   孙向锦   添加其他功能
198
  		PageData pd = this.getPageData();
bed6e1fc   孙向锦   添加其他功能
199
  		if (pd.containsKey("ID")) {
4fd2e08c   孙向锦   修复接口中的bug
200
  			ResponseGson<PageData> res = new ResponseGson();
bed6e1fc   孙向锦   添加其他功能
201
202
203
204
  			PageData pageData = sclassService.findById(pd);
  			if (pageData != null && pageData.containsKey("ID")) {
  				PageData pt = new PageData();
  				pt.put("SCLASS_ID", pageData.get("ID"));
91a745c9   孙向锦   完善后台功能
205
  				List<PageData> studentList = v1Service.getClassStudent(pt);
bed6e1fc   孙向锦   添加其他功能
206
  				pageData.put("studentList", studentList);
9f161055   孙向锦   修改高斯客户反馈
207
208
209
  				pt.put("CLASS_ID", pageData.get("ID"));
  				List<PageData> keyboards = attachkeyboardService.listAllClassId(pt);
  				pageData.put("keyboards", keyboards);
bed6e1fc   孙向锦   添加其他功能
210
211
212
213
  				res.setData(pageData);
  			} else {
  				res.set2Error();
  			}
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
214
  			logger.info("class cost time : " + (System.currentTimeMillis() - cur));
4fd2e08c   孙向锦   修复接口中的bug
215
216
217
218
219
  			return res.toJson();
  		} else {
  			ResponseGson<List<PageData>> res = new ResponseGson();
  			List<PageData> list = sclassService.listAll(pd);
  			res.setData(list);
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
220
  			logger.info("class cost time : " + (System.currentTimeMillis() - cur));
4fd2e08c   孙向锦   修复接口中的bug
221
  			return res.toJson();
4fd2e08c   孙向锦   修复接口中的bug
222
223
224
225
226
227
  		}
  	}
  	
  	@RequestMapping(value = "/questiontype", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public Object questiontype() throws Exception {
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
228
  		long cur = System.currentTimeMillis();
4fd2e08c   孙向锦   修复接口中的bug
229
230
231
232
  		PageData pd = this.getPageData();
  		ResponseGson<List<PageData>> res = new ResponseGson();
  		List<PageData> list = questiontypeService.listAll(pd);
  		res.setData(list);
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
233
  		logger.info("questiontype cost time : " + (System.currentTimeMillis() - cur));
4fd2e08c   孙向锦   修复接口中的bug
234
235
236
237
238
239
  		return res.toJson();
  	}
  	
  	@RequestMapping(value = "/classtype", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public Object classtype() throws Exception {
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
240
  		long cur = System.currentTimeMillis();
4fd2e08c   孙向锦   修复接口中的bug
241
242
243
244
  		PageData pd = this.getPageData();
  		ResponseGson<List<PageData>> res = new ResponseGson();
  		List<PageData> list = classtypeService.listAll(pd);
  		res.setData(list);
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
245
  		logger.info("classtype cost time : " + (System.currentTimeMillis() - cur));
4fd2e08c   孙向锦   修复接口中的bug
246
247
248
249
250
251
  		return res.toJson();
  	}
  	
  	@RequestMapping(value = "/grade", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public Object grade() throws Exception {
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
252
  		long cur = System.currentTimeMillis();
4fd2e08c   孙向锦   修复接口中的bug
253
254
255
256
257
  		PageData pd = this.getPageData();
  		ResponseGson<List<PageData>> res = new ResponseGson();
  		if (!pd.containsKey("SCHOOL_ID")) {
  			List<PageData> list = gradeService.listAll(pd);
  			res.setData(list);
91a745c9   孙向锦   完善后台功能
258
  		} else {
4fd2e08c   孙向锦   修复接口中的bug
259
260
  			List<PageData> list = schoolgradesubjectService.listAllGrade(pd);
  			res.setData(list);
bed6e1fc   孙向锦   添加其他功能
261
  		}
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
262
  		logger.info("class cost time : " + (System.currentTimeMillis() - cur));
bed6e1fc   孙向锦   添加其他功能
263
264
  		return res.toJson();
  	}
4fd2e08c   孙向锦   修复接口中的bug
265
266
267
268
  	
  	@RequestMapping(value = "/subject", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public Object subject() throws Exception {
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
269
  		long cur = System.currentTimeMillis();
4fd2e08c   孙向锦   修复接口中的bug
270
271
272
273
274
275
276
277
278
  		PageData pd = this.getPageData();
  		ResponseGson<List<PageData>> res = new ResponseGson();
  		if (!pd.containsKey("SCHOOL_ID")) {
  			List<PageData> list = subjectService.listAll(pd);
  			res.setData(list);
  		} else {
  			List<PageData> list = schoolgradesubjectService.listAllSubject(pd);
  			res.setData(list);
  		}
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
279
  		logger.info("subject cost time : " + (System.currentTimeMillis() - cur));
4fd2e08c   孙向锦   修复接口中的bug
280
281
282
283
  		return res.toJson();
  	}
  	
  	
91a745c9   孙向锦   完善后台功能
284
  
bed6e1fc   孙向锦   添加其他功能
285
286
287
  	@RequestMapping(value = "/keypadscan", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public Object keypadScan() throws Exception {
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
288
  		long cur = System.currentTimeMillis();
bed6e1fc   孙向锦   添加其他功能
289
  		PageData pd = this.getPageData();
91a745c9   孙向锦   完善后台功能
290
291
292
293
294
  		ResponseGson<String> res = new ResponseGson();
  		String ID = get32UUID();
  		pd.put("KEYPADCHECK_ID", ID); // 主键
  		pd.put("CREATE_DATE", Tools.date2Str(new Date())); // 创建时间
  		try {
bed6e1fc   孙向锦   添加其他功能
295
  			keypadcheckService.save(pd);
91a745c9   孙向锦   完善后台功能
296
  			res.setData(ID);
bed6e1fc   孙向锦   添加其他功能
297
  			res.setSuccess();
91a745c9   孙向锦   完善后台功能
298
  		} catch (Exception ex) {
bed6e1fc   孙向锦   添加其他功能
299
300
  			res.setDataError();
  		}
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
301
  		logger.info("keypadScan cost time : " + (System.currentTimeMillis() - cur));
bed6e1fc   孙向锦   添加其他功能
302
303
  		return res.toJson();
  	}
91a745c9   孙向锦   完善后台功能
304
  
bed6e1fc   孙向锦   添加其他功能
305
306
307
  	@RequestMapping(value = "/paper", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public Object paper() throws Exception {
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
308
  		long cur = System.currentTimeMillis();
bed6e1fc   孙向锦   添加其他功能
309
310
  		PageData pd = this.getPageData();
  		ResponseGson<List<PageData>> res = new ResponseGson<List<PageData>>();
91a745c9   孙向锦   完善后台功能
311
  		if (pd.containsKey("PAPER_TYPE") && pd.containsKey("USER_ID")) {
bed6e1fc   孙向锦   添加其他功能
312
313
314
  			Page page = new Page();
  			page.getPd().put("PAPER_TYPE", pd.get("PAPER_TYPE"));
  			page.getPd().put("USER_ID", pd.get("USER_ID"));
91a745c9   孙向锦   完善后台功能
315
  			if (pd.containsKey("CURRENTPAGE")) {
bed6e1fc   孙向锦   添加其他功能
316
  				String curpage = pd.getString("CURRENTPAGE");
91a745c9   孙向锦   完善后台功能
317
  				try {
bed6e1fc   孙向锦   添加其他功能
318
  					page.setCurrentPage(Integer.parseInt(curpage));
91a745c9   孙向锦   完善后台功能
319
320
  				} catch (Exception ex) {
  				}
bed6e1fc   孙向锦   添加其他功能
321
  			}
91a745c9   孙向锦   完善后台功能
322
  			if (pd.containsKey("SHOWCOUNT")) {
bed6e1fc   孙向锦   添加其他功能
323
  				String showCount = pd.getString("SHOWCOUNT");
91a745c9   孙向锦   完善后台功能
324
  				try {
bed6e1fc   孙向锦   添加其他功能
325
  					page.setShowCount(Integer.parseInt(showCount));
91a745c9   孙向锦   完善后台功能
326
327
328
  				} catch (Exception ex) {
  				}
  			} else {
bed6e1fc   孙向锦   添加其他功能
329
330
331
332
  				page.setShowCount(100);
  			}
  			List<PageData> pageList = paperService.listAllByType(page);
  			res.setData(pageList);
91a745c9   孙向锦   完善后台功能
333
  		} else {
338594c8   孙向锦   添加教师端页面
334
  			res.setParmError();
bed6e1fc   孙向锦   添加其他功能
335
  		}
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
336
  		logger.info("paper cost time : " + (System.currentTimeMillis() - cur));
bed6e1fc   孙向锦   添加其他功能
337
338
  		return res.toJson();
  	}
91a745c9   孙向锦   完善后台功能
339
340
  
  	@RequestMapping(value = "/paperinfo", produces = "application/json;charset=UTF-8")
bed6e1fc   孙向锦   添加其他功能
341
  	@ResponseBody
91a745c9   孙向锦   完善后台功能
342
  	public Object paperInfo() throws Exception {
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
343
  		long cur = System.currentTimeMillis();
bed6e1fc   孙向锦   添加其他功能
344
  		PageData pd = this.getPageData();
338594c8   孙向锦   添加教师端页面
345
  		ResponseGson<Paper> res = new ResponseGson<Paper>();
91a745c9   孙向锦   完善后台功能
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
  		if (pd.containsKey("PAPER_ID")) {
  			try {
  				try {
  					Paper paper = new Paper();
  					PageData ppd = paperService.findById(pd);
  					if (ppd != null) {
  						paper.setTitle(ppd.getString("TITLE"));
  						paper.setExam_time(ppd.getString("EXAM_TIME"));
  						paper.setUser_id(ppd.getString("USER_ID"));
  						paper.setPaper_type(ppd.getString("PAPER_TYPE"));
  						paper.setSubject_id(ppd.getString("SUBJECT_ID"));
  						paper.setGrade_id(ppd.getString("GRADE_ID"));
  						paper.setScore(ppd.getString("SCORE"));
  						paper.setQuestions(new ArrayList<Question>());
  
  						List<PageData> questList = v1Service
  								.getTestPaperInfo(pd);
  						for (PageData qpd : questList) {
  							Question question = new Question();
  							question.setAnswer(qpd.getString("ANSWER"));
  							question.setQuestion_id(qpd
  									.getString("QUESTION_ID"));
  							question.setSubject_id(qpd.getString("SUBJECT_ID"));
  							question.setChapter_id(qpd.getString("CHAPTER_ID"));
  							question.setProblem_type_id(qpd
  									.getString("PROBLEM_TYPE_ID"));
  							question.setKnowledge_id(qpd
  									.getString("KNOWLEDGE_ID"));
  							question.setContent(qpd.getString("CONTENT"));
  							question.setOption_num(qpd.getString("OPTION_NUM"));
  							question.setOption_content(qpd
  									.getString("OPTION_CONTENT"));
  							question.setDifficulty(qpd.getString("DIFFICULTY"));
  							question.setAnalysis(qpd.getString("ANALYSIS"));
  							question.setQuestion_from(qpd
  									.getString("QUESTION_FROM"));
4fd2e08c   孙向锦   修复接口中的bug
382
383
384
385
  							question.setScore(qpd.getString("SCORE"));
  							question.setPart_score(qpd
  									.getString("PART_SCORE"));
  							question.setQuestionType(qpd.getString("PROBLEM_TYPE_ID"));
91a745c9   孙向锦   完善后台功能
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
  							question.setRank(qpd.getString("RANK"));
  							question.setNo_name(qpd.getString("NO_NAME"));
  							if ("-1".equals("" + qpd.getString("P_ID"))) {
  								PageData pidPd = new PageData();
  								pidPd.put("PID", question.getQuestion_id());
  								question.setQuestions(new ArrayList<Question>());
  								List<PageData> qs = v1Service
  										.getQuestionsByPID(pidPd);
  								for (PageData q : qs) {
  									Question qq = new Question();
  									qq.setAnswer(q.getString("ANSWER"));
  									qq.setQuestion_id(q
  											.getString("QUESTION_ID"));
  									qq.setSubject_id(q.getString("SUBJECT_ID"));
  									qq.setChapter_id(q.getString("CHAPTER_ID"));
  									qq.setProblem_type_id(q
  											.getString("PROBLEM_TYPE_ID"));
  									qq.setKnowledge_id(q
  											.getString("KNOWLEDGE_ID"));
  									qq.setContent(q.getString("CONTENT"));
  									qq.setOption_num(q.getString("OPTION_NUM"));
  									qq.setOption_content(q
  											.getString("OPTION_CONTENT"));
  									qq.setDifficulty(q.getString("DIFFICULTY"));
  									qq.setAnalysis(q.getString("ANALYSIS"));
  									qq.setQuestion_from(q
  											.getString("QUESTION_FROM"));
4fd2e08c   孙向锦   修复接口中的bug
413
414
415
416
  									qq.setScore(q.getString("SCORE"));
  									qq.setPart_score(q
  											.getString("PART_SCORE"));
  									qq.setQuestionType(qpd.getString("PROBLEM_TYPE_ID"));
91a745c9   孙向锦   完善后台功能
417
418
419
420
421
422
423
424
425
  									qq.setRank(q.getString("RANK"));
  									qq.setNo_name(q.getString("NO_NAME"));
  									question.getQuestions().add(qq);
  								}
  							}
  							if ("-1".equals(qpd.getString("P_ID"))
  									|| "0".equals(qpd.getString("P_ID"))) {
  								paper.getQuestions().add(question);
  							}
338594c8   孙向锦   添加教师端页面
426
  						}
91a745c9   孙向锦   完善后台功能
427
428
429
430
  						// pd.put("JSON", paper.toJson());
  						res.setData(paper);
  						logger.info(paper.toJson());
  
338594c8   孙向锦   添加教师端页面
431
  					}
91a745c9   孙向锦   完善后台功能
432
433
  				} catch (Exception ex) {
  					ex.printStackTrace();
338594c8   孙向锦   添加教师端页面
434
  				}
91a745c9   孙向锦   完善后台功能
435
  			} catch (Exception ex) {
338594c8   孙向锦   添加教师端页面
436
437
  				ex.printStackTrace();
  				res.setError();
bed6e1fc   孙向锦   添加其他功能
438
  			}
91a745c9   孙向锦   完善后台功能
439
  		} else {
bed6e1fc   孙向锦   添加其他功能
440
441
  			res.setOtherError();
  		}
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
442
  		logger.info("paperInfo cost time : " + (System.currentTimeMillis() - cur));
bed6e1fc   孙向锦   添加其他功能
443
444
  		return res.toJson();
  	}
91a745c9   孙向锦   完善后台功能
445
  
bed6e1fc   孙向锦   添加其他功能
446
447
448
  	@RequestMapping(value = "/paperquestion", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public Object paperQuestion() throws Exception {
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
449
  		long cur = System.currentTimeMillis();
bed6e1fc   孙向锦   添加其他功能
450
451
  		PageData pd = this.getPageData();
  		ResponseGson<PageData> res = new ResponseGson();
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
452
  		logger.info("paperquestion cost time : " + (System.currentTimeMillis() - cur));
bed6e1fc   孙向锦   添加其他功能
453
454
  		return res.toJson();
  	}
4fd2e08c   孙向锦   修复接口中的bug
455
456
457
458
  	
  	@RequestMapping(value = "/question", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public Object question() throws Exception {
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
459
  		long cur = System.currentTimeMillis();
4fd2e08c   孙向锦   修复接口中的bug
460
461
462
463
464
465
466
467
468
  		PageData pd = this.getPageData();
  		ResponseGson<PageData> res = new ResponseGson();
  		if(pd.containsKey("ID")){
  			pd.put("QUESTION_ID", pd.get("ID"));
  			PageData data = questionService.findById(pd);
  			res.setData(data);
  		}else{
  			res.setDataError();
  		}
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
469
  		logger.info("question cost time : " + (System.currentTimeMillis() - cur));
4fd2e08c   孙向锦   修复接口中的bug
470
471
472
473
474
475
  		return res.toJson();
  	}
  	
  	@RequestMapping(value = "/question/add", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public Object questionAdd() throws Exception {
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
476
  		long cur = System.currentTimeMillis();
4fd2e08c   孙向锦   修复接口中的bug
477
478
479
480
  		PageData pd = this.getPageData();
  		ResponseGson<PageData> res = new ResponseGson();
  		pd.put("QUESTION_ID", this.get32UUID());
  		questionService.save(pd);
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
481
  		logger.info("questionAdd cost time : " + (System.currentTimeMillis() - cur));
4fd2e08c   孙向锦   修复接口中的bug
482
483
484
  		return res.toJson();
  	}
  	
338594c8   孙向锦   添加教师端页面
485
486
487
  	@RequestMapping(value = "/uploadpaper", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public Object uploadpaper() throws Exception {
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
488
  		long cur = System.currentTimeMillis();
338594c8   孙向锦   添加教师端页面
489
490
  		PageData pd = this.getPageData();
  		ResponseGson<String> res = new ResponseGson();
91a745c9   孙向锦   完善后台功能
491
492
  
  		if (!StringUtils.isEmpty(pd.getJsonString())) {
4fd2e08c   孙向锦   修复接口中的bug
493
  			logger.info(pd.getJsonString());
338594c8   孙向锦   添加教师端页面
494
495
496
497
  			Paper paper = Paper.parse(pd.getJsonString());
  			PageData paperPd = new PageData();
  			String paperID = this.get32UUID();
  			res.setData(paperID);
91a745c9   孙向锦   完善后台功能
498
499
500
501
502
503
504
505
506
507
  			paperPd.put("PAPER_ID", paperID);
  			paperPd.put("TITLE", paper.getTitle());
  			paperPd.put("USER_ID", paper.getUser_id());
  			paperPd.put("PAPER_TYPE", paper.getPaper_type());
  			paperPd.put("SUBJECT_ID", paper.getSubject_id());
  			paperPd.put("GRADE_ID", paper.getGrade_id());
  			paperPd.put("EXAM_TIME", paper.getExam_time());
  			paperPd.put("SCORE", paper.getScore());
  			paperPd.put("PAPER_STATE", "0");
  			paperPd.put("REMARK", "");
338594c8   孙向锦   添加教师端页面
508
509
  			String schoolID = Myelfun.getUserID(paper.getUser_id());
  			paperPd.put("SCHOOL_ID", schoolID);
91a745c9   孙向锦   完善后台功能
510
511
512
  			paperPd.put("CREATE_DATE", Tools.date2Str(new Date()));
  			paperPd.put("MODIFY_DATE", Tools.date2Str(new Date()));
  
4fd2e08c   孙向锦   修复接口中的bug
513
514
  			int questionNum = 0 ;
  			
91a745c9   孙向锦   完善后台功能
515
  
338594c8   孙向锦   添加教师端页面
516
  			List<Question> questions = paper.getQuestions();
91a745c9   孙向锦   完善后台功能
517
518
  			if (questions != null) {
  				for (Question question : questions) {
338594c8   孙向锦   添加教师端页面
519
520
521
  					String questionID = this.get32UUID();
  					PageData qPd = new PageData();
  					qPd.put("QUESTION_ID", questionID);
91a745c9   孙向锦   完善后台功能
522
523
  					if (question.getQuestions() != null
  							&& question.getQuestions().size() > 0) {
338594c8   孙向锦   添加教师端页面
524
  						qPd.put("P_ID", "-1");
91a745c9   孙向锦   完善后台功能
525
  					} else {
4fd2e08c   孙向锦   修复接口中的bug
526
  						questionNum ++ ;
338594c8   孙向锦   添加教师端页面
527
528
529
530
  						qPd.put("P_ID", "0");
  					}
  					qPd.put("SUBJECT_ID", paper.getSubject_id());
  					qPd.put("CHAPTER_ID", question.getChapter_id());
4fd2e08c   孙向锦   修复接口中的bug
531
  					qPd.put("PROBLEM_TYPE_ID", question.getProblem_type_id() == null ? "1" :  question.getProblem_type_id());
338594c8   孙向锦   添加教师端页面
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
  					qPd.put("TEACHER_ID", paper.getUser_id());
  					qPd.put("SCHOOL_ID", schoolID);
  					qPd.put("KNOWLEDGE_ID", question.getKnowledge_id());
  					qPd.put("CONTENT", question.getContent());
  					qPd.put("OPTION_NUM", question.getOption_num());
  					qPd.put("OPTION_CONTENT", question.getOption_content());
  					qPd.put("ANSWER", question.getAnswer());
  					qPd.put("DIFFICULTY", question.getDifficulty());
  					qPd.put("ANALYSIS", question.getAnalysis());
  					qPd.put("QUESTION_FROM", question.getQuestion_from());
  					qPd.put("SUG_SCORE", question.getScore());
  					qPd.put("SUG_PART_SCORE", question.getPart_score());
  					qPd.put("USER_ID", paper.getUser_id());
  					qPd.put("CREATE_DATE", Tools.date2Str(new Date()));
  					qPd.put("REMARK", "");
  					questionService.save(qPd);
91a745c9   孙向锦   完善后台功能
548
  
338594c8   孙向锦   添加教师端页面
549
  					PageData pqPd = new PageData();
91a745c9   孙向锦   完善后台功能
550
551
552
553
554
555
556
  					pqPd.put("PAPER_ID", paperID);
  					pqPd.put("QUESTION_ID", questionID);
  					pqPd.put("SCORE", question.getScore());
  					pqPd.put("PART_SCORE", "0");
  					pqPd.put("RANK", question.getRank());
  					pqPd.put("NO_NAME", question.getNo_name());
  					pqPd.put("PAPERQUESTION_ID", this.get32UUID());
338594c8   孙向锦   添加教师端页面
557
  					paperquestionService.save(pqPd);
91a745c9   孙向锦   完善后台功能
558
559
  
  					if (question.getQuestions() != null) {
338594c8   孙向锦   添加教师端页面
560
  						List<Question> qs = question.getQuestions();
91a745c9   孙向锦   完善后台功能
561
  						for (Question q : qs) {
338594c8   孙向锦   添加教师端页面
562
563
564
565
566
567
  							String qID = this.get32UUID();
  							PageData cqPd = new PageData();
  							cqPd.put("QUESTION_ID", qID);
  							cqPd.put("P_ID", questionID);
  							cqPd.put("SUBJECT_ID", paper.getSubject_id());
  							cqPd.put("CHAPTER_ID", q.getChapter_id());
4fd2e08c   孙向锦   修复接口中的bug
568
  							cqPd.put("PROBLEM_TYPE_ID", question.getProblem_type_id() == null ? "1" :  question.getProblem_type_id());
338594c8   孙向锦   添加教师端页面
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
  							cqPd.put("TEACHER_ID", paper.getUser_id());
  							cqPd.put("SCHOOL_ID", schoolID);
  							cqPd.put("KNOWLEDGE_ID", q.getKnowledge_id());
  							cqPd.put("CONTENT", q.getContent());
  							cqPd.put("OPTION_NUM", q.getOption_num());
  							cqPd.put("OPTION_CONTENT", q.getOption_content());
  							cqPd.put("ANSWER", q.getAnswer());
  							cqPd.put("DIFFICULTY", q.getDifficulty());
  							cqPd.put("ANALYSIS", q.getAnalysis());
  							cqPd.put("QUESTION_FROM", q.getQuestion_from());
  							cqPd.put("SUG_SCORE", q.getScore());
  							cqPd.put("SUG_PART_SCORE", q.getSug_part_score());
  							cqPd.put("USER_ID", paper.getUser_id());
  							cqPd.put("CREATE_DATE", Tools.date2Str(new Date()));
  							cqPd.put("REMARK", "");
91a745c9   孙向锦   完善后台功能
584
  
338594c8   孙向锦   添加教师端页面
585
  							questionService.save(cqPd);
91a745c9   孙向锦   完善后台功能
586
  
338594c8   孙向锦   添加教师端页面
587
  							PageData cpqPd = new PageData();
91a745c9   孙向锦   完善后台功能
588
589
590
591
592
593
594
595
  							cpqPd.put("PAPER_ID", paperID);
  							cpqPd.put("QUESTION_ID", qID);
  							cpqPd.put("SCORE", q.getScore());
  							cpqPd.put("PART_SCORE", "0");
  							cpqPd.put("RANK", q.getRank());
  							cpqPd.put("NO_NAME", q.getNo_name());
  							cpqPd.put("PAPERQUESTION_ID", this.get32UUID());
  
338594c8   孙向锦   添加教师端页面
596
  							paperquestionService.save(cpqPd);
4fd2e08c   孙向锦   修复接口中的bug
597
  							questionNum ++ ;
338594c8   孙向锦   添加教师端页面
598
599
600
601
  						}
  					}
  				}
  			}
4fd2e08c   孙向锦   修复接口中的bug
602
603
  			paperPd.put("QUESTION_NUM", "" + questionNum);
  			paperService.save(paperPd);
91a745c9   孙向锦   完善后台功能
604
605
  
  		} else {
338594c8   孙向锦   添加教师端页面
606
607
  			res.setDataError();
  		}
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
608
  		logger.info("uploadpaper cost time : " + (System.currentTimeMillis() - cur));
91a745c9   孙向锦   完善后台功能
609
610
611
612
613
614
615
  		return res.toJson();
  	}
  
  	// 上传测验成绩
  	@RequestMapping(value = "/uploadtestpaper", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public Object uploadTestpaper() {
4fd2e08c   孙向锦   修复接口中的bug
616
  		long cur = System.currentTimeMillis();
91a745c9   孙向锦   完善后台功能
617
618
619
  		PageData pd = this.getPageData();
  		ResponseGson<String> res = new ResponseGson();
  		if (!StringUtils.isEmpty(pd.getJsonString())) {
4fd2e08c   孙向锦   修复接口中的bug
620
  			logger.info(pd.getJsonString());
91a745c9   孙向锦   完善后台功能
621
622
623
624
  			TestPaper testPaper = TestPaper.parse(pd.getJsonString());
  			try {
  				PageData testPd = new PageData();
  				String testPaperId = this.get32UUID();
91a745c9   孙向锦   完善后台功能
625
  				testPd.put("TEACHER_ID", testPaper.getTeacherId());
91a745c9   孙向锦   完善后台功能
626
627
  				testPd.put("PAPER_ID", testPaper.getPaperId());
  				testPd.put("SCLASS_ID", testPaper.getClassId());
91a745c9   孙向锦   完善后台功能
628
629
630
631
632
  				testPd.put(
  						"CREATE_DATE",
  						testPaper.getCreateDate() == null ? Tools
  								.date2Str(new Date()) : testPaper
  								.getCreateDate());
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
  				List<PageData> listData = testpaperService.listAll(testPd);
  				if (!(listData != null && listData.size() > 0)) {
  					testPd.put("START_DATE", testPaper.getStartDate());
  					testPd.put("END_DATE", testPaper.getEndDate());
  					testPd.put("NAME", testPaper.getName());
  					testPd.put("TESTPAPER_ID", testPaperId);
  					testPd.put("OTHER_SCORE", testPaper.getOtherScore());
  					testPd.put("HIGHT_SCORE", testPaper.getHighScore());
  					testPd.put("LOW_SCORE", testPaper.getLowScore());
  					testPd.put("AVG_SCORE", testPaper.getAvgScore());
  					testPd.put("REMARK", testPaper.getRemark());
  					testpaperService.save(testPd);
  					if (testPaper.getStudents() != null) {
  						List<PageData> testInfoPdList = new ArrayList();
  						PageData testInfoPd = null;
  						for (StudentAnswer studentAnswer : testPaper
  								.getStudents()) {
  							if (studentAnswer.getQuestions() != null) {
  								PageData studentPageData = new PageData();
  								studentPageData.put("STUDENTTEST_ID",
  										get32UUID());
  								studentPageData.put("STUDENT_ID",
  										studentAnswer.getStudentId());
  								studentPageData.put("TEST_ID", testPaperId);
  								studentPageData.put("PAPER_ID",
  										testPaper.getPaperId());
  								studentPageData.put("SCORE",
  										studentAnswer.getScore());
  								studentPageData.put("CLASS_ID",
  										testPaper.getClassId());
  								studenttestService.save(studentPageData);
  
  								for (TestPaperInfo testPaperInfo : studentAnswer
  										.getQuestions()) {
  									testInfoPd = new PageData();
  									testInfoPd.put("TESTPAPERINFO_ID",
  											this.get32UUID());
  									testInfoPd.put("PAPER_ID",
  											testPaper.getPaperId());
  									testInfoPd.put("STUDENT_ID",
  											studentAnswer.getStudentId());
  									testInfoPd.put("TEST_ID", testPaperId);
  									testInfoPd.put("QUESTION_ID",
  											testPaperInfo.getQuestionId());
  									testInfoPd.put("ANSWER",
  											testPaperInfo.getAnswer());
  									testInfoPd.put("RIGHT",
  											testPaperInfo.getRight());
  									testInfoPd.put("SCORE",
  											testPaperInfo.getScore());
  									testInfoPd.put("LIKES",
  											testPaperInfo.getLikes());
  									testInfoPd
  											.put("ANSWER_TYPE",
  													testPaperInfo
  															.getAnswerType() == null ? "1"
  															: testPaperInfo
  																	.getAnswerType());
  									testInfoPd.put("PRESS_TIME",
  											testPaperInfo.getPressTime());
  									testInfoPd.put("RECEIVER_DATE",
  											testPaperInfo.getReceiverDate());
  									testInfoPd.put("SUBJECTIVE",
  											testPaperInfo.getSubjective());
  									testInfoPd.put("NOTE",
  											testPaperInfo.getNote());
  									testInfoPd.put("MARK_NO",
  											testPaperInfo.getMarkNo());
  									testInfoPdList.add(testInfoPd);
  								}
  							}
  						}
  						testpaperinfoService.batchSave(testInfoPdList);
  					}
  				}else{
  					testPaperId = listData.get(0).getString("TESTPAPER_ID");
  				}
  				res.setData(testPaperId);
  			} catch (Exception e) {
  				e.printStackTrace();
  				res.setError();
  				res.setMessage(e.getMessage());
  			}
  		} else {
  			res.setDataError();
  		}
  		logger.info("uploadtestpaper cost time:" + (System.currentTimeMillis() - cur));
  
  		return res.toJson();
  
  	}
  	
  	
  	// 上传测验成绩
  	@RequestMapping(value = "/uploadupdatetestpaper", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public Object uploadupdateTestpaper() {
  		long cur = System.currentTimeMillis();
  		PageData pd = this.getPageData();
  		ResponseGson<String> res = new ResponseGson();
  		if (!StringUtils.isEmpty(pd.getJsonString())) {
  			logger.info(pd.getJsonString());
  			TestPaper testPaper = TestPaper.parse(pd.getJsonString());
  			try {
  				PageData testPd = new PageData();
  				String testPaperId = this.get32UUID();
  				testPd.put("TEACHER_ID", testPaper.getTeacherId());
  				testPd.put("PAPER_ID", testPaper.getPaperId());
  				testPd.put("SCLASS_ID", testPaper.getClassId());
  				testPd.put(
  						"CREATE_DATE",
  						testPaper.getCreateDate() == null ? Tools
  								.date2Str(new Date()) : testPaper
  								.getCreateDate());
  				List<PageData> listData = testpaperService.listAll(testPd);
  				if ((listData != null && listData.size() > 0)) {
  					testPaperId = listData.get(0).getString("TESTPAPER_ID");
  					testpaperService.deleteList(testPd);
  					testPd.put("TEST_ID", testPaperId);
  					testpaperinfoService.delete(testPd);
  					studenttestService.delete(testPd);
  				}
  				testPd.put("START_DATE", testPaper.getStartDate());
  				testPd.put("END_DATE", testPaper.getEndDate());
  				testPd.put("NAME", testPaper.getName());
  				testPd.put("TESTPAPER_ID", testPaperId);
91a745c9   孙向锦   完善后台功能
759
760
761
762
763
764
765
  				testPd.put("OTHER_SCORE", testPaper.getOtherScore());
  				testPd.put("HIGHT_SCORE", testPaper.getHighScore());
  				testPd.put("LOW_SCORE", testPaper.getLowScore());
  				testPd.put("AVG_SCORE", testPaper.getAvgScore());
  				testPd.put("REMARK", testPaper.getRemark());
  				testpaperService.save(testPd);
  				if (testPaper.getStudents() != null) {
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
766
767
  					List<PageData> testInfoPdList = new ArrayList();
  					PageData testInfoPd = null;
91a745c9   孙向锦   完善后台功能
768
769
770
  					for (StudentAnswer studentAnswer : testPaper.getStudents()) {
  						if (studentAnswer.getQuestions() != null) {
  							PageData studentPageData = new PageData();
91a745c9   孙向锦   完善后台功能
771
772
773
774
775
776
777
778
779
  							studentPageData.put("STUDENT_ID",
  									studentAnswer.getStudentId());
  							studentPageData.put("TEST_ID", testPaperId);
  							studentPageData.put("PAPER_ID",
  									testPaper.getPaperId());
  							studentPageData.put("SCORE",
  									studentAnswer.getScore());
  							studentPageData.put("CLASS_ID",
  									testPaper.getClassId());
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
780
  							studentPageData.put("STUDENTTEST_ID", get32UUID());
91a745c9   孙向锦   完善后台功能
781
782
783
784
  							studenttestService.save(studentPageData);
  
  							for (TestPaperInfo testPaperInfo : studentAnswer
  									.getQuestions()) {
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
785
  								testInfoPd = new PageData();
91a745c9   孙向锦   完善后台功能
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
  								testInfoPd.put("TESTPAPERINFO_ID",
  										this.get32UUID());
  								testInfoPd.put("PAPER_ID",
  										testPaper.getPaperId());
  								testInfoPd.put("STUDENT_ID",
  										studentAnswer.getStudentId());
  								testInfoPd.put("TEST_ID", testPaperId);
  								testInfoPd.put("QUESTION_ID",
  										testPaperInfo.getQuestionId());
  								testInfoPd.put("ANSWER",
  										testPaperInfo.getAnswer());
  								testInfoPd.put("RIGHT",
  										testPaperInfo.getRight());
  								testInfoPd.put("SCORE",
  										testPaperInfo.getScore());
  								testInfoPd.put("LIKES",
  										testPaperInfo.getLikes());
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
803
804
805
  								testInfoPd.put("ANSWER_TYPE", testPaperInfo
  										.getAnswerType() == null ? "1"
  										: testPaperInfo.getAnswerType());
91a745c9   孙向锦   完善后台功能
806
807
808
809
810
811
812
813
814
  								testInfoPd.put("PRESS_TIME",
  										testPaperInfo.getPressTime());
  								testInfoPd.put("RECEIVER_DATE",
  										testPaperInfo.getReceiverDate());
  								testInfoPd.put("SUBJECTIVE",
  										testPaperInfo.getSubjective());
  								testInfoPd.put("NOTE", testPaperInfo.getNote());
  								testInfoPd.put("MARK_NO",
  										testPaperInfo.getMarkNo());
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
815
  								testInfoPdList.add(testInfoPd);
91a745c9   孙向锦   完善后台功能
816
817
818
  							}
  						}
  					}
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
819
  					testpaperinfoService.batchSave(testInfoPdList);
91a745c9   孙向锦   完善后台功能
820
821
822
823
824
825
826
827
828
829
  				}
  				res.setData(testPaperId);
  			} catch (Exception e) {
  				e.printStackTrace();
  				res.setError();
  				res.setMessage(e.getMessage());
  			}
  		} else {
  			res.setDataError();
  		}
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
830
831
  		logger.info("uploadtestpaper cost time:"
  				+ (System.currentTimeMillis() - cur));
91a745c9   孙向锦   完善后台功能
832
833
834
835
836
837
838
839
840
  
  		return res.toJson();
  
  	}
  
  	// 下载测验成绩
  	@RequestMapping(value = "/downloadtestpaper", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public Object downloadTestpaper() {
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
841
  		long cur = System.currentTimeMillis();
91a745c9   孙向锦   完善后台功能
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
  		PageData pd = this.getPageData();
  		ResponseGson<TestPaper> res = new ResponseGson();
  
  		String paperId = pd.getString("ID");
  
  		if (!StringUtils.isEmpty(paperId)) {
  			TestPaper testPaper = new TestPaper();
  			try {
  				pd.put("TESTPAPER_ID", paperId);
  				PageData testPd = testpaperService.findById(pd);
  				if (testPd != null) {
  					testPaper.setTestpaperId(paperId);
  					testPaper.setTeacherId(testPd.getString("TEACHER_ID"));
  					testPaper.setName(testPd.getString("NAME"));
  					testPaper.setPaperId(testPd.getString("PAPER_ID"));
  					testPaper.setClassId(testPd.getString("SCLASS_ID"));
  					testPaper.setStartDate(testPd.getString("START_DATE"));
  					testPaper.setEndDate(testPd.getString("END_DATE"));
  					testPaper.setCreateDate(testPd.getString("CREATE_DATE"));
  					testPaper.setOtherScore(testPd.getString("OTHER_SCORE"));
  					testPaper.setHighScore(testPd.getString("HIGHT_SCORE"));
  					testPaper.setLowScore(testPd.getString("LOW_SCORE"));
  					testPaper.setAvgScore(testPd.getString("AVG_SCORE"));
  					testPaper.setRemark(testPd.getString("REMARK"));
  					PageData testInfof = new PageData();
  					testInfof.put("TEST_ID", paperId);
  
  					List<PageData> studentList = studenttestService
  							.listAll(testInfof);
  
  					for (PageData sPageData : studentList) {
  						StudentAnswer studentAnswer = new StudentAnswer();
  						testInfof.put("STDUENT_ID",
  								sPageData.getString("STDUENT_ID"));
  						studentAnswer.setScore(sPageData.getString("SCORE"));
  						List<PageData> list = testpaperinfoService
  								.listAll(testInfof);
  						for (PageData testInfoPd : list) {
  							TestPaperInfo testPaperInfo = new TestPaperInfo();
  							testPaperInfo.setTestPaperInfoId(testInfoPd
  									.getString("TESTPAPERINFO_ID"));
  							testPaperInfo.setQuestionId(testInfoPd
  									.getString("QUESTION_ID"));
  							testPaperInfo.setAnswer(testInfoPd
  									.getString("ANSWER"));
  							testPaperInfo.setRight(testInfoPd
  									.getString("RIGHT"));
  							testPaperInfo.setScore(testInfoPd
  									.getString("SCORE"));
  							testPaperInfo.setLikes(testInfoPd
  									.getString("LIKES"));
  							testPaperInfo.setAnswerType(testInfoPd
  									.getString("ANSWER_TYPE"));
  							testPaperInfo.setPressTime(testInfoPd
  									.getString("PRESS_TIME"));
  							testPaperInfo.setReceiverDate(testInfoPd
  									.getString("RECEIVER_DATE"));
  							testPaperInfo.setSubjective(testInfoPd
  									.getString("SUBJECTIVE"));
  							testPaperInfo.setNote(testInfoPd.getString("NOTE"));
  							testPaperInfo.setMarkNo(testInfoPd
  									.getString("MARK_NO"));
  							testPaperInfo.setRank(testInfoPd.getString("RANK"));
  							studentAnswer.getQuestions().add(testPaperInfo);
  						}
  						testPaper.getStudents().add(studentAnswer);
  					}
  				}
  
  				res.setData(testPaper);
  			} catch (Exception e) {
  				e.printStackTrace();
  				res.setError();
  			}
  		}
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
917
  		logger.info("downloadtestpaper cost time:" + (System.currentTimeMillis() - cur));
338594c8   孙向锦   添加教师端页面
918
  		return res.toJson();
91a745c9   孙向锦   完善后台功能
919
  
338594c8   孙向锦   添加教师端页面
920
921
  	}
  
91a745c9   孙向锦   完善后台功能
922
923
924
925
  	// 下载测验成绩
  	@RequestMapping(value = "/testpaper", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public Object testpaper() {
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
926
  		long cur = System.currentTimeMillis();
91a745c9   孙向锦   完善后台功能
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
  		PageData pd = this.getPageData();
  		ResponseGson<List<TestPaper>> res = new ResponseGson();
  		pd.put("TEACHER_ID", pd.getString("USER_ID"));
  		try {
  			List<PageData> pageList = testpaperService.listAll(pd);
  			List<TestPaper> list = new ArrayList<TestPaper>();
  			if (pageList != null) {
  				for (PageData testPd : pageList) {
  					TestPaper testPaper = new TestPaper();
  					testPaper.setTestpaperId(testPd.getString("TESTPAPER_ID"));
  					testPaper.setTeacherId(testPd.getString("TEACHER_ID"));
  					testPaper.setName(testPd.getString("NAME"));
  					testPaper.setPaperId(testPd.getString("PAPER_ID"));
  					testPaper.setClassId(testPd.getString("SCLASS_ID"));
  					testPaper.setStartDate(testPd.getString("START_DATE"));
  					testPaper.setEndDate(testPd.getString("END_DATE"));
  					testPaper.setCreateDate(testPd.getString("CREATE_DATE"));
  					testPaper.setOtherScore(testPd.getString("OTHER_SCORE"));
  					testPaper.setHighScore(testPd.getString("HIGHT_SCORE"));
  					testPaper.setLowScore(testPd.getString("LOW_SCORE"));
  					testPaper.setAvgScore(testPd.getString("AVG_SCORE"));
  					testPaper.setRemark(testPd.getString("REMARK"));
  					list.add(testPaper);
  				}
  			}
  			res.setData(list);
  		} catch (Exception e) {
  			res.setError();
  			res.setMessage(e.getMessage());
  			e.printStackTrace();
  		}
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
958
  		logger.info("testpaper cost time:" + (System.currentTimeMillis() - cur));
91a745c9   孙向锦   完善后台功能
959
960
961
  		return res.toJson();
  
  	}
4fd2e08c   孙向锦   修复接口中的bug
962
963
964
965
966
967
968
  	
  	
  	@RequestMapping(value = "/schooladmin", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public void schoolAdmin(){
  		PageData pd = this.getPageData();
  		this.getUserID();
4fd2e08c   孙向锦   修复接口中的bug
969
970
  	}
  	
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
  	@RequestMapping(value = "/newversion", produces = "application/json;charset=UTF-8")
  	@ResponseBody
  	public Object getNewVersion(HttpServletRequest request) throws Exception{
  		PageData pd = this.getPageData();
  		String softId = pd.getString("SOFTID");
  		String path = request.getContextPath();
  		String basePath = request.getScheme() + "://"
  				+ request.getServerName() + ":" + request.getServerPort()
  				+ path + "/";
  		ResponseGson<PageData> res = new ResponseGson();
  		if(softId != null && !"".equals(softId)){
  			pd.put("SOFTWARE_ID", softId);
  			PageData result = softwareversionService.findNewVersion(pd);
  			if(result != null){
  				result.remove("SOFTWAREVERSION_ID");
  				result.remove("SOFTWARE_ID");
9452be31   孙向锦   添加高斯的客户反馈
987
  				result.put("VERSION_PATH",basePath + "uploadFiles/uploadFile/" + result.getString("VERSION_PATH"));
2480c889   孙向锦   添加软件管理模块。对软件形成统一的管理
988
989
990
991
992
993
994
995
996
997
998
999
1000
  				res.setData(result);
  			}else{
  				res.setDataError();
  			}
  		}else{
  			res.setDataError();
  		}
  		return res.toJson();
  	}
  	
  	
  
  	
bed6e1fc   孙向锦   添加其他功能
1001
  }