XiaomiMESHttp_StationOutbound.cs 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436
  1. using Newtonsoft.Json;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using System.Text;
  6. namespace MainForm.ClassFile.XiaomiAPI_MES
  7. {
  8. /// <summary>
  9. /// 小米MES - 出站接⼝
  10. /// 接口地址:
  11. /// 接口方法:UnitConfirmDataSetOut
  12. /// </summary>
  13. public class XiaomiMESHttp_StationOutbound : XiaomiMESHttp_X5
  14. {
  15. #region 变量
  16. /// <summary>
  17. /// 接口地址
  18. /// </summary>
  19. protected new static string MESUrl { set; get; } = GlobalContext.StationOutMESUrl;
  20. /// <summary>
  21. /// 接口方法
  22. /// </summary>
  23. protected new static string Method { set; get; } = "UnitConfirmDataSetOut";
  24. #endregion 变量
  25. /// <summary>
  26. /// 小米MES - 出站
  27. /// </summary>
  28. /// <param name="request"></param>
  29. /// <returns></returns>
  30. public static XmMES_StationOutResponse StationOut(XmMES_StationOutRequest_Body body)
  31. {
  32. XmMES_StationOutResponse stationOutResponse = new XmMES_StationOutResponse();
  33. string bodyJson = JsonConvert.SerializeObject(body);
  34. XiaomiMES_X5RequestHeader header = new XiaomiMES_X5RequestHeader();
  35. header.appid = Appid; // 系统分配的应⽤ID
  36. header.method = Method; // API接⼝名称
  37. header.sign = GetSign_Up(Appid, bodyJson, Appkey); // md5签名
  38. header.url = MESUrl; // 接⼝地址
  39. //XmMES_StationOutRequest request = new XmMES_StationOutRequest();
  40. //request.header = header;
  41. //request.body = body;
  42. //string data = JsonConvert.SerializeObject(request);
  43. //转base64
  44. dynamic requestData = new { header = header, body = bodyJson };
  45. var serializedBody = JsonConvert.SerializeObject(requestData);
  46. var data = Convert.ToBase64String(Encoding.UTF8.GetBytes(serializedBody));
  47. XiaomiMES_X5Response response = Post(MESUrl, data);
  48. // ZS保存日志
  49. stationOutResponse.header = response.header;
  50. string responseBody = response.body;
  51. stationOutResponse.body = JsonConvert.DeserializeObject<XmMESStationOut_Body>(responseBody);
  52. return stationOutResponse;
  53. }
  54. #region 入参
  55. /// <summary>
  56. /// 出站接⼝ - 入参
  57. /// </summary>
  58. public class XmMES_StationOutRequest
  59. {
  60. /// <summary>
  61. /// 出站接⼝ - 入参 - header
  62. /// </summary>
  63. public XiaomiMES_X5RequestHeader header { get; set; } = new XiaomiMES_X5RequestHeader();
  64. /// <summary>
  65. /// 出站接⼝ - 入参 - body
  66. /// </summary>
  67. public XmMES_StationOutRequest_Body body { get; set; } = new XmMES_StationOutRequest_Body();
  68. }
  69. /// <summary>
  70. /// 出站接⼝ - 入参 - Body 实体
  71. /// </summary>
  72. public class XmMES_StationOutRequest_Body
  73. {
  74. /// <summary>
  75. /// 装备id(可配置)
  76. /// </summary>
  77. public string machineId { get; set; } = string.Empty;
  78. /// <summary>
  79. /// ⼯位ID(可配置)
  80. /// </summary>
  81. public string stationId { get; set; } = string.Empty;
  82. /// <summary>
  83. /// 客⼾端本机MAC地址,格式:XX-XX-XX-XX-XX-XX
  84. /// </summary>
  85. public string clientMac { get; set; } = string.Empty;
  86. /// <summary>
  87. /// 客⼾端请求时间,格式yyyy-MM-dd HH:mm:ss.fff
  88. /// </summary>
  89. public string clientTime { get; set; } = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff");
  90. /// <summary>
  91. /// 产品SN
  92. /// </summary>
  93. public string unitSn { get; set; } = string.Empty;
  94. /// <summary>
  95. /// 过站明细唯⼀标识UUID(每次调⽤OUT⽣成⼀个全新得uuid进⾏赋值,使⽤UUID函数直接⽣成即可)
  96. /// </summary>
  97. public string uuidInspection { get; set; } = Guid.NewGuid().ToString();
  98. /// <summary>
  99. /// 过站条件
  100. /// PASS或FAIL
  101. /// </summary>
  102. public string state { get; set; } = string.Empty;
  103. /// <summary>
  104. /// ⽤⼾ID;非必填
  105. /// 如果接⼊了MES⽤⼾才需要传⼊
  106. /// </summary>
  107. public string userId { get; set; } = string.Empty;
  108. /// <summary>
  109. /// ⼯⼚id;非必填
  110. /// </summary>
  111. public string factoryId { get; set; } = string.Empty;
  112. /// <summary>
  113. /// 设备数据
  114. /// </summary>
  115. public XmStationOut_UnitData unitData { get; set; } = new XmStationOut_UnitData();
  116. /// <summary>
  117. /// 出站接⼝ - 入参 - 设备数据
  118. /// </summary>
  119. public class XmStationOut_UnitData
  120. {
  121. /// <summary>
  122. /// 检测项数据;如果没有则不传
  123. /// </summary>
  124. public List<XmStationOut_InspectionItemData> inspectionItemData { get; set; } = new List<XmStationOut_InspectionItemData>();
  125. /// <summary>
  126. /// 不良点位检测数据;如果没有则不传
  127. /// </summary>
  128. public List<XmStationOut_InspectionPointData> inspectionPointData { get; set; } = new List<XmStationOut_InspectionPointData>();
  129. /// <summary>
  130. /// 制程⼯艺参数;如果没有则不传
  131. /// </summary>
  132. public List<XmStationOut_ProcessData> processData { get; set; } = new List<XmStationOut_ProcessData>();
  133. /// <summary>
  134. /// 关键参数;如果没有则不传
  135. /// </summary>
  136. public List<XmStationOut_KeyParam> keyParams { get; set; } = new List<XmStationOut_KeyParam>();
  137. /// <summary>
  138. /// 载具信息;如果没有则不传
  139. /// </summary>
  140. public XmStationOut_VehicleData vehicleData { get; set; } = new XmStationOut_VehicleData();
  141. /// <summary>
  142. /// ⽂件信息;如果没有则不传
  143. /// </summary>
  144. public List<XmStationOut_FileData> fileData { get; set; } = new List<XmStationOut_FileData>();
  145. /// <summary>
  146. /// 辅耗材消耗信息;如果没有则不传
  147. /// </summary>
  148. public List<XmStationOut_ConsumableData> consumableData { get; set; } = new List<XmStationOut_ConsumableData>();
  149. /// <summary>
  150. /// 关键部件绑定sn信息;如果没有则不传
  151. /// </summary>
  152. public List<XmStationOut_KeyMaterial> keyMaterial { get; set; } = new List<XmStationOut_KeyMaterial>();
  153. }
  154. /// <summary>
  155. /// 出站接⼝ - 入参 - 设备数据 - 检测项数据
  156. /// </summary>
  157. public class XmStationOut_InspectionItemData
  158. {
  159. /// <summary>
  160. /// ⼦条码SN
  161. /// </summary>
  162. public string childUnitSn { get; set; } = string.Empty;
  163. /// <summary>
  164. /// 检测结果
  165. /// PASS/FAIL
  166. /// </summary>
  167. public string childUnitState { get; set; } = string.Empty;
  168. /// <summary>
  169. /// ⼯具版本号
  170. /// </summary>
  171. public string toolVersion { get; set; } = string.Empty;
  172. /// <summary>
  173. /// 检测明细数据
  174. /// </summary>
  175. public List<XmStationOut_DataItem> dataItem { get; set; } = new List<XmStationOut_DataItem>();
  176. /// <summary>
  177. /// 添加检测项明细
  178. /// </summary>
  179. /// <param name="dataName">数据描述</param>
  180. /// <param name="dataValue">数值</param>
  181. /// <param name="maxStr">最⼤值</param>
  182. /// <param name="minStr">最⼩值</param>
  183. /// <param name="passStr">项⽬的检验结果:PASS/FAIL</param>
  184. public void AddDataItem(string functionName,string testItem, string dataValue,string maxStr,string minStr,string passStr)
  185. {
  186. dataItem.Add(new XmStationOut_DataItem
  187. {
  188. functionName = functionName,
  189. testItem = testItem,
  190. value = dataValue,
  191. hiLimit = maxStr,
  192. lowLimit = minStr,
  193. testTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  194. status = passStr,
  195. });
  196. }
  197. }
  198. /// <summary>
  199. /// 出站接⼝ - 入参 - 设备数据 - 检测项数据 - 检测明细数据
  200. /// </summary>
  201. public class XmStationOut_DataItem
  202. {
  203. /// <summary>
  204. /// 测试项名称
  205. /// </summary>
  206. public string functionName { get; set; } = string.Empty;
  207. /// <summary>
  208. /// 数据描述
  209. /// </summary>
  210. public string testItem { get; set; } = string.Empty;
  211. /// <summary>
  212. /// 数值
  213. /// </summary>
  214. public string value { get; set; } = string.Empty;
  215. /// <summary>
  216. /// 最⼤值;非必填
  217. /// </summary>
  218. public string hiLimit { get; set; } = string.Empty;
  219. /// <summary>
  220. /// 最⼩值;非必填
  221. /// </summary>
  222. public string lowLimit { get; set; } = string.Empty;
  223. /// <summary>
  224. /// 测试时间,单位s
  225. /// </summary>
  226. public string testTime { get; set; } = string.Empty;
  227. /// <summary>
  228. /// 错误代码(参考ErrorCode定义标准化表);非必填
  229. /// </summary>
  230. public string errorCode { get; set; } = string.Empty;
  231. /// <summary>
  232. /// 项⽬的检验结果
  233. /// PASS/FAIL
  234. /// </summary>
  235. public string status { get; set; } = string.Empty;
  236. /// <summary>
  237. /// 描述信息
  238. /// </summary>
  239. public string description { get; set; } = string.Empty;
  240. }
  241. /// <summary>
  242. /// 出站接⼝ - 入参 - 设备数据 - 不良点位检测数据
  243. /// </summary>
  244. public class XmStationOut_InspectionPointData
  245. {
  246. /// <summary>
  247. /// 检验数据项⽬名称
  248. /// </summary>
  249. public string no { get; set; } = string.Empty;
  250. /// <summary>
  251. /// 检测结果
  252. /// </summary>
  253. public string result { get; set; } = string.Empty;
  254. /// <summary>
  255. /// ⼩板号
  256. /// </summary>
  257. public string panelNo { get; set; } = string.Empty;
  258. /// <summary>
  259. /// 不良code;非必填
  260. /// </summary>
  261. public string defectCode { get; set; } = string.Empty;
  262. /// <summary>
  263. /// 不良描述;非必填
  264. /// </summary>
  265. public string defectDesc { get; set; } = string.Empty;
  266. /// <summary>
  267. /// 不良位置
  268. /// </summary>
  269. public string location { get; set; } = string.Empty;
  270. }
  271. /// <summary>
  272. /// 出站接⼝ - 入参 - 设备数据 - 制程⼯艺参数
  273. /// </summary>
  274. public class XmStationOut_ProcessData
  275. {
  276. /// <summary>
  277. /// 数据名字
  278. /// </summary>
  279. public string dataName { get; set; } = string.Empty;
  280. /// <summary>
  281. /// 数据值;非必填
  282. /// </summary>
  283. public string dataValue { get; set; } = string.Empty;
  284. }
  285. /// <summary>
  286. /// 出站接⼝ - 入参 - 设备数据 - 关键参数
  287. /// </summary>
  288. public class XmStationOut_KeyParam
  289. {
  290. /// <summary>
  291. /// 关键参数code
  292. /// </summary>
  293. public string paramCode { get; set; } = string.Empty;
  294. /// <summary>
  295. /// 关键参数值
  296. /// </summary>
  297. public string paramValue { get; set; } = string.Empty;
  298. }
  299. /// <summary>
  300. /// 出站接⼝ - 入参 - 设备数据 - 载具信息
  301. /// </summary>
  302. public class XmStationOut_VehicleData
  303. {
  304. /// <summary>
  305. /// 载具sn
  306. /// </summary>
  307. public string vehicleSn { get; set; } = string.Empty;
  308. /// <summary>
  309. /// 载具类型
  310. /// </summary>
  311. public string vehicleType { get; set; } = string.Empty;
  312. /// <summary>
  313. /// 槽位
  314. /// </summary>
  315. public string slot { get; set; } = string.Empty;
  316. }
  317. /// <summary>
  318. /// 出站接⼝ - 入参 - 设备数据 - 文件信息
  319. /// </summary>
  320. public class XmStationOut_FileData
  321. {
  322. /// <summary>
  323. /// ⽂件名称
  324. /// </summary>
  325. public string fileName { get; set; } = string.Empty;
  326. /// <summary>
  327. /// ⽂件在⽂件服务器对应的uuid,可以采⽤异步上传,⾃定义uuid,先上传out,然后再异步上传⽂件,提升过站效率
  328. /// </summary>
  329. public string fileId { get; set; } = string.Empty;
  330. /// <summary>
  331. /// ⽂件服务器bucket
  332. /// </summary>
  333. public string bucket { get; set; } = string.Empty;
  334. }
  335. /// <summary>
  336. /// 出站接⼝ - 入参 - 设备数据 - 辅耗材消耗信息
  337. /// </summary>
  338. public class XmStationOut_ConsumableData
  339. {
  340. /// <summary>
  341. /// 辅耗材sn
  342. /// </summary>
  343. public string consumableSn { get; set; } = string.Empty;
  344. /// <summary>
  345. /// 消耗数量
  346. /// </summary>
  347. public string useQty { get; set; } = string.Empty;
  348. /// <summary>
  349. /// 辅耗材使⽤位置;非必填
  350. /// </summary>
  351. public string componentLocation { get; set; } = string.Empty;
  352. }
  353. /// <summary>
  354. /// 出站接⼝ - 入参 - 设备数据 - 关键部件绑定sn信息
  355. /// </summary>
  356. public class XmStationOut_KeyMaterial
  357. {
  358. /// <summary>
  359. /// 绑定顺序 1,2,3,...
  360. /// </summary>
  361. public int bindSort { get; set; }
  362. /// <summary>
  363. /// 绑定部件的SN
  364. /// </summary>
  365. public string materialSn { get; set; } = string.Empty;
  366. }
  367. }
  368. #endregion 入参
  369. #region 出参
  370. /// <summary>
  371. /// 出站接⼝ - 出参
  372. /// </summary>
  373. public class XmMES_StationOutResponse
  374. {
  375. /// <summary>
  376. /// 出站接⼝ - 出参 - header
  377. /// </summary>
  378. public XiaomiMES_X5ResponseHeader header { get; set; } = new XiaomiMES_X5ResponseHeader();
  379. /// <summary>
  380. /// 出站接⼝ - 出参 - body
  381. /// </summary>
  382. public XmMESStationOut_Body body { get; set; } = new XmMESStationOut_Body();
  383. }
  384. /// <summary>
  385. /// 出站接⼝ - 出参 - Body 实体
  386. /// </summary>
  387. public class XmMESStationOut_Body
  388. {
  389. /// <summary>
  390. /// 服务器响应时间,格式yyyy-MM-dd HH:mm:ss.fff
  391. /// </summary>
  392. public string serverTime { get; set; } = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff");
  393. /// <summary>
  394. /// 回溯结果:
  395. /// PASS 成功,可以下⼀站;FAIL 失败,需要进维修室*(需要回溯的⼯站专⽤,其它⼯站可以忽略该字段)
  396. /// </summary>
  397. public string lookBackResult { get; set; } = string.Empty;
  398. ///// <summary>
  399. /////
  400. ///// </summary>
  401. //public string requestTime { get; set; } = string.Empty;
  402. ///// <summary>
  403. /////
  404. ///// </summary>
  405. //public string processTime { get; set; } = string.Empty;
  406. }
  407. #endregion 出参
  408. }
  409. }