using System; using System.Collections.Generic; using System.Configuration; using System.Drawing; using System.IO; using System.Linq; using System.Net; using System.Net.Http; using System.Web.Http; using BLL; namespace WebAPI.Controllers { /// /// 考试-考生记录信息 /// public class TestRecordController : ApiController { #region 根据TestPlanId获取考生及试卷列表 /// /// 根据TestPlanId获取考生及试卷列表 /// /// /// 考试人员 public Model.ResponeData getTestRecordListByTestPlanId(string testPlanId) { var responeData = new Model.ResponeData(); try { responeData.data = APITestRecordService.getTestRecordListByTestPlanId(testPlanId); } catch (Exception ex) { responeData.code = 0; responeData.message = ex.Message; } return responeData; } #endregion #region 根据试卷ID获取试卷记录详细 /// /// 根据试卷ID获取试卷记录详细 /// /// /// 试卷详细 public Model.ResponeData getTestRecordByTestRecordId(string testRecordId) { var responeData = new Model.ResponeData(); try { responeData.data = APITestRecordService.getTestRecordByTestRecordId(testRecordId); } catch (Exception ex) { responeData.code = 0; responeData.message = ex.Message; } return responeData; } #endregion #region 根据TestRecordId获取试卷题目列表 /// /// 根据TestRecordId获取试卷题目列表 /// /// /// 页码 /// 试卷题目列表 public Model.ResponeData getTestRecordItemListByTestRecordId(string testRecordId, int pageIndex) { var responeData = new Model.ResponeData(); try { var getDataLists = APITestRecordService.geTestRecordItemListByTestRecordId(testRecordId); int pageCount = getDataLists.Count; if (pageCount > 0 && pageIndex > 0) { getDataLists = getDataLists.OrderBy(x => x.TestType).ThenBy(x => x.TrainingItemCode).Skip(Funs.PageSize * (pageIndex - 1)).Take(Funs.PageSize).ToList(); } responeData.data = new { pageCount, getDataLists }; } catch (Exception ex) { responeData.code = 0; responeData.message = ex.Message; } return responeData; } #endregion #region 获取当前试卷的答题倒计时 /// /// 获取当前试卷的答题倒计时 /// /// /// public Model.ResponeData getTestTimesByTestRecordId(string testRecordId) { var responeData = new Model.ResponeData(); try { int mTime = 0; using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString)) { var getTestRecord = db.Training_TestRecord.FirstOrDefault(e => e.TestRecordId == testRecordId); if (getTestRecord != null) { DateTime startTime = DateTime.Now; if (getTestRecord.TestStartTime.HasValue) { startTime = getTestRecord.TestStartTime.Value; } else { getTestRecord.TestStartTime = startTime; db.SubmitChanges(); } mTime = Convert.ToInt32((getTestRecord.TestStartTime.Value.AddMinutes(getTestRecord.Duration) - DateTime.Now).TotalSeconds); } } responeData.data = new { mTime }; } catch (Exception ex) { responeData.code = 0; responeData.message = ex.Message; } return responeData; } #endregion #region 根据TestRecordItemId获取试卷题目详细 /// /// 根据TestRecordItemId获取试卷题目详细 /// /// /// 考试人员 public Model.ResponeData getTestRecordItemByTestRecordItemId(string testRecordItemId) { var responeData = new Model.ResponeData(); try { responeData.data = APITestRecordService.geTestRecordItemByTestRecordItemId(testRecordItemId); } catch (Exception ex) { responeData.code = 0; responeData.message = ex.Message; } return responeData; } #endregion #region 根据ProjectId、PersonId获取当前人试卷列表 /// /// 根据ProjectId、PersonId获取当前人试卷列表 /// /// 项目ID /// 人员ID(null查全部) /// 页码 /// 考试记录列表 public Model.ResponeData getTrainingTestRecordListByProjectIdPersonId(string projectId, string personId, int pageIndex) { var responeData = new Model.ResponeData(); try { personId = PersonService.GetPersonIdByUserId(personId); var getDataLists = APITestRecordService.getTrainingTestRecordListByProjectIdPersonId(projectId, personId); int pageCount = getDataLists.Count; if (pageCount > 0 && pageIndex > 0) { getDataLists = getDataLists.OrderByDescending(x => x.TestStartTime).Skip(Funs.PageSize * (pageIndex - 1)).Take(Funs.PageSize).ToList(); } responeData.data = new { pageCount, getDataLists }; } catch (Exception ex) { responeData.code = 0; responeData.message = ex.Message; } return responeData; } #endregion #region 根据ProjectId获取所有考试记录列表 /// /// 根据ProjectId获取所有考试记录列表 /// /// 项目ID /// 页码 /// 考试记录列表 public Model.ResponeData getTrainingTestRecordListByProjectId(string projectId, int pageIndex) { var responeData = new Model.ResponeData(); try { var getDataLists = APITestRecordService.getTrainingTestRecordListByProjectId(projectId, null, null, null, null); int pageCount = getDataLists.Count; if (pageCount > 0 && pageIndex > 0) { getDataLists = getDataLists.OrderByDescending(x => x.TestStartTime).Skip(Funs.PageSize * (pageIndex - 1)).Take(Funs.PageSize).ToList(); } responeData.data = new { pageCount, getDataLists }; } catch (Exception ex) { responeData.code = 0; responeData.message = ex.Message; } return responeData; } #endregion #region 根据ProjectId获取所有考试记录列表 /// /// 根据ProjectId获取所有考试记录列表 /// /// 项目ID /// 单位ID /// 岗位ID /// 0-未通过;1通过;空所有 /// 页码 /// 考试记录列表 public Model.ResponeData getTrainingTestRecordListQuery(string projectId, string unitId, string workPostId, string departId, string strPass, int pageIndex) { var responeData = new Model.ResponeData(); try { if (!string.IsNullOrEmpty(departId)) { var getDataLists = APITestRecordService.getTrainingTestRecordListByDepartId(unitId,departId,strPass,string.Empty); int pageCount = getDataLists.Count; if (pageCount > 0 && pageIndex > 0) { getDataLists = getDataLists.OrderByDescending(x => x.TestStartTime).Skip(Funs.PageSize * (pageIndex - 1)).Take(Funs.PageSize).ToList(); } responeData.data = new { pageCount, getDataLists }; } else { var getDataLists = APITestRecordService.getTrainingTestRecordListByProjectId(projectId, unitId, workPostId, strPass, string.Empty); int pageCount = getDataLists.Count; if (pageCount > 0 && pageIndex > 0) { getDataLists = getDataLists.OrderByDescending(x => x.TestStartTime).Skip(Funs.PageSize * (pageIndex - 1)).Take(Funs.PageSize).ToList(); } responeData.data = new { pageCount, getDataLists }; } } catch (Exception ex) { responeData.code = 0; responeData.message = ex.Message; } return responeData; } #endregion #region 根据ProjectId获取所有考试记录列表 /// /// 根据ProjectId获取所有考试记录列表 /// /// 项目ID /// 单位ID /// 岗位ID /// 0-未通过;1通过;空所有 /// 参数 /// 页码 /// 考试记录列表 #endregion #region 根据TestRecordItemId、selectedItem 考生答题 /// /// 根据TestRecordItemId、selectedItem 考生答题 /// /// 题目ID /// 选项 public Model.ResponeData getTestRecordItemAnswerBySelectedItem(string testRecordItemId, string selectedItem) { var responeData = new Model.ResponeData(); try { if (!string.IsNullOrEmpty(testRecordItemId) && !string.IsNullOrEmpty(selectedItem)) { using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString)) { var getTItem = db.Training_TestRecordItem.FirstOrDefault(x => x.TestRecordItemId == testRecordItemId); if (getTItem != null) { getTItem.SubjectScore = 0; getTItem.SelectedItem = selectedItem; if (!string.IsNullOrEmpty(selectedItem)) { if (getTItem.AnswerItems == selectedItem) { getTItem.SubjectScore = getTItem.Score ?? 0; } else { var listA = Funs.GetStrListByStr(getTItem.AnswerItems.ToUpper(), ','); var listS = Funs.GetStrListByStr(selectedItem.ToUpper(), ','); if (getTItem.TestType == "2" && listA.Count >= listS.Count) { int i = 0; foreach (var item in listS) { if (!listA.Contains(item)) { i++; break; } } if (i == 0) { if (listA.Count == listS.Count) { getTItem.SubjectScore = getTItem.Score ?? 0; } else { getTItem.SubjectScore = Convert.ToDecimal((getTItem.Score ?? 0) * 1.0 / 2); } } } } } db.SubmitChanges(); } } } else { responeData.code = 0; responeData.message = "答题为空选项!"; } } catch (Exception ex) { responeData.code = 0; responeData.message = ex.Message; } return responeData; } #endregion #region 交卷 /// /// 交卷 /// /// 试卷ID public Model.ResponeData getSubmitTestRecordByTestRecordId(string testRecordId,string Signature) { var responeData = new Model.ResponeData(); try { using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString)) { string returnTestRecordId = string.Empty; decimal getTestScores = 0; var getTestRecord = db.Training_TestRecord.FirstOrDefault(e => e.TestRecordId == testRecordId); if (getTestRecord != null) { if (getTestRecord.TestStartTime.HasValue) { getTestRecord.Signature = Signature; getTestRecord.TestEndTime = DateTime.Now; var getRItem = db.Training_TestRecordItem.Where(x => x.TestRecordId == testRecordId); if (getRItem.Count() > 0) { getTestRecord.TestScores = getRItem.Sum(x => x.SubjectScore ?? 0); } db.SubmitChanges(); getTestScores = getTestRecord.TestScores ?? 0; } ////考试分数 int getPassScores = SysConstSetService.getPassScore(); if (getTestScores <= getPassScores) { int testCount = db.Training_TestRecord.Where(x => x.TestPlanId == getTestRecord.TestPlanId && x.TestManId == getTestRecord.TestManId).Count(); if (testCount < 2) { ////重新生成一条考试记录 以及考试试卷 returnTestRecordId = APITestRecordService.getResitTestRecord(getTestRecord); responeData.message = "考试不合格!您的成绩为:【" + getTestScores.ToString() + "】,您将进入补考。"; } else { // APITestRecordService.updateAll(getTestRecord.TestPlanId); responeData.message = "考试不合格!您的成绩为:【" + getTestScores.ToString() + "】,请再次参加培训后补考。"; } } else { // APITestRecordService.updateAll(getTestRecord.TestPlanId); responeData.message = "恭喜考试通过!您的成绩为:【" + getTestScores.ToString() + "】。"; } responeData.data = new { getTestScores, getPassScores, returnTestRecordId }; } } } catch (Exception ex) { responeData.code = 0; responeData.message = ex.Message; } return responeData; } #endregion #region 交卷 /// /// 交卷 /// public Model.ResponeData SaveSubmitTestRecordByTestRecordId(Model.TestRecordItem testRecordItem) { string testRecordId = testRecordItem.TestRecordId; string Signature = testRecordItem.Signature; string Fingerprint = testRecordItem.Fingerprint; var responeData = new Model.ResponeData(); try { using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString)) { var getTestRecord = db.Training_TestRecord.FirstOrDefault(e => e.TestRecordId == testRecordId); if (getTestRecord != null) { string rootUrl = ConfigurationManager.AppSettings["localRoot"]; string SignatureUrl = @"FileUpload\TestRecord\" + getTestRecord.TestRecordId + "~签名" + ".png"; string FingerprintUrl = @"FileUpload\TestRecord\" + getTestRecord.TestRecordId + "~指纹" + ".png"; string Signaturefilename = rootUrl + SignatureUrl; string Fingerprintfilename = rootUrl + FingerprintUrl; if (!string.IsNullOrEmpty(Signature)) { Signature = Signature.Replace("data:image/svg+xml;base64,", "").Replace("data:image/png;base64,", "").Replace("data:image/jgp;base64,", "").Replace("data:image/jpg;base64,", "").Replace("data:image/jpeg;base64,", "");//将base64头部信息替换 byte[] bytes = Convert.FromBase64String(Signature); MemoryStream memStream = new MemoryStream(bytes); Image mImage = Image.FromStream(memStream); Bitmap bp = new Bitmap(mImage); MemoryStream ms = new MemoryStream(); bp.Save(Signaturefilename, System.Drawing.Imaging.ImageFormat.Png); // System.IO.File.WriteAllBytes(Signaturefilename, Convert.FromBase64String(Signature)); getTestRecord.Signature = Signaturefilename.Replace(rootUrl, ""); } if (!string.IsNullOrEmpty(Fingerprint)) { Fingerprint = Fingerprint.Replace("data:image/svg+xml;base64,", "").Replace("data:image/png;base64,", "").Replace("data:image/jgp;base64,", "").Replace("data:image/jpg;base64,", "").Replace("data:image/jpeg;base64,", "");//将base64头部信息替换 byte[] bytes = Convert.FromBase64String(Fingerprint); MemoryStream memStream = new MemoryStream(bytes); Image mImage = Image.FromStream(memStream); Bitmap bp = new Bitmap(mImage); MemoryStream ms = new MemoryStream(); bp.Save(Fingerprintfilename, System.Drawing.Imaging.ImageFormat.Png); getTestRecord.Fingerprint = Fingerprintfilename.Replace(rootUrl, ""); } APITestRecordService.updateTestRecord(getTestRecord); string returnTestRecordId = string.Empty; ////考试分数 decimal getTestScores = APITestRecordService.getSubmitTestRecord(getTestRecord); ////及格分数 int getPassScores = 80; var testRule = db.Sys_TestRule.FirstOrDefault(); if (testRule != null) { getPassScores = testRule.PassingScore; } if (getTestScores <= getPassScores) { int testCount = db.Training_TestRecord.Where(x => x.TestPlanId == getTestRecord.TestPlanId && x.TestManId == getTestRecord.TestManId).Count(); if (testCount < 2) { ////重新生成一条考试记录 以及考试试卷 returnTestRecordId = APITestRecordService.getResitTestRecord(getTestRecord); responeData.message = "考试不合格!您的成绩为:【" + getTestScores.ToString() + "】,您将进入补考。"; } else { APITestRecordService.updateAll(getTestRecord.TestPlanId); responeData.message = "考试不合格!您的成绩为:【" + getTestScores.ToString() + "】,请再次参加培训后补考。"; } } else { APITestRecordService.updateAll(getTestRecord.TestPlanId); responeData.message = "恭喜考试通过!您的成绩为:【" + getTestScores.ToString() + "】。"; } responeData.data = new { getTestScores, getPassScores, returnTestRecordId }; } } } catch (Exception ex) { responeData.code = 0; responeData.message = ex.Message; } return responeData; } #endregion } }