MESHelperServiceImpl.java 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197
  1. package com.uas.eis.serviceImpl;
  2. import com.uas.eis.core.config.SpObserver;
  3. import com.uas.eis.dao.BaseDao;
  4. import com.uas.eis.dao.SqlRowList;
  5. import com.uas.eis.entity.ErrorMessage;
  6. import com.uas.eis.entity.HelperType;
  7. import com.uas.eis.exception.ApiSystemException;
  8. import com.uas.eis.sdk.entity.ApiResult;
  9. import com.uas.eis.service.MESDataService;
  10. import com.uas.eis.service.MESHelperService;
  11. import com.uas.eis.utils.*;
  12. import net.sf.json.JSONObject;
  13. import net.sf.json.JsonConfig;
  14. import org.apache.commons.lang.StringUtils;
  15. import org.springframework.beans.factory.annotation.Autowired;
  16. import org.springframework.beans.factory.annotation.Value;
  17. import org.springframework.stereotype.Service;
  18. import sun.awt.TimedWindowEvent;
  19. import java.sql.Timestamp;
  20. import java.util.ArrayList;
  21. import java.util.HashMap;
  22. import java.util.List;
  23. import java.util.Map;
  24. @Service
  25. public class MESHelperServiceImpl implements MESHelperService {
  26. @Autowired
  27. private BaseDao baseDao;
  28. @Value("${spring.datasource.username}")
  29. private String username;
  30. String Master;
  31. @Override
  32. public Map<Object,Object> DLLMain(String accessKey, String requestId, String data) {
  33. String AE_MASTER = checkAccessKey(accessKey, requestId);
  34. SpObserver.putSp(AE_MASTER);
  35. Master=SpObserver.getSp();
  36. Map<Object, Object> map = BaseUtil.parseFormStoreToMap(data);
  37. //解析map
  38. if(!StringUtil.hasText(map.get("type"))){
  39. throw new ApiSystemException(new ApiResult(ErrorMessage.BUSINESS_TYPENULL,requestId));
  40. }
  41. if(!StringUtil.hasText(map.get("detail"))){
  42. throw new ApiSystemException(new ApiResult(ErrorMessage.BUSINESS_DATAILLEGAL,requestId));
  43. }
  44. String type = map.get("type").toString();
  45. JSONObject json = JSONObject.fromObject(map.get("detail"));
  46. HelperType helperType = HelperType.getTypeByCode(type);
  47. if(null == helperType){
  48. throw new ApiSystemException(new ApiResult(ErrorMessage.BUSINESS_TYPEILLEGAL,requestId));
  49. }
  50. int err = 0;
  51. //返回值
  52. Map<Object, Object> remap = new HashMap<Object, Object>();
  53. switch(helperType){
  54. case CheckRoutePassed:
  55. remap = CheckRoutePassed(json);
  56. break;
  57. case CheckUserAndResourcePassed:
  58. remap = CheckUserAndResourcePassed(json);
  59. break;
  60. case GetAddressRangeByMO:
  61. remap = GetAddressRangeByMO(json);
  62. break;
  63. case GetMEIOrNetCodeRange:
  64. remap = GetMEIOrNetCodeRange(json);
  65. break;
  66. case GetRcardMOInfo:
  67. remap = GetRcardMOInfo(json);
  68. break;
  69. case GetMobileAllInfo:
  70. remap = GetMobileAllInfo(json);
  71. break;
  72. case SetAddressInfo:
  73. remap = SetAddressInfo(json);
  74. break;
  75. case GetMaster:
  76. remap = GetMaster(json);
  77. break;
  78. case SetMobileData:
  79. remap = SetMobileData(json);
  80. break;
  81. case SetIMEIInfo:
  82. remap = SetIMEIInfo(json);
  83. break;
  84. case SetTestDetail:
  85. remap = SetTestDetail(json);
  86. break;
  87. case SetPcbaData:
  88. remap = SetPcbaData(json);
  89. break;
  90. case GetInfoByMaterial:
  91. remap = GetInfoByMaterial(json);
  92. break;
  93. case GoMo:
  94. remap = GoMo(json);
  95. break;
  96. case GetMakeInfoBySN:
  97. remap = GetMakeInfoBySN(json);
  98. break;
  99. case GetMakeInfoByProd:
  100. remap = GetMakeInfoByProd(json);
  101. break;
  102. case GetProdInfo:
  103. remap = GetProdInfo(json);
  104. break;
  105. case GetPSN:
  106. remap = GetPSN(json);
  107. break;
  108. case GetMakeRelation:
  109. remap = GetMakeRelation(json);
  110. break;
  111. default:
  112. err = -1;
  113. break;
  114. }
  115. if(err == -1){
  116. throw new ApiSystemException(new ApiResult(ErrorMessage.BUSINESS_TYPEILLEGAL,requestId));
  117. }
  118. SpObserver.putSp(username);
  119. return remap;
  120. }
  121. private Map<Object,Object> GoMo(JSONObject map){
  122. Map<Object, Object> rmap = new HashMap<Object, Object>();
  123. String iSN=null;
  124. String iResCode=null;
  125. String iMo=null;
  126. String oErrMessage=null;
  127. if(map.get("iMo")==null){
  128. oErrMessage = "工单号不能为空";
  129. rmap.put("oErrMessage",oErrMessage);
  130. return rmap;
  131. }
  132. if(map.get("iResCode")==null){
  133. oErrMessage = "岗位资源不能为空";
  134. rmap.put("oErrMessage",oErrMessage);
  135. return rmap;
  136. }
  137. if(map.get("iSN")==null){
  138. oErrMessage = "SN不能为空";
  139. rmap.put("oErrMessage",oErrMessage);
  140. return rmap;
  141. }
  142. iSN=map.get("iSN").toString();
  143. iResCode=map.get("iResCode").toString();
  144. iMo=map.get("iMo").toString();
  145. List<String> list = new ArrayList<String>();
  146. list = baseDao.callProcedureWithOut("CS_CHECKSTEPSNANDMACODE", new Object[]{
  147. String.valueOf(iMo),
  148. String.valueOf(iResCode),
  149. String.valueOf(iSN),
  150. String.valueOf("")
  151. }, new Integer[]{1, 2, 3, 4}, new Integer[]{5, 6, 7});
  152. oErrMessage=list.get(2);
  153. SqlRowList rs = baseDao.queryForRowSet("select ms_status,ms_stepcode,ms_nextstepcode from makeserial where ms_id=( select max(ms_id) from makeserial where ms_sncode in ( select '" + iSN + "' from dual union select sn from makesnrelation where beforesn='" + iSN + "' and sn<>' ' union select beforesn from makesnrelation where sn='" + iSN + "' and beforesn<>' '))");
  154. String ms_status = "";
  155. String ms_stepcode = "";
  156. String ms_nextstepcode = "";
  157. if(rs.next()){
  158. ms_status= rs.getString("ms_status");
  159. ms_stepcode=rs.getString("ms_stepcode");
  160. ms_nextstepcode=rs.getString("ms_nextstepcode");
  161. }
  162. String stepcode = GetStepCodeBySource(iResCode);
  163. if ( oErrMessage == null || (ms_status == "3" && ms_stepcode == stepcode))
  164. {
  165. if (ms_status == "3")
  166. {
  167. oErrMessage = null;
  168. }
  169. }
  170. rmap.put("oErrMessage",oErrMessage);
  171. return rmap;
  172. }
  173. private Map<Object,Object> GetInfoByMaterial(JSONObject map){
  174. Map<Object, Object> rmap = new HashMap<Object, Object>();
  175. String iPCBA=null;
  176. String oErrMessage=null;
  177. if(map.get("iPCBA")==null){
  178. oErrMessage = "主板SN不能为空";
  179. rmap.put("oErrMessage",oErrMessage);
  180. return rmap;
  181. }
  182. iPCBA=map.get("iPCBA").toString();
  183. SqlRowList rs=baseDao.queryForRowSet("select nvl(max(ms_id),0)ms_id from CRAFTMATERIAL left join makeserial on ms_firstsn=cm_firstsn where cm_barcode='"+iPCBA+"' and nvl(cm_status,0)<>-1 order by cm_id desc");
  184. if(rs.next()){
  185. if(!rs.getString("ms_id").equals("0")){
  186. rs=baseDao.queryForRowSet("select ma_bios,ma_ec,ms_sncode,ma_hardware from makeserial left join make on ms_makecode=ma_code where ms_id='"+rs.getString("ms_id")+"'");
  187. if (rs.next()){
  188. rmap.put("oSN",rs.getString("ms_sncode"));
  189. rmap.put("oBIOS",rs.getString("ma_bios"));
  190. rmap.put("oEC",rs.getString("ma_ec"));
  191. rmap.put("oHardWare",rs.getString("ma_hardware"));
  192. }
  193. }else{
  194. oErrMessage = "主板SN未查询到关联信息";
  195. rmap.put("oErrMessage",oErrMessage);
  196. return rmap;
  197. }
  198. }
  199. return rmap;
  200. }
  201. private Map<Object,Object> CheckRoutePassed(JSONObject map){
  202. //实际业务数据
  203. Map<Object, Object> rmap = new HashMap<>();
  204. String iSN=map.get("iSN").toString();
  205. String iResCode=map.get("iResCode").toString();
  206. String oErrMessage="";
  207. if (iSN ==null)
  208. {
  209. oErrMessage = "SN不能为空";
  210. }
  211. List<String> list = new ArrayList<String>();
  212. list = baseDao.callProcedureWithOut(Master+".CS_CHECKSTEPSNANDMACODE", new Object[]{
  213. String.valueOf(""),
  214. String.valueOf(iResCode),
  215. String.valueOf(iSN),
  216. String.valueOf("")
  217. }, new Integer[]{1, 2, 3, 4}, new Integer[]{5, 6, 7});
  218. oErrMessage=list.get(2);
  219. if(oErrMessage!=null){
  220. rmap.put("oErrMessage",oErrMessage);
  221. return rmap;
  222. }
  223. SqlRowList rs = baseDao.queryForRowSet("select ms_status,ms_stepcode,ms_nextstepcode from "+Master+".makeserial where ms_id=( select max(ms_id) from "+Master+".makeserial where ms_sncode in ( select '" + iSN + "' from dual union select sn from "+Master+".makesnrelation where beforesn='" + iSN + "' and sn<>' ' union select beforesn from "+Master+".makesnrelation where sn='" + iSN + "' and beforesn<>' '))");
  224. String ms_status = "";
  225. String ms_stepcode = "";
  226. String ms_nextstepcode = "";
  227. if(rs.next()){
  228. ms_status= rs.getString("ms_status");
  229. ms_stepcode=rs.getString("ms_stepcode");
  230. ms_nextstepcode=rs.getString("ms_nextstepcode");
  231. }
  232. String stepcode = GetStepCodeBySource(iResCode);
  233. if (ms_nextstepcode != "" && !ms_nextstepcode.equals(stepcode))
  234. {
  235. oErrMessage = "当前序列号下一工序" + ms_nextstepcode;
  236. }
  237. rmap.put("oErrMessage",oErrMessage);
  238. return rmap;
  239. }
  240. private Map<Object,Object> CheckUserAndResourcePassed(JSONObject map){
  241. //实际业务数据
  242. Map<Object, Object> rmap = new HashMap<>();
  243. String oErrMessage = null;
  244. if (map.get("iUserCode") == null || map.get("iResCode") == null || map.get("iPassWord") == null)
  245. {
  246. oErrMessage = "用户名,密码,岗位资源必须填写";
  247. rmap.put("oErrMessage",oErrMessage);
  248. return rmap;
  249. }
  250. String iUserCode=map.get("iUserCode").toString();
  251. String iPassWord=map.get("iPassWord").toString();
  252. String iResCode=map.get("iResCode").toString();
  253. if (CheckUserLogin(iUserCode, iPassWord))
  254. {
  255. String SQL = "select em_code,em_type,em_name from "+Master+".employee where em_code=? ";
  256. SqlRowList rs = baseDao.queryForRowSet(SQL, iUserCode);
  257. if (rs.next())
  258. {
  259. String em_name = rs.getString("em_name");
  260. String em_type = rs.getString("em_type");
  261. if (iResCode ==null)
  262. {
  263. oErrMessage = "岗位资源不允许为空";
  264. rmap.put("oErrMessage",oErrMessage);
  265. return rmap;
  266. }
  267. if (em_type.equals("admin"))
  268. {
  269. if (!baseDao.checkIf(""+Master+".Source", "sc_code='" + iResCode + "' and sc_statuscode='AUDITED'"))
  270. {
  271. oErrMessage = "岗位资源编号错误或者未审核!";
  272. }
  273. }
  274. else
  275. {
  276. SqlRowList rs1=baseDao.queryForRowSet("select ur_resourcecode from "+Master+".cs$empgroup left join "+Master+".cs$userresource on ur_groupcode=eg_groupcode left join "+Master+".source on ur_resourcecode=sc_code where eg_emcode = '"+ iUserCode + "' and sc_statuscode='AUDITED'");
  277. //如果存在该编号
  278. if (rs1.next())
  279. {
  280. //判断如果多个岗位资源存在,用户输入的只要在其中就行
  281. while (rs.next())
  282. {
  283. if (!rs.getString("ur_resourcecode").equals("iResCode")){
  284. oErrMessage = "用户不处于当前资源所属分组!";
  285. }else
  286. {
  287. oErrMessage=null;
  288. continue;
  289. }
  290. }
  291. }
  292. else
  293. oErrMessage = "岗位资源编号错误或者未审核!";
  294. }
  295. }
  296. else
  297. oErrMessage = "用户不存在!";
  298. }else{
  299. oErrMessage = "用户名密码不正确!";
  300. }
  301. rmap.put("oErrMessage",oErrMessage);
  302. return rmap;
  303. }
  304. private Map<Object,Object> GetAddressRangeByMO(JSONObject map){
  305. //实际业务数据
  306. Map<Object, Object> rmap = new HashMap<>();
  307. String iSN="";
  308. String oErrMessage = null;
  309. String oWIFI = "";
  310. String oBT = "";
  311. String oCode1 = "";
  312. String oCode2 = "";
  313. String oCode3 = "";
  314. if(map.get("iSN")==null){
  315. oErrMessage = "SN不能为空";
  316. rmap.put("oErrMessage",oErrMessage);
  317. return rmap;
  318. }
  319. iSN=map.get("iSN").toString();
  320. //判断工单是否归属
  321. JSONObject map3=new JSONObject();
  322. map3.put("iSN",iSN);
  323. Map<Object, Object> map2=GetRcardMOInfo(map3);
  324. if(map2.get("oErrMessage")!=null){
  325. oErrMessage=map2.get("oErrMessage").toString();
  326. rmap.put("oErrMessage",oErrMessage);
  327. return rmap;
  328. }
  329. List<String> list = new ArrayList<String>();
  330. list = baseDao.callProcedureWithOut(Master+".CS_GETADDRESSBYMAKECODE", new Object[]{
  331. String.valueOf(iSN),
  332. String.valueOf(map2.get("oMoCode").toString()),
  333. }, new Integer[]{1,2}, new Integer[]{3,4,5,6,7,8});
  334. oWIFI = list.get(0);
  335. oBT = list.get(1);
  336. oCode1 = list.get(2);
  337. oCode2 = list.get(3);
  338. oCode3 = list.get(4);
  339. oErrMessage= list.get(5);
  340. if (oErrMessage == "" || oErrMessage == null || oErrMessage == "null"){
  341. rmap.put("oWIFI",oWIFI);
  342. rmap.put("oBT",oBT);
  343. rmap.put("oCode1",oCode1);
  344. rmap.put("oCode2",oCode2);
  345. rmap.put("oCode3",oCode3);
  346. }
  347. else
  348. rmap.put("oErrMessage",oErrMessage);
  349. return rmap;
  350. }
  351. private Map<Object,Object> GetMEIOrNetCodeRange(JSONObject map){
  352. //实际业务数据
  353. Map<Object, Object> rmap = new HashMap<>();
  354. String iSN="";
  355. String oErrMessage = null;
  356. String oIMEI1 = "";
  357. String oIMEI2 = "";
  358. String oMEID = "";
  359. String oNetCode = "";
  360. String oPSN = "";
  361. String oID1 = "";
  362. String oID2 = "";
  363. String oID3 = "";
  364. String oID4 = "";
  365. String oID5 = "";
  366. if(map.get("iSN")==null){
  367. oErrMessage = "SN不能为空";
  368. rmap.put("oErrMessage",oErrMessage);
  369. return rmap;
  370. }
  371. if(map.get("iIMEI1")!=null){
  372. oIMEI1=map.get("iIMEI1").toString();
  373. }
  374. if(map.get("iNetCode")!=null){
  375. oNetCode=map.get("iNetCode").toString();
  376. }
  377. iSN=map.get("iSN").toString();
  378. List<String> list = new ArrayList<String>();
  379. list = baseDao.callProcedureWithOut(Master+".CS_GETIMEIORNETCODERANGE", new Object[]{
  380. String.valueOf(iSN),
  381. String.valueOf(""),
  382. String.valueOf(oIMEI1),
  383. String.valueOf(oNetCode),
  384. }, new Integer[]{1,2,3,4}, new Integer[]{5,6,7,8,9,10,11,12,13,14});
  385. oIMEI1 = list.get(0);
  386. oIMEI2 = list.get(1);
  387. oMEID = list.get(2);
  388. oNetCode = list.get(3);
  389. oID1 = list.get(4);
  390. oID2 = list.get(5);
  391. oID3 = list.get(6);
  392. oID4 = list.get(7);
  393. oID5 = list.get(8);
  394. oErrMessage= list.get(9);
  395. if (oErrMessage == "" || oErrMessage == null || oErrMessage == "null"){
  396. rmap.put("oIMEI1",oIMEI1);
  397. rmap.put("oIMEI2",oIMEI2);
  398. rmap.put("oMEID",oMEID);
  399. rmap.put("oNetCode",oNetCode);
  400. rmap.put("oPSN",oPSN);
  401. rmap.put("oID1",oID1);
  402. rmap.put("oID2",oID2);
  403. rmap.put("oID3",oID3);
  404. rmap.put("oID4",oID4);
  405. rmap.put("oID5",oID5);
  406. }
  407. else
  408. rmap.put("oErrMessage",oErrMessage);
  409. return rmap;
  410. }
  411. private Map<Object,Object> GetRcardMOInfo(JSONObject map){
  412. //实际业务数据
  413. Map<Object, Object> rmap = new HashMap<>();
  414. //取MakeProcess表中的执行记录ID最大的一个工单的号码
  415. String oErrMessage = null;
  416. if(map.get("iSN")==null){
  417. oErrMessage = "SN不能为空";
  418. rmap.put("oErrMessage",oErrMessage);
  419. return rmap;
  420. }
  421. String iSN=map.get("iSN").toString();
  422. StringBuffer sql=new StringBuffer();
  423. sql.append("select max(ms_id)ms_id from makeserial where ms_sncode in (select '" + iSN + "' from dual union select sn from ");
  424. sql.append("makesnrelation where beforesn='" + iSN + "' and sn<>' ' union select beforesn from makesnrelation where sn='" + iSN + "' and beforesn<>' ')");
  425. SqlRowList rs = baseDao.queryForRowSet(sql.toString());
  426. String ms_id="";
  427. if(rs.next()){
  428. if(rs.getString("ms_id")==null){
  429. oErrMessage = "序列号:" + iSN + " 未归属工单";
  430. rmap.put("oErrMessage",oErrMessage);
  431. return rmap;
  432. }
  433. else{
  434. ms_id= rs.getString("ms_id");
  435. }
  436. }
  437. Object[] oMoCode = baseDao.getFieldsDataByCondition("MakeSerial", "ms_makecode,ms_prodcode", "ms_id='" + ms_id + "'");
  438. if (oMoCode != null){
  439. rmap.put("oMoCode",oMoCode[0]);
  440. rmap.put("oPrCode",oMoCode[1]);
  441. oErrMessage= null;
  442. }
  443. else
  444. {
  445. oErrMessage = "序列号:" + iSN + " 未归属工单";
  446. }
  447. rmap.put("oErrMessage",oErrMessage);
  448. return rmap;
  449. }
  450. private Map<Object,Object> GetMobileAllInfo(JSONObject map){
  451. //实际业务数据
  452. Map<Object, Object> rmap = new HashMap<>();
  453. String iSN="";
  454. String oErrMessage = null;
  455. String oIMEI1 = "";
  456. String oIMEI2 = "";
  457. String oMEID = "";
  458. String oNetCode = "";
  459. String oPSN = "";
  460. String oID1 = "";
  461. String oID2 = "";
  462. String oID3 = "";
  463. String oID4 = "";
  464. String oID5 = "";
  465. String oWIFI = "";
  466. String oBT = "";
  467. String oCode1 = "";
  468. String oCode2 = "";
  469. String oCode3 = "";
  470. if(map.get("iSN")==null){
  471. oErrMessage = "SN不能为空";
  472. rmap.put("oErrMessage",oErrMessage);
  473. return rmap;
  474. }
  475. iSN=map.get("iSN").toString();
  476. Object ms_id =baseDao.getFieldDataByCondition("makeserial", "max(ms_id)", "ms_sncode='" + iSN + "'");
  477. if(ms_id!=null)
  478. {
  479. SqlRowList rs=baseDao.queryForRowSet("select ms_id, ms_mac, ms_bt, ms_meid, ms_netcode, ms_psn, ms_imei1, ms_imei2, ms_imei3, ms_othcode1, ms_othcode2, ms_othcode3, ms_othid1, ms_othid2, ms_othid3 from MakeSerial where ms_id="+ms_id.toString());
  480. if(rs.next()){
  481. oWIFI = rs.getString("ms_mac");
  482. oBT = rs.getString("ms_bt");
  483. oPSN = rs.getString("ms_psn");
  484. oNetCode = rs.getString("ms_netcode");
  485. oMEID = rs.getString("ms_meid");
  486. oIMEI1 = rs.getString("ms_imei1");
  487. oIMEI2 = rs.getString("ms_imei2");
  488. oCode1 = rs.getString("ms_othcode1");
  489. oCode2 = rs.getString("ms_othcode2");
  490. oCode3 = rs.getString("ms_othcode3");
  491. oID1 = rs.getString("ms_othid3");
  492. oID2 = rs.getString("ms_othid3");
  493. oID3 = rs.getString("ms_othid3");
  494. }
  495. }else
  496. {
  497. oErrMessage = "序列号" + iSN + "不存在";
  498. rmap.put("oErrMessage",oErrMessage);
  499. return rmap;
  500. }
  501. if (oErrMessage == "" || oErrMessage == null || oErrMessage == "null"){
  502. rmap.put("oIMEI1",oIMEI1);
  503. rmap.put("oIMEI2",oIMEI2);
  504. rmap.put("oMEID",oMEID);
  505. rmap.put("oNetCode",oNetCode);
  506. rmap.put("oPSN",oPSN);
  507. rmap.put("oID1",oID1);
  508. rmap.put("oID2",oID2);
  509. rmap.put("oID3",oID3);
  510. rmap.put("oID4",oID4);
  511. rmap.put("oID5",oID5);
  512. rmap.put("oWIFI",oWIFI);
  513. rmap.put("oBT",oBT);
  514. rmap.put("oCode1",oCode1);
  515. rmap.put("oCode2",oCode2);
  516. rmap.put("oCode3",oCode3);
  517. }
  518. else
  519. rmap.put("oErrMessage",oErrMessage);
  520. return rmap;
  521. }
  522. private Map<Object,Object> SetAddressInfo(JSONObject map){
  523. //实际业务数据
  524. Map<Object, Object> rmap = new HashMap<>();
  525. String oErrMessage = null;
  526. if(map.get("iSN")==null){
  527. oErrMessage = "SN不能为空";
  528. rmap.put("oErrMessage",oErrMessage);
  529. return rmap;
  530. }
  531. String iSN=map.get("iSN").toString();
  532. String iWIFI = null;
  533. String iBT = null;
  534. String iCode1 = null;
  535. String iCode2 = null;
  536. String iCode3 = null;
  537. if(map.get("iMAC")!=null){
  538. iWIFI=map.get("iMAC").toString();
  539. }
  540. if(map.get("iWIFI")!=null){
  541. iWIFI=map.get("iWIFI").toString();
  542. }
  543. if(map.get("iBT")!=null){
  544. iBT=map.get("iBT").toString();
  545. }
  546. if(map.get("iCode1")!=null){
  547. iCode1=map.get("iCode1").toString();
  548. }
  549. if(map.get("iCode2")!=null){
  550. iCode2=map.get("iCode2").toString();
  551. }
  552. if(map.get("iCode3")!=null){
  553. iCode3=map.get("iCode3").toString();
  554. }
  555. List<String> list = new ArrayList<String>();
  556. list = baseDao.callProcedureWithOut(Master+".CS_SETADDRESSINFO", new Object[]{
  557. String.valueOf(iSN),
  558. String.valueOf(iWIFI),
  559. String.valueOf(iBT),
  560. String.valueOf(iCode1),
  561. String.valueOf(iCode2),
  562. String.valueOf(iCode3)
  563. }, new Integer[]{1, 2, 3, 4, 5, 6}, new Integer[]{7});
  564. oErrMessage = list.get(0);
  565. rmap.put("oErrMessage",oErrMessage);
  566. return rmap;
  567. }
  568. private Map<Object,Object> GetMaster(JSONObject map){
  569. //实际业务数据
  570. Map<Object, Object> rmap = new HashMap<>();
  571. SqlRowList rs=baseDao.queryForRowSet("select ma_user,AE_KEY,AE_SECRET from mes.master left join MES.APIEMPLOYEE B on ma_user=ae_master");
  572. while(rs.next())
  573. {
  574. rmap.put(rs.getString("ma_user"),rs.getString("AE_KEY")+"|"+rs.getString("AE_SECRET"));
  575. }
  576. return rmap;
  577. }
  578. private Map<Object,Object> SetMobileData(JSONObject map){
  579. //实际业务数据
  580. Map<Object, Object> rmap = new HashMap<>();
  581. String oErrMessage = null;
  582. if(map.get("iSN")==null||map.get("iTSN")==null){
  583. oErrMessage = "SN不能为空";
  584. rmap.put("oErrMessage",oErrMessage);
  585. return rmap;
  586. }
  587. String iSN=map.get("iSN").toString();
  588. String iTSN=map.get("iTSN").toString();
  589. String iSourceCode = null;
  590. String iOperater = null;
  591. String iResult = null;
  592. String flag = null;
  593. String iErrCode = null;
  594. if(map.get("iSourceCode")!=null){
  595. iSourceCode=map.get("iSourceCode").toString();
  596. }
  597. if(map.get("iOperater")!=null){
  598. iOperater=map.get("iOperater").toString();
  599. }
  600. if(map.get("iResult")!=null){
  601. iResult=map.get("iResult").toString();
  602. }
  603. if(map.get("flag")!=null){
  604. flag=map.get("flag").toString();
  605. }
  606. if(map.get("iErrCode")!=null){
  607. iErrCode=map.get("iErrCode").toString();
  608. }
  609. List<String> list = new ArrayList<String>();
  610. list = baseDao.callProcedureWithOut("CS_DLLSNCHANGE_TOOL", new Object[]{
  611. String.valueOf(iTSN),
  612. String.valueOf(iSN),
  613. String.valueOf(iSourceCode),
  614. String.valueOf(iOperater),
  615. String.valueOf(iResult),
  616. String.valueOf(iErrCode),
  617. }, new Integer[]{1, 2, 3, 4, 5, 6}, new Integer[]{7});
  618. oErrMessage = list.get(0);
  619. rmap.put("oErrMessage",oErrMessage);
  620. return rmap;
  621. }
  622. private Map<Object,Object> SetIMEIInfo(JSONObject map){
  623. //实际业务数据
  624. Map<Object, Object> rmap = new HashMap<>();
  625. String oErrMessage = null;
  626. if(map.get("iSN")==null){
  627. oErrMessage = "SN不能为空";
  628. rmap.put("oErrMessage",oErrMessage);
  629. return rmap;
  630. }
  631. String iSN=map.get("iSN").toString();
  632. String iIMEI1=null;
  633. String iIMEI2 = null;
  634. String iIMEI3 = null;
  635. String iMEID = null;
  636. String iNET = null;
  637. String iID1 = null;
  638. String iID2 = null;
  639. String iID3 = null;
  640. if(map.get("iIMEI1")!=null){
  641. iIMEI1=map.get("iIMEI1").toString();
  642. }
  643. if(map.get("iIMEI2")!=null){
  644. iIMEI2=map.get("iIMEI2").toString();
  645. }
  646. if(map.get("iIMEI3")!=null){
  647. iIMEI3=map.get("iIMEI3").toString();
  648. }
  649. if(map.get("iMEID")!=null){
  650. iMEID=map.get("iMEID").toString();
  651. }
  652. if(map.get("iNET")!=null){
  653. iNET=map.get("iNET").toString();
  654. }
  655. if(map.get("iID1")!=null){
  656. iID1=map.get("iID1").toString();
  657. }
  658. if(map.get("iID2")!=null){
  659. iID2=map.get("iID2").toString();
  660. }
  661. if(map.get("iID3")!=null){
  662. iID3=map.get("iID3").toString();
  663. }
  664. List<String> list = new ArrayList<String>();
  665. list = baseDao.callProcedureWithOut(Master+".CS_SETIMEIINFO", new Object[]{
  666. String.valueOf(iSN),
  667. String.valueOf(iIMEI1),
  668. String.valueOf(iIMEI2),
  669. String.valueOf(iIMEI3),
  670. String.valueOf(iMEID),
  671. String.valueOf(iNET),
  672. String.valueOf(""),
  673. String.valueOf(iID1),
  674. String.valueOf(iID2),
  675. String.valueOf(iID3),
  676. }, new Integer[]{1, 2, 3, 4, 5, 6,7,8,9,10}, new Integer[]{11});
  677. oErrMessage = list.get(0);
  678. rmap.put("oErrMessage",oErrMessage);
  679. return rmap;
  680. }
  681. private Map<Object,Object> SetTestDetail(JSONObject map){
  682. //实际业务数据
  683. Map<Object, Object> rmap = new HashMap<>();
  684. String oErrMessage=null;
  685. if(map.get("iSN")==null){
  686. oErrMessage = "SN不能为空";
  687. rmap.put("oErrMessage",oErrMessage);
  688. return rmap;
  689. }
  690. String iSN=map.get("iSN").toString();
  691. String iTestResult= "";
  692. String iResCode= "";
  693. String iClassName="";
  694. String iTestDetail= "";
  695. String iMaxValue= "";
  696. String iMinValue= "";
  697. if(map.get("iTestResult")!=null){
  698. iTestResult=map.get("iTestResult").toString();
  699. }
  700. if(map.get("iClassName")!=null){
  701. iClassName=map.get("iClassName").toString();
  702. }
  703. if(map.get("iResCode")!=null){
  704. iResCode=map.get("iResCode").toString();
  705. }
  706. if(map.get("iTestDetail")!=null){
  707. iTestDetail=map.get("iTestDetail").toString();
  708. }
  709. if(map.get("iMaxValue")!=null){
  710. iMaxValue=map.get("iTestDetail").toString();
  711. }
  712. if(map.get("iMinValue")!=null){
  713. iMinValue=map.get("iTestDetail").toString();
  714. }
  715. JSONObject map3=new JSONObject();
  716. map3.put("iSN",iSN);
  717. Map<Object, Object> map2=GetRcardMOInfo(map3);
  718. String omakeCode = "";
  719. StringBuffer sql=new StringBuffer();
  720. String[] name=iClassName.split("\\|");
  721. String[] result=iTestResult.split("\\|");
  722. String[] value=iTestDetail.split("\\|");
  723. if(name.length!=value.length||name.length!=result.length){
  724. rmap.put("oErrMessage","测试项目名称和值的项次不一致");
  725. return rmap;
  726. }
  727. for (int i=0;i<name.length;i++){
  728. sql.setLength(0);
  729. sql.append("Insert into STEPTESTDETAIL (STD_ID,STD_CLASS,STD_SN,STD_MAKECODE,STD_ACTUALVALUE,STD_TESTRESULT,STD_INDATE,STD_RESCODE,STD_MAXVALUE, STD_MINVALUE)");
  730. sql.append("values(STEPTESTDETAIL_SEQ.nextval,'"+name[i]+"','" + iSN + "','" + map2.get("oMoCode") + "','" + value[i] + "','" + result[i] + "',sysdate,'" + iResCode + "','"+iMaxValue+"','"+iMinValue+"')");
  731. baseDao.execute(sql.toString());
  732. }
  733. rmap.put("oErrMessage",oErrMessage);
  734. return rmap;
  735. }
  736. private Map<Object,Object> SetPcbaData(JSONObject map){
  737. //实际业务数据
  738. Map<Object, Object> rmap = new HashMap<>();
  739. String oErrMessage = null;
  740. if(map.get("iSN")==null){
  741. oErrMessage = "SN不能为空";
  742. rmap.put("oErrMessage",oErrMessage);
  743. return rmap;
  744. }
  745. String iSN=map.get("iSN").toString();
  746. String iResCode = null;
  747. String iOperator = null;
  748. String iResult = null;
  749. String iErrCode = null;
  750. if(map.get("iResCode")!=null){
  751. iResCode=map.get("iResCode").toString();
  752. }
  753. if(map.get("iOperater")!=null){
  754. iOperator=map.get("iOperater").toString();
  755. }
  756. if(map.get("iResult")!=null){
  757. iResult=map.get("iResult").toString();
  758. }
  759. if(map.get("iErrCode")!=null){
  760. iErrCode=map.get("iErrCode").toString();
  761. }
  762. SqlRowList rs=baseDao.queryForRowSet("select nvl(st_ifinput,0)st_ifinput,nvl(st_ifoqc,0)st_ifoqc,nvl(st_ifweigh,0)st_ifweigh from "+Master+".source left join "+Master+".step on sc_stepcode=st_code where sc_code='"+iResCode+"'");
  763. if(rs.next()){
  764. String st_ifinput=rs.getString("st_ifinput");
  765. String st_ifoqc=rs.getString("st_ifinput");
  766. String st_ifweigh=rs.getString("st_ifweigh");
  767. if(st_ifinput.equals("-1")){
  768. oErrMessage = "上料工序必须在客户端进行过站";
  769. rmap.put("oErrMessage",oErrMessage);
  770. return rmap;
  771. }
  772. if(st_ifoqc.equals("-1")){
  773. oErrMessage = "OQC必须在客户端进行过站";
  774. rmap.put("oErrMessage",oErrMessage);
  775. return rmap;
  776. }
  777. if(st_ifweigh.equals("-1")){
  778. oErrMessage = "称重工序必须在客户端进行过站";
  779. rmap.put("oErrMessage",oErrMessage);
  780. return rmap;
  781. }
  782. }
  783. JSONObject map3=new JSONObject();
  784. map3.put("iSN",iSN);
  785. Map<Object, Object> map2=GetRcardMOInfo(map3);
  786. String oMoCode=null;
  787. if(map2.get("oMoCode")!=null){
  788. oMoCode=map2.get("oMoCode").toString();
  789. }
  790. if (map2.get("oErrMessage")==null)
  791. return SetStepFinish(oMoCode, iResCode, iSN, "", iResult, iOperator, iErrCode);
  792. return rmap;
  793. }
  794. /// <summary>
  795. /// 获取步骤代码
  796. /// </summary>
  797. /// <param name="Source"></param>
  798. /// <returns></returns>
  799. private String GetStepCodeBySource(String Source)
  800. {
  801. Object o=baseDao.getFieldDataByCondition("source", "sc_stepcode", "sc_code='" + Source + "'");
  802. if(o!=null)
  803. return o.toString();
  804. else
  805. return "";
  806. }
  807. private Boolean CheckUserLogin(String iUserCode, String iPassWord)
  808. {
  809. SqlRowList rs =baseDao.queryForRowSet("select em_code from "+Master+".employee where em_code='"+iUserCode+"' and em_password =?",iPassWord);
  810. if (rs.next())
  811. return true;
  812. else
  813. {
  814. return false;
  815. }
  816. }
  817. private Map<Object,Object> GetMakeInfoBySN(JSONObject map)
  818. {
  819. Map<Object, Object> rmap = new HashMap<Object, Object>();
  820. String iSN=null;
  821. String oErrMessage=null;
  822. if(map.get("iSN")==null){
  823. oErrMessage = "SN不能为空";
  824. rmap.put("oErrMessage",oErrMessage);
  825. return rmap;
  826. }
  827. iSN=map.get("iSN").toString();
  828. SqlRowList rs=baseDao.queryForRowSet("select ma_remark1,ma_remark2,ma_remark3,ma_remark4,ma_remark5,ma_remark6,ma_remark7,ma_remark8,ma_remark9,ma_remark10,ma_remark11,ma_remark12,ma_remark13,ma_remark14,ma_remark15,ma_remark16,ma_remark17,ma_remark18 from "+Master+".make " +
  829. "left join "+Master+".makeserial on ms_makecode=ma_code where ms_sncode='"+iSN+"' order by ms_id desc");
  830. if(rs.next()){
  831. rmap.put("oMaremark1",rs.getString("ma_remark1"));
  832. rmap.put("oMaremark2",rs.getString("ma_remark2"));
  833. rmap.put("oMaremark3",rs.getString("ma_remark3"));
  834. rmap.put("oMaremark4",rs.getString("ma_remark4"));
  835. rmap.put("oMaremark5",rs.getString("ma_remark5"));
  836. rmap.put("oMaremark6",rs.getString("ma_remark6"));
  837. rmap.put("oMaremark7",rs.getString("ma_remark7"));
  838. rmap.put("oMaremark8",rs.getString("ma_remark8"));
  839. rmap.put("oMaremark9",rs.getString("ma_remark9"));
  840. rmap.put("oMaremark10",rs.getString("ma_remark10"));
  841. rmap.put("oMaremark11",rs.getString("ma_remark11"));
  842. rmap.put("oMaremark12",rs.getString("ma_remark12"));
  843. rmap.put("oMaremark13",rs.getString("ma_remark13"));
  844. rmap.put("oMaremark14",rs.getString("ma_remark14"));
  845. rmap.put("oMaremark15",rs.getString("ma_remark15"));
  846. rmap.put("oMaremark16",rs.getString("ma_remark16"));
  847. rmap.put("oMaremark17",rs.getString("ma_remark17"));
  848. rmap.put("oMaremark18",rs.getString("ma_remark18"));
  849. return rmap;
  850. }else{
  851. oErrMessage = "SN未查询到关联信息";
  852. rmap.put("oErrMessage",oErrMessage);
  853. return rmap;
  854. }
  855. }
  856. private Map<Object,Object> GetPSN(JSONObject map){
  857. String oErrMessage="";
  858. Map<Object, Object> rmap = new HashMap<Object, Object>();
  859. if(map.get("iSN")==null){
  860. oErrMessage = "SN不能为空";
  861. rmap.put("oErrMessage",oErrMessage);
  862. return rmap;
  863. }
  864. String iSN=map.get("iSN").toString();
  865. Object iMakecode=baseDao.getFieldDataByCondition("makeserial","ms_makecode","ms_id=(select max(ms_id) from makeserial where ms_sncode='"+iSN+"')");
  866. if(iMakecode==null){
  867. oErrMessage = iSN+"无关联工单";
  868. rmap.put("oErrMessage",oErrMessage);
  869. return rmap;
  870. }
  871. //之前有获取过的
  872. SqlRowList rs=baseDao.queryForRowSet("select msl_sncode from makesnlist where msl_beforesn='"+iSN+"'");
  873. if(rs.next()){
  874. rmap.put("msl_sncode",rs.getString("msl_sncode"));
  875. return rmap;
  876. }
  877. rs=baseDao.queryForRowSet("select msl_sncode,msl_id from makesnlist where msl_makecode='"+iMakecode+"' and msl_type='after' and nvl(msl_status,0)=0 order by msl_sncode");
  878. if(rs.next()){
  879. String msl_id=rs.getString("msl_id");
  880. String msl_sncode=rs.getString("msl_sncode");
  881. baseDao.execute("update makesnlist set msl_status=-1,msl_beforesn='"+iSN+"' where msl_id="+msl_id+" and nvl(msl_status,0)=0");
  882. rmap.put("msl_sncode",msl_sncode);
  883. return rmap;
  884. }else{
  885. oErrMessage = "无可分配号段";
  886. rmap.put("oErrMessage",oErrMessage);
  887. return rmap;
  888. }
  889. }
  890. private Map<Object,Object> GetMakeRelation(JSONObject map){
  891. String oErrMessage="";
  892. Map<Object, Object> rmap = new HashMap<Object, Object>();
  893. if(map.get("iSN")==null){
  894. oErrMessage = "SN不能为空";
  895. rmap.put("oErrMessage",oErrMessage);
  896. return rmap;
  897. }
  898. String iSN=map.get("iSN").toString();
  899. Object iMakecode=baseDao.getFieldDataByCondition("makeserial","ms_makecode","ms_id=(select max(ms_id) from makeserial where ms_sncode='"+iSN+"')");
  900. if(iMakecode==null){
  901. oErrMessage = iSN+"无关联工单";
  902. rmap.put("oErrMessage",oErrMessage);
  903. return rmap;
  904. }
  905. //之前有获取过的
  906. SqlRowList rs=baseDao.queryForRowSet("select * from makeinfodet left join MakeRemark on MID_ORDERCODE=ordernumber " +
  907. "left join aftersaledet on asd_sn=mid_sn left join DeliveryIn on DeliveryIn.sn=mid_sn " +
  908. "left join Deliveryout on Deliveryout.sn=mid_sn left join remakedet on mid_sn=RMD_SN where mid_ordercode='"+iMakecode+"' and rownum=1");
  909. if(rs.next()){
  910. rmap.put("MID_ID","");
  911. rmap.put("MID_MIID",rs.getString("MID_MIID"));
  912. rmap.put("MID_ORDERCODE",rs.getString("MID_ORDERCODE"));
  913. rmap.put("MID_SN",rs.getString("MID_SN"));
  914. rmap.put("MID_WIFIMAC",rs.getString("MID_WIFIMAC"));
  915. rmap.put("MID_IMEI",rs.getString("MID_IMEI"));
  916. rmap.put("MID_BTMAC",rs.getString("MID_BTMAC"));
  917. rmap.put("MID_OSVERSION",rs.getString("MID_OSVERSION"));
  918. rmap.put("MID_OSPRODUCTKEY",rs.getString("MID_OSPRODUCTKEY"));
  919. rmap.put("MID_OSPRODUCTID",rs.getString("MID_OSPRODUCTID"));
  920. rmap.put("MID_DRIVERVERSION",rs.getString("MID_DRIVERVERSION"));
  921. rmap.put("MID_BIOSVERSION",rs.getString("MID_BIOSVERSION"));
  922. rmap.put("MID_PROCESSID",rs.getString("MID_PROCESSID"));
  923. rmap.put("MID_HARDDISKSN",rs.getString("MID_HARDDISKSN"));
  924. rmap.put("MID_HARDDISKMODEL",rs.getString("MID_HARDDISKMODEL"));
  925. rmap.put("MID_CREATETIME",rs.getString("MID_CREATETIME"));
  926. rmap.put("MID_DETNO",rs.getString("MID_DETNO"));
  927. rmap.put("MID_EC",rs.getString("MID_EC"));
  928. rmap.put("ORDERNUMBER",rs.getString("ORDERNUMBER"));
  929. rmap.put("CUSTOMER",rs.getString("CUSTOMER"));
  930. rmap.put("MODEL",rs.getString("MODEL"));
  931. rmap.put("ORDERQUANTITY",rs.getString("ORDERQUANTITY"));
  932. rmap.put("BARCODE",rs.getString("BARCODE"));
  933. rmap.put("CPU",rs.getString("CPU"));
  934. rmap.put("RAM",rs.getString("RAM"));
  935. rmap.put("ROM",rs.getString("ROM"));
  936. rmap.put("GENERATION",rs.getString("GENERATION"));
  937. rmap.put("WIFI",rs.getString("WIFI"));
  938. rmap.put("LCD",rs.getString("LCD"));
  939. rmap.put("DPI",rs.getString("DPI"));
  940. rmap.put("TP",rs.getString("TP"));
  941. rmap.put("NFC",rs.getString("NFC"));
  942. rmap.put("CAMERA",rs.getString("CAMERA"));
  943. rmap.put("BAT",rs.getString("BAT"));
  944. rmap.put("GPS",rs.getString("GPS"));
  945. rmap.put("FINGERPRINT",rs.getString("FINGERPRINT"));
  946. rmap.put("MAINBOARDVER",rs.getString("MAINBOARDVER"));
  947. rmap.put("SUBBOARDVER",rs.getString("SUBBOARDVER"));
  948. rmap.put("OSTYPE",rs.getString("OSTYPE"));
  949. rmap.put("MACHINECODE",rs.getString("MACHINECODE"));
  950. rmap.put("MCU",rs.getString("MCU"));
  951. rmap.put("GYROSCOPE",rs.getString("GYROSCOPE"));
  952. rmap.put("ACCELEROMETER",rs.getString("ACCELEROMETER"));
  953. rmap.put("MAGNETOMETER",rs.getString("MAGNETOMETER"));
  954. rmap.put("LIGHTSENSOR",rs.getString("LIGHTSENSOR"));
  955. rmap.put("BRIDGEIC",rs.getString("BRIDGEIC"));
  956. rmap.put("REMARK",rs.getString("REMARK"));
  957. rmap.put("IDENTITYMODULE",rs.getString("IDENTITYMODULE"));
  958. rmap.put("ASD_MACHINETYPE",rs.getString("ASD_MACHINETYPE"));
  959. rmap.put("ASD_RECIVETIME",rs.getString("ASD_RECIVETIME"));
  960. rmap.put("ASD_SALEER",rs.getString("ASD_SALEER"));
  961. rmap.put("ASD_CUSTNAME",rs.getString("ASD_CUSTNAME"));
  962. rmap.put("ASD_QTY",rs.getString("ASD_QTY"));
  963. rmap.put("ASD_SENDMAN",rs.getString("ASD_SENDMAN"));
  964. rmap.put("ASD_CONFIG",rs.getString("ASD_CONFIG"));
  965. rmap.put("ASD_CONTENT",rs.getString("ASD_CONTENT"));
  966. rmap.put("ASD_KIND",rs.getString("ASD_KIND"));
  967. rmap.put("ASD_DEALMAN",rs.getString("ASD_DEALMAN"));
  968. rmap.put("ASD_FINISHTIME",rs.getString("ASD_FINISHTIME"));
  969. rmap.put("ASD_STATUS",rs.getString("ASD_STATUS"));
  970. rmap.put("ASD_REMARK",rs.getString("ASD_REMARK"));
  971. rmap.put("ASD_ACTREMAKETIME",rs.getString("ASD_ACTREMAKETIME"));
  972. rmap.put("ASD_BIOS",rs.getString("ASD_BIOS"));
  973. rmap.put("ASD_OS",rs.getString("ASD_OS"));
  974. rmap.put("ASD_DETNO",rs.getString("ASD_DETNO"));
  975. rmap.put("ASD_SN",rs.getString("ASD_SN"));
  976. rmap.put("ASD_IMEI",rs.getString("ASD_IMEI"));
  977. rmap.put("ASD_INDATE",rs.getString("ASD_INDATE"));
  978. rmap.put("SN",rs.getString("SN"));
  979. rmap.put("IMEI",rs.getString("IMEI"));
  980. rmap.put("SALES",rs.getString("SALES"));
  981. rmap.put("DELIVERY",rs.getString("DELIVERY"));
  982. rmap.put("RMD_MACHINETYPE",rs.getString("RMD_MACHINETYPE"));
  983. rmap.put("RMD_SN",rs.getString("RMD_SN"));
  984. rmap.put("RMD_REMARK",rs.getString("RMD_REMARK"));
  985. rmap.put("RMD_RECIVETIME",rs.getString("RMD_RECIVETIME"));
  986. rmap.put("RMD_SALEER",rs.getString("RMD_SALEER"));
  987. rmap.put("RMD_CUSTNAME",rs.getString("RMD_CUSTNAME"));
  988. rmap.put("RMD_QTY",rs.getString("RMD_QTY"));
  989. rmap.put("RMD_ASSISTANT",rs.getString("RMD_ASSISTANT"));
  990. rmap.put("RMD_BADNAME",rs.getString("RMD_BADNAME"));
  991. rmap.put("RMD_BADCONFRM",rs.getString("RMD_BADCONFRM"));
  992. rmap.put("RMD_BADTYPE",rs.getString("RMD_BADTYPE"));
  993. rmap.put("RMD_BADREASON",rs.getString("RMD_BADREASON"));
  994. rmap.put("RMD_DEALMAN",rs.getString("RMD_DEALMAN"));
  995. rmap.put("RMD_FINISHTIME",rs.getString("RMD_FINISHTIME"));
  996. rmap.put("RMD_STATUS",rs.getString("RMD_STATUS"));
  997. rmap.put("RMD_ANAREASON",rs.getString("RMD_ANAREASON"));
  998. rmap.put("RMD_REPAIR",rs.getString("RMD_REPAIR"));
  999. rmap.put("RMD_REPAIRKIND",rs.getString("RMD_REPAIRKIND"));
  1000. rmap.put("RMD_DAYS",rs.getString("RMD_DAYS"));
  1001. rmap.put("RMD_MDM",rs.getString("RMD_MDM"));
  1002. rmap.put("RMD_TYPE",rs.getString("RMD_TYPE"));
  1003. rmap.put("RMD_DETNO",rs.getString("RMD_DETNO"));
  1004. return rmap;
  1005. }else{
  1006. oErrMessage = "无对应配置信息";
  1007. rmap.put("oErrMessage",oErrMessage);
  1008. return rmap;
  1009. }
  1010. }
  1011. private Map<Object,Object> GetProdInfo(JSONObject map){
  1012. Map<Object, Object> rmap = new HashMap<Object, Object>();
  1013. String iSN=null;
  1014. String oErrMessage=null;
  1015. if(map.get("iSN")==null){
  1016. oErrMessage = "SN不能为空";
  1017. rmap.put("oErrMessage",oErrMessage);
  1018. return rmap;
  1019. }
  1020. iSN=map.get("iSN").toString();
  1021. String prcode=baseDao.getFieldDataByCondition(Master+".makeserial","ms_prodcode","ms_id=(select max(ms_id) from makeserial where ms_sncode='"+iSN+"')").toString();
  1022. SqlRowList rs=baseDao.queryForRowSet("select pid_item,pid_value from "+Master+".productitem left join "+Master+".productitemdetail on pi_id=pid_piid " +
  1023. "where pi_prodcode='"+prcode+"' and pid_item is not null");
  1024. while(rs.next()){
  1025. rmap.put(rs.getString("pid_item"),rs.getString("pid_value"));
  1026. }
  1027. return rmap;
  1028. /*if(rs.next()){
  1029. }else{
  1030. oErrMessage = "SN未查询到关联信息";
  1031. rmap.put("oErrMessage",oErrMessage);
  1032. return rmap;
  1033. }*/
  1034. }
  1035. private Map<Object,Object> GetMakeInfoByProd(JSONObject map)
  1036. {
  1037. Map<Object, Object> rmap = new HashMap<Object, Object>();
  1038. String iSN=null;
  1039. String oErrMessage=null;
  1040. if(map.get("iSN")==null){
  1041. oErrMessage = "产品编号不能为空";
  1042. rmap.put("oErrMessage",oErrMessage);
  1043. return rmap;
  1044. }
  1045. iSN=map.get("iSN").toString();
  1046. SqlRowList rs=baseDao.queryForRowSet("select pr_remark1,pr_remark2,pr_remark3,pr_remark4,pr_remark5" +
  1047. ",pr_remark6,pr_remark7,pr_remark8 from "+Master+".Makeserial left join "+Master+".product on pr_code=ms_prodcode where ms_sncode='"+iSN+"' order by ms_id desc");
  1048. if(rs.next()){
  1049. rmap.put("oProdmark1",rs.getString("pr_remark1"));
  1050. rmap.put("oProdmark2",rs.getString("pr_remark2"));
  1051. rmap.put("oProdmark3",rs.getString("pr_remark3"));
  1052. rmap.put("oProdmark4",rs.getString("pr_remark4"));
  1053. rmap.put("oProdmark5",rs.getString("pr_remark5"));
  1054. rmap.put("oProdmark6",rs.getString("pr_remark6"));
  1055. rmap.put("oProdmark7",rs.getString("pr_remark7"));
  1056. rmap.put("oProdmark8",rs.getString("pr_remark8"));
  1057. return rmap;
  1058. }else{
  1059. oErrMessage = "产品未查询到关联信息";
  1060. rmap.put("oErrMessage",oErrMessage);
  1061. return rmap;
  1062. }
  1063. }
  1064. public Map<Object,Object> SetStepFinish(String iMakeCode, String iSourceCode, String iSN, String iMPKind, String iResult, String iUserCode, String iErrCode)
  1065. {
  1066. String oErrMessage = null;
  1067. Object StepCode = baseDao.getFieldDataByCondition(Master+".Makeserial", "ms_stepcode", "ms_sncode='" + iSN + "' and ms_makecode='" + iMakeCode + "'");
  1068. String CurrentStep = GetStepCodeBySource(iSourceCode);
  1069. Object BgCode = baseDao.getFieldDataByCondition(Master+".step", "nvl(st_badgroupcode,' ')", "st_code='" + CurrentStep + "'");
  1070. Map<Object, Object> rmap = new HashMap<>();
  1071. switch (iResult)
  1072. {
  1073. case "OK":
  1074. break;
  1075. case "NG":
  1076. if (iErrCode == "")
  1077. {
  1078. oErrMessage = "测试结果为NG时必须传递不良代码";
  1079. rmap.put("oErrMessage",oErrMessage);
  1080. return rmap;
  1081. }
  1082. else
  1083. {
  1084. baseDao.updateByCondition(""+Master+".makebad", "mb_status=-1", "mb_sncode='" + iSN + "' and mb_makecode='" + iMakeCode + "' and mb_stepcode='" + CurrentStep + "' and mb_status=0");
  1085. String[] BadCode = iErrCode.split(",");
  1086. StringBuffer sql=new StringBuffer();
  1087. for (int i = 0; i < BadCode.length; i++)
  1088. {
  1089. if(!baseDao.checkIf("badcode","bc_code='"+ BadCode[i]+"'")){
  1090. oErrMessage = "不良代码"+BadCode[i]+"不存在";
  1091. rmap.put("oErrMessage",oErrMessage);
  1092. return rmap;
  1093. }
  1094. int mb_id = baseDao.getSeqId("makebad_seq");
  1095. sql.setLength(0);
  1096. sql.append("insert into "+Master+".makebad(mb_id,mb_makecode,mb_mscode,mb_sncode,mb_inman,mb_indate,mb_stepcode");
  1097. sql.append(",mb_sourcecode,mb_badcode,mb_badtable,mb_bgcode,mb_soncode,mb_status) select '" + mb_id + "'");
  1098. sql.append(",ma_code,ms_code,ms_sncode,'" + iUserCode + "',sysdate,'" + CurrentStep + "','" + iSourceCode + "','" + BadCode[i] + "','',");
  1099. sql.append("'" + BgCode + "',sp_soncode,'0' from make left join makeSerial on ms_makecode=ma_code left join stepProduct on ");
  1100. sql.append("sp_mothercode=ma_prodcode and sp_stepcode=ms_nextstepcode where ms_sncode='" + iSN + "' and ms_makecode='" + iMakeCode + "'");
  1101. baseDao.execute(sql.toString());
  1102. }
  1103. //将不良的序列号的状态码设为3
  1104. baseDao.execute("update "+Master+".makeserial set ms_status='3' where ms_sncode='" + iSN + "' and ms_makecode='" + iMakeCode + "'");
  1105. }
  1106. break;
  1107. default:
  1108. oErrMessage = "测试结果必须为NG或者OK";
  1109. rmap.put("oErrMessage",oErrMessage);
  1110. return rmap;
  1111. }
  1112. //不良采集为良品是更新
  1113. if (StepCode!=null &&StepCode.toString().equals(CurrentStep) && iResult == "OK")
  1114. {
  1115. Object[] ob = baseDao.getFieldsDataByCondition("makeserial", "ms_status,ms_craftcode,ms_prodcode", "ms_sncode='" + iSN + "' and ms_makecode='" + iMakeCode + "'");
  1116. if (ob!=null)
  1117. {
  1118. String ms_status =ob[0].toString();
  1119. String ms_craftcode= ob[1].toString();
  1120. String ms_prodcode = ob[2].toString();
  1121. if (ms_status == "3")
  1122. {
  1123. String nextstepcode =baseDao.getFieldDataByCondition(Master+".craft left join "+Master+".craftdetail on cr_id=cd_crid ", "cd_nextstepcode", "cr_code='" + ms_craftcode + "' and cr_prodcode='" + ms_prodcode + "' and cd_stepcode='" + CurrentStep + "'").toString();
  1124. baseDao.updateByCondition(Master+".makeserial", "ms_status=1,ms_nextstepcode='" + nextstepcode + "'", "ms_sncode='" + iSN + "' and ms_makecode='" + iMakeCode + "'");
  1125. baseDao.updateByCondition(Master+".makebad", "mb_status=-1", "mb_sncode='" + iSN + "' and mb_makecode='" + iMakeCode + "'");
  1126. }
  1127. }
  1128. }
  1129. return CS_SetFinish(iMakeCode, iSourceCode, iSN, iUserCode, iResult);
  1130. }
  1131. private Map<Object,Object> CS_SetFinish(String iMakeCode, String iSourceCode, String iSN, String iUserCode, String iResult)
  1132. {
  1133. Map<Object, Object> rmap = new HashMap<>();
  1134. String oErrMessage=null;
  1135. List<String> list = new ArrayList<String>();
  1136. list = baseDao.callProcedureWithOut(Master+".CS_SETSTEPRESULT_TOOL", new Object[]{
  1137. String.valueOf(iMakeCode),
  1138. String.valueOf(iSourceCode),
  1139. String.valueOf(iSN),
  1140. String.valueOf(iUserCode),
  1141. String.valueOf(iResult),
  1142. }, new Integer[]{1, 2, 3, 4, 5}, new Integer[]{6});
  1143. oErrMessage = list.get(0);
  1144. rmap.put("oErrMessage",oErrMessage);
  1145. return rmap;
  1146. }
  1147. private String checkAccessKey(String accessKey,String requestId){
  1148. Object accessSecret_O = baseDao.getFieldDataByCondition("APIEMPLOYEE", "AE_SECRET", "AE_KEY='" + accessKey + "'");
  1149. Object AE_MASTER = baseDao.getFieldDataByCondition("APIEMPLOYEE", "AE_MASTER", "AE_KEY='" + accessKey + "'");
  1150. String accessSecret = accessSecret_O == null ? "" : accessSecret_O.toString();
  1151. // 检查KEY是否合理
  1152. if (StringUtils.isEmpty(accessKey) || StringUtils.isEmpty(accessSecret) || AE_MASTER== null || "".equals(AE_MASTER.toString())) {
  1153. ApiResult apiResult = new ApiResult(ErrorMessage.ACCESSKEY_ILLEGAL.getCode(),ErrorMessage.ACCESSKEY_ILLEGAL.getMessage(),requestId);
  1154. throw new ApiSystemException(apiResult);
  1155. }
  1156. return AE_MASTER.toString();
  1157. }
  1158. }