Make_BodyTest.cs 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. using Newtonsoft.Json;
  2. using Newtonsoft.Json.Linq;
  3. using System;
  4. using System.Data;
  5. using System.Drawing;
  6. using System.Net.Http;
  7. using System.Text;
  8. using System.Threading.Tasks;
  9. using System.Windows.Forms;
  10. using UAS_MES_NEW.CustomControl.RichText;
  11. using UAS_MES_NEW.DataOperate;
  12. using UAS_MES_NEW.Entity;
  13. namespace UAS_MES_NEW.Make
  14. {
  15. public partial class Make_BodyTest : Form
  16. {
  17. public Make_BodyTest()
  18. {
  19. InitializeComponent();
  20. }
  21. string url = "http://192.168.41.200:9527/";
  22. string key = "c6b0ac61-bb5a-411f-9213-3ed05da979f8";
  23. DataHelper dh;
  24. DataTable dt;
  25. int InsertNum = 0;
  26. private void Make_Humiture_Load(object sender, EventArgs e)
  27. {
  28. IpPortUrlVal.Text = url;
  29. ketVal.Text = key;
  30. workTimeVal1.Value = DateTime.Today.AddHours(08).AddMinutes(00).AddSeconds(0);
  31. workTimeVal2.Value = DateTime.Today.AddHours(12).AddMinutes(30).AddSeconds(0);
  32. workTimeVal3.Value = DateTime.Today.AddHours(12).AddMinutes(00).AddSeconds(0);
  33. workTimeVal4.Value = DateTime.Today.AddHours(17).AddMinutes(30).AddSeconds(0);
  34. workTimeLab1.Visible = false;
  35. workTimeLab2.Visible = false;
  36. workTimeLab3.Visible = false;
  37. workTimeLab4.Visible = false;
  38. workTimeVal1.Visible = false;
  39. workTimeVal2.Visible = false;
  40. workTimeVal3.Visible = false;
  41. workTimeVal4.Visible = false;
  42. dh = SystemInf.dh;
  43. }
  44. private void onStart_Click(object sender, EventArgs e)
  45. {
  46. if (string.IsNullOrEmpty(IpPortUrlVal.Text))
  47. {
  48. ShowMsg(Msg1, 0, "请输出请求地址");
  49. IpPortUrlVal.Focus();
  50. IpPortUrlVal.SelectAll();
  51. return;
  52. }
  53. if (onStart.Text == "获取中")
  54. {
  55. IpPortUrlVal.Enabled = true;
  56. ketVal.Enabled = true;
  57. workTimeVal1.Enabled = true;
  58. workTimeVal2.Enabled = true;
  59. workTimeVal3.Enabled = true;
  60. workTimeVal4.Enabled = true;
  61. onStart.Text = "开启获取";
  62. timer1.Stop();
  63. }
  64. else
  65. {
  66. IpPortUrlVal.Enabled = false;
  67. ketVal.Enabled = false;
  68. workTimeVal1.Enabled = false;
  69. workTimeVal2.Enabled = false;
  70. workTimeVal3.Enabled = false;
  71. workTimeVal4.Enabled = false;
  72. onStart.Text = "获取中";
  73. ShowMsg(Msg1, 2, $"执行间隔:{timer1.Interval / 60000}分钟");
  74. timer1.Start();
  75. //timer1_Tick(null, null);
  76. }
  77. }
  78. private async void timer1_Tick(object sender, EventArgs e)
  79. {
  80. try
  81. {
  82. string apiUrl = IpPortUrlVal.Text.Trim() + "api/AcsDataApi/GetData";
  83. DateTime startTime = DateTime.Now.Date;
  84. DateTime endTime = DateTime.Now.Date.AddDays(1).AddSeconds(-1);
  85. var dataObject = new
  86. {
  87. Key = ketVal.Text.Trim(),
  88. Type = "Event",
  89. STime = startTime.ToString("yyyy-MM-dd HH:mm:ss"),
  90. ETime = endTime.ToString("yyyy-MM-dd HH:mm:ss"),
  91. IsAllType = "0"
  92. };
  93. string result = await HttpHelper.PostAsync(apiUrl, dataObject);
  94. JObject root = JObject.Parse(result);
  95. JArray dataArr = (JArray)root["Data"];
  96. if (root["Code"].ToString() == "1")
  97. {
  98. ShowMsg(Msg1, 1, $"获取人体测试仪设备成功,已获取到{dataArr.Count}条记录");
  99. }
  100. InsertNum = 0;
  101. foreach (JToken item in dataArr)
  102. {
  103. string DeptName = item["DeptName"].ToString();
  104. string EmployeeCode = item["EmployeeCode"].ToString();
  105. string EmployeeName = item["EmployeeName"].ToString();
  106. string EventName = item["EventName"].ToString();
  107. string ControlName = item["ControlName"].ToString();
  108. string EventID = item["EventID"].ToString();
  109. string EventTime = item["EventTime"].ToString();
  110. DateTime.TryParse(EventTime, out DateTime dtHour);
  111. string timeType = dtHour.Hour < 11 ? "上午" : "下午";
  112. dt = (DataTable)dh.ExecuteSql($"select * from bodytest where BT_EVENTID = '{EventID}'", "select");
  113. if (dt.Rows.Count == 0)
  114. {
  115. string sql = $@"INSERT INTO BODYTEST (BT_ID,BT_DEPTNAME,BT_EMPNO,BT_EMP,BT_TYPE,BT_TIMETYPE,
  116. BT_HAND,BT_DHAND,BT_LEFTSHOES,BT_RIGHTSHOES,BT_CONTROLNAME,BT_EVENTID,BT_INDATE) VALUES
  117. (BODYTEST_SEQ.NEXTVAL,'{DeptName}','{EmployeeCode}','{EmployeeName}','{EventName}','{timeType}',
  118. '','','','','{ControlName}','{EventID}',to_date('{EventTime}', 'YYYY-MM-DD HH24:MI:SS'))";
  119. dh.ExecuteSql(sql, "insert");
  120. InsertNum += 1;
  121. }
  122. }
  123. ShowMsg(Msg1, 1, $"人体测试信息已记录{InsertNum}条记录");
  124. }
  125. catch (Exception ex)
  126. {
  127. ShowMsg(Msg1, 0, $"获取数据时发生错误: {ex.Message}");
  128. }
  129. }
  130. private void claerBtn_Click(object sender, EventArgs e)
  131. {
  132. Msg1.Clear();
  133. }
  134. private void ShowMsg(RichTextAutoBottom msgBox, int type, string msg)
  135. {
  136. msg = msg.Replace("\r", "").Replace("\n", "");
  137. string msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  138. string showMsg = $"{msgTime}: {msg}\n";
  139. if (type == 0)
  140. {
  141. msgBox.AppendText(showMsg, Color.Red);
  142. msgBox.SelectionStart = msgBox.Text.Length;
  143. msgBox.ScrollToCaret();
  144. }
  145. else if (type == 1)
  146. {
  147. msgBox.AppendText(showMsg, Color.Green);
  148. msgBox.SelectionStart = msgBox.Text.Length;
  149. msgBox.ScrollToCaret();
  150. }
  151. else if (type == 2)
  152. {
  153. msgBox.AppendText(showMsg, Color.YellowGreen);
  154. msgBox.SelectionStart = msgBox.Text.Length;
  155. msgBox.ScrollToCaret();
  156. }
  157. }
  158. public static class HttpHelper
  159. {
  160. public static async Task<string> PostAsync<T>(string url, T data)
  161. {
  162. var client = new HttpClient();
  163. string json = JsonConvert.SerializeObject(data);
  164. var content = new StringContent(json, Encoding.UTF8, "application/json");
  165. var response = await client.PostAsync(url, content);
  166. response.EnsureSuccessStatusCode();
  167. return await response.Content.ReadAsStringAsync();
  168. }
  169. }
  170. }
  171. }