MESHelperServiceImpl.java 47 KB

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