XiaomiMESHttp_StationOutbound.cs 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414
  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. }
  177. /// <summary>
  178. /// 出站接⼝ - 入参 - 设备数据 - 检测项数据 - 检测明细数据
  179. /// </summary>
  180. public class XmStationOut_DataItem
  181. {
  182. /// <summary>
  183. /// 测试项名称
  184. /// </summary>
  185. public string functionName { get; set; } = string.Empty;
  186. /// <summary>
  187. /// 数据描述
  188. /// </summary>
  189. public string testItem { get; set; } = string.Empty;
  190. /// <summary>
  191. /// 数值
  192. /// </summary>
  193. public string value { get; set; } = string.Empty;
  194. /// <summary>
  195. /// 最⼤值;非必填
  196. /// </summary>
  197. public string hiLimit { get; set; } = string.Empty;
  198. /// <summary>
  199. /// 最⼩值;非必填
  200. /// </summary>
  201. public string lowLimit { get; set; } = string.Empty;
  202. /// <summary>
  203. /// 测试时间,单位s
  204. /// </summary>
  205. public string testTime { get; set; } = string.Empty;
  206. /// <summary>
  207. /// 错误代码(参考ErrorCode定义标准化表);非必填
  208. /// </summary>
  209. public string errorCode { get; set; } = string.Empty;
  210. /// <summary>
  211. /// 项⽬的检验结果
  212. /// PASS/FAIL
  213. /// </summary>
  214. public string status { get; set; } = string.Empty;
  215. /// <summary>
  216. /// 描述信息
  217. /// </summary>
  218. public string description { get; set; } = string.Empty;
  219. }
  220. /// <summary>
  221. /// 出站接⼝ - 入参 - 设备数据 - 不良点位检测数据
  222. /// </summary>
  223. public class XmStationOut_InspectionPointData
  224. {
  225. /// <summary>
  226. /// 检验数据项⽬名称
  227. /// </summary>
  228. public string no { get; set; } = string.Empty;
  229. /// <summary>
  230. /// 检测结果
  231. /// </summary>
  232. public string result { get; set; } = string.Empty;
  233. /// <summary>
  234. /// ⼩板号
  235. /// </summary>
  236. public string panelNo { get; set; } = string.Empty;
  237. /// <summary>
  238. /// 不良code;非必填
  239. /// </summary>
  240. public string defectCode { get; set; } = string.Empty;
  241. /// <summary>
  242. /// 不良描述;非必填
  243. /// </summary>
  244. public string defectDesc { get; set; } = string.Empty;
  245. /// <summary>
  246. /// 不良位置
  247. /// </summary>
  248. public string location { get; set; } = string.Empty;
  249. }
  250. /// <summary>
  251. /// 出站接⼝ - 入参 - 设备数据 - 制程⼯艺参数
  252. /// </summary>
  253. public class XmStationOut_ProcessData
  254. {
  255. /// <summary>
  256. /// 数据名字
  257. /// </summary>
  258. public string dataName { get; set; } = string.Empty;
  259. /// <summary>
  260. /// 数据值;非必填
  261. /// </summary>
  262. public string dataValue { get; set; } = string.Empty;
  263. }
  264. /// <summary>
  265. /// 出站接⼝ - 入参 - 设备数据 - 关键参数
  266. /// </summary>
  267. public class XmStationOut_KeyParam
  268. {
  269. /// <summary>
  270. /// 关键参数code
  271. /// </summary>
  272. public string paramCode { get; set; } = string.Empty;
  273. /// <summary>
  274. /// 关键参数值
  275. /// </summary>
  276. public string paramValue { get; set; } = string.Empty;
  277. }
  278. /// <summary>
  279. /// 出站接⼝ - 入参 - 设备数据 - 载具信息
  280. /// </summary>
  281. public class XmStationOut_VehicleData
  282. {
  283. /// <summary>
  284. /// 载具sn
  285. /// </summary>
  286. public string vehicleSn { get; set; } = string.Empty;
  287. /// <summary>
  288. /// 载具类型
  289. /// </summary>
  290. public string vehicleType { get; set; } = string.Empty;
  291. /// <summary>
  292. /// 槽位
  293. /// </summary>
  294. public string slot { get; set; } = string.Empty;
  295. }
  296. /// <summary>
  297. /// 出站接⼝ - 入参 - 设备数据 - 文件信息
  298. /// </summary>
  299. public class XmStationOut_FileData
  300. {
  301. /// <summary>
  302. /// ⽂件名称
  303. /// </summary>
  304. public string fileName { get; set; } = string.Empty;
  305. /// <summary>
  306. /// ⽂件在⽂件服务器对应的uuid,可以采⽤异步上传,⾃定义uuid,先上传out,然后再异步上传⽂件,提升过站效率
  307. /// </summary>
  308. public string fileId { get; set; } = string.Empty;
  309. /// <summary>
  310. /// ⽂件服务器bucket
  311. /// </summary>
  312. public string bucket { get; set; } = string.Empty;
  313. }
  314. /// <summary>
  315. /// 出站接⼝ - 入参 - 设备数据 - 辅耗材消耗信息
  316. /// </summary>
  317. public class XmStationOut_ConsumableData
  318. {
  319. /// <summary>
  320. /// 辅耗材sn
  321. /// </summary>
  322. public string consumableSn { get; set; } = string.Empty;
  323. /// <summary>
  324. /// 消耗数量
  325. /// </summary>
  326. public string useQty { get; set; } = string.Empty;
  327. /// <summary>
  328. /// 辅耗材使⽤位置;非必填
  329. /// </summary>
  330. public string componentLocation { get; set; } = string.Empty;
  331. }
  332. /// <summary>
  333. /// 出站接⼝ - 入参 - 设备数据 - 关键部件绑定sn信息
  334. /// </summary>
  335. public class XmStationOut_KeyMaterial
  336. {
  337. /// <summary>
  338. /// 绑定顺序 1,2,3,...
  339. /// </summary>
  340. public int bindSort { get; set; }
  341. /// <summary>
  342. /// 绑定部件的SN
  343. /// </summary>
  344. public string materialSn { get; set; } = string.Empty;
  345. }
  346. }
  347. #endregion 入参
  348. #region 出参
  349. /// <summary>
  350. /// 出站接⼝ - 出参
  351. /// </summary>
  352. public class XmMES_StationOutResponse
  353. {
  354. /// <summary>
  355. /// 出站接⼝ - 出参 - header
  356. /// </summary>
  357. public XiaomiMES_X5ResponseHeader header { get; set; } = new XiaomiMES_X5ResponseHeader();
  358. /// <summary>
  359. /// 出站接⼝ - 出参 - body
  360. /// </summary>
  361. public XmMESStationOut_Body body { get; set; } = new XmMESStationOut_Body();
  362. }
  363. /// <summary>
  364. /// 出站接⼝ - 出参 - Body 实体
  365. /// </summary>
  366. public class XmMESStationOut_Body
  367. {
  368. /// <summary>
  369. /// 服务器响应时间,格式yyyy-MM-dd HH:mm:ss.fff
  370. /// </summary>
  371. public string serverTime { get; set; } = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff");
  372. /// <summary>
  373. /// 回溯结果:
  374. /// PASS 成功,可以下⼀站;FAIL 失败,需要进维修室*(需要回溯的⼯站专⽤,其它⼯站可以忽略该字段)
  375. /// </summary>
  376. public string lookBackResult { get; set; } = string.Empty;
  377. ///// <summary>
  378. /////
  379. ///// </summary>
  380. //public string requestTime { get; set; } = string.Empty;
  381. ///// <summary>
  382. /////
  383. ///// </summary>
  384. //public string processTime { get; set; } = string.Empty;
  385. }
  386. #endregion 出参
  387. }
  388. }