From 77f8f99697748749edd553b127de34b02ccb18c5 Mon Sep 17 00:00:00 2001 From: username@email.com <yzy2002yzy@163.com> Date: 星期五, 25 六月 2021 11:43:59 +0800 Subject: [PATCH] 提交 --- zhengcaioa/zhengcaioa/Controllers/AdmManagement/SigninController.cs | 125 ++++++++++++++++++++++++++++++++++++++--- 1 files changed, 114 insertions(+), 11 deletions(-) diff --git a/zhengcaioa/zhengcaioa/Controllers/AdmManagement/SigninController.cs b/zhengcaioa/zhengcaioa/Controllers/AdmManagement/SigninController.cs index bedb534..e10e018 100644 --- a/zhengcaioa/zhengcaioa/Controllers/AdmManagement/SigninController.cs +++ b/zhengcaioa/zhengcaioa/Controllers/AdmManagement/SigninController.cs @@ -11,6 +11,7 @@ using Microsoft.AspNetCore.Http; using Newtonsoft.Json.Linq; using System.Transactions; +using System.Runtime.InteropServices; namespace zhengcaioa.Controllers.AdmManagement { @@ -85,12 +86,88 @@ /// <param name="signinType">10鏃╀笂涓婄彮 11鏃╀笂涓嬬彮 20涓嬪崍涓婄彮 21涓嬪崍涓嬬彮 30鍔犵彮涓婄彮 31鍔犵彮涓嬬彮</param> /// <returns></returns> [CheckLogin] - public string Save(string id,int signinType) - { - ResultEntity resultEntity = _signinService.save(id, signinType); + public string Save(string id,int signinType,string mac) + { + ResultEntity resultEntity = new ResultEntity(); + resultEntity.Result = false; + try + { + if (string.IsNullOrEmpty(mac)) + { + resultEntity = _signinService.save(id, signinType); + } + else + { + var curentuser = JsonConvert.DeserializeObject<PltUser>(HttpContext.Session.GetString("User")); + if(curentuser.IpMac == mac) + { + //var mac = GetClientMAC(GetClientIP()); + + } + else + { + resultEntity.Message = "鎵撳崱鐢佃剳妫�鏌ヤ笉鍖归厤銆�"; + } + } + } + catch(Exception er) + { } return JsonConvert.SerializeObject(resultEntity); } + + [DllImport("Iphlpapi.dll")] + private static extern int SendARP(Int32 dest, Int32 host, ref Int64 mac, ref Int32 length); + + [DllImport("Ws2_32.dll")] + private static extern Int32 inet_addr(string ip); + + private string GetClientIP() + { + HttpContextAccessor context = new HttpContextAccessor(); + var ip = context.HttpContext?.Connection.RemoteIpAddress.ToString(); + var mac = GetClientMAC(ip); + var str = "IP:" + ip + " 锛孧AC:" + mac; + return str; + } + + private string GetClientMAC(string ip) + { + string mac_dest = string.Empty; + try + { + Int32 ldest = inet_addr(ip); //鐩殑鍦扮殑ip + Int32 lhost = inet_addr(""); //鏈嶅姟鍣ㄧ殑ip + Int64 macinfo = new Int64(); + Int32 len = 6; + int res = SendARP(ldest, 0, ref macinfo, ref len); + string mac_src = macinfo.ToString("X"); + while (mac_src.Length < 12) + { + mac_src = mac_src.Insert(0, "0"); + } + for (int i = 0; i < 11; i++) + { + if (0 == (i % 2)) + { + if (i == 10) + { + mac_dest = mac_dest.Insert(0, mac_src.Substring(i, 2)); + } + else + { + mac_dest = "-" + mac_dest.Insert(0, mac_src.Substring(i, 2)); + } + + } + } + } + catch (Exception ex) + { + throw ex; + } + return mac_dest; + } /// <summary> /// 鍙栧緱浠婂ぉ绛惧埌淇℃伅 @@ -340,7 +417,7 @@ if ((int)StratTime.Date.DayOfWeek >= admAttendanceRuleDTO.WeekStart && (int)StratTime.Date.DayOfWeek <= admAttendanceRuleDTO.WeekEnd) { //鏄惁鑺傚亣鏃� - if (jiejiari.Exists(x => x.ValueStart <= StratTime.Date && x.ValueStart >= StratTime.Date)) + if (jiejiari.Exists(x => x.ValueStart <= StratTime.Date && x.ValueEnd >= StratTime.Date)) { LavehTime += 0; @@ -389,7 +466,7 @@ { //鏄惁璋冧紤鏃� 璋冧紤鏃ラ渶瑕佷笂鐝� - if (tiaoxiuri.Exists(x => x.ValueStart <= StratTime.Date && x.ValueStart >= StratTime.Date)) + if (tiaoxiuri.Exists(x => x.ValueStart <= StratTime.Date && x.ValueEnd >= StratTime.Date)) { if (StratTime <= StratTimeWorkingStart) { @@ -435,7 +512,7 @@ if ((int)EndTime.Date.DayOfWeek >= admAttendanceRuleDTO.WeekStart && (int)EndTime.Date.DayOfWeek <= admAttendanceRuleDTO.WeekEnd) { //鏄惁鑺傚亣鏃� - if (jiejiari.Exists(x => x.ValueStart <= EndTime.Date && x.ValueStart >= EndTime.Date)) + if (jiejiari.Exists(x => x.ValueStart <= EndTime.Date && x.ValueEnd >= EndTime.Date)) { LavehTime += 0; @@ -485,7 +562,7 @@ { //鏄惁璋冧紤鏃� 璋冧紤鏃ラ渶瑕佷笂鐝� - if (tiaoxiuri.Exists(x => x.ValueStart <= EndTime.Date && x.ValueStart >= EndTime.Date)) + if (tiaoxiuri.Exists(x => x.ValueStart <= EndTime.Date && x.ValueEnd >= EndTime.Date)) { if (EndTime >= EndTimeOffworkEnd) { @@ -534,7 +611,7 @@ if ((int)dateTimenow.Date.DayOfWeek >= admAttendanceRuleDTO.WeekStart && (int)dateTimenow.Date.DayOfWeek <= admAttendanceRuleDTO.WeekEnd) { //鏄惁鍋囨湡 鍋囨湡涓嶄笂鐝� - if (jiejiari.Exists(x => x.ValueStart <= dateTimenow.Date && x.ValueStart >= dateTimenow.Date)) + if (jiejiari.Exists(x => x.ValueStart <= dateTimenow.Date && x.ValueEnd >= dateTimenow.Date)) { LavehTime += 0; } @@ -547,7 +624,7 @@ { //鏄惁璋冧紤鏃� 璋冧紤鏃ラ渶瑕佷笂鐝� - if (tiaoxiuri.Exists(x => x.ValueStart <= StratTime.Date && x.ValueStart >= StratTime.Date)) + if (tiaoxiuri.Exists(x => x.ValueStart <= StratTime.Date && x.ValueEnd >= StratTime.Date)) { LavehTime += shangbanshijian; } @@ -560,8 +637,32 @@ if(ts.Days == 0) - { - LavehTime -= shangbanshijian; + { //鏄惁涓婄彮鏃ユ湡 + if ((int)StratTime.Date.DayOfWeek >= admAttendanceRuleDTO.WeekStart && (int)StratTime.Date.DayOfWeek <= admAttendanceRuleDTO.WeekEnd) + { + //鏄惁鑺傚亣鏃� + if (jiejiari.Exists(x => x.ValueStart <= StratTime.Date && x.ValueEnd >= StratTime.Date)) + { + LavehTime -= 0; + } + else + { + LavehTime -= shangbanshijian; + } + } + else + { + //鏄惁璋冧紤鏃� 璋冧紤鏃ラ渶瑕佷笂鐝� + if (tiaoxiuri.Exists(x => x.ValueStart <= StratTime.Date && x.ValueEnd >= StratTime.Date)) + { + LavehTime -= shangbanshijian; + } + else + { + LavehTime -= 0; + } + } + } } @@ -749,6 +850,8 @@ ViewData["curentuser"] = curentuser; using (TransactionScope scope = new TransactionScope()) { + dto.FullAttendance = 0; + dto.AbsenteeismPayment2 = 0; dto.RecStatus = "A"; if (String.IsNullOrEmpty(dto.Id)) { -- Gitblit v1.9.1