MESHelperServiceImpl.java 77 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032
  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 flexjson.JSON;
  13. import net.sf.json.JSONArray;
  14. import net.sf.json.JSONObject;
  15. import net.sf.json.JsonConfig;
  16. import org.apache.commons.lang.StringUtils;
  17. import org.dom4j.DocumentException;
  18. import org.springframework.beans.factory.annotation.Autowired;
  19. import org.springframework.beans.factory.annotation.Value;
  20. import org.springframework.boot.jackson.JsonObjectDeserializer;
  21. import org.springframework.stereotype.Service;
  22. import org.springframework.web.bind.annotation.RequestBody;
  23. import org.w3c.dom.Document;
  24. import org.w3c.dom.Element;
  25. import org.w3c.dom.Node;
  26. import org.w3c.dom.NodeList;
  27. import org.xml.sax.SAXException;
  28. import sun.awt.TimedWindowEvent;
  29. import java.io.IOException;
  30. import java.sql.Timestamp;
  31. import java.util.*;
  32. import org.dom4j.DocumentHelper;
  33. import javax.xml.parsers.DocumentBuilder;
  34. import javax.xml.parsers.DocumentBuilderFactory;
  35. import javax.xml.parsers.ParserConfigurationException;
  36. import org.xml.sax.InputSource;
  37. import java.io.StringReader;
  38. @Service
  39. public class MESHelperServiceImpl implements MESHelperService {
  40. @Autowired
  41. private BaseDao baseDao;
  42. @Value("${spring.datasource.username}")
  43. private String username;
  44. @Override
  45. public Map<Object,Object> Radium(String data) {
  46. Map<String, Object> map=null;
  47. Map<Object, Object> rmap = new HashMap<Object, Object>();
  48. String oErrMessage="";
  49. String UserName="";
  50. try{
  51. map =BaseUtil.convertJsonToMap(data);
  52. }catch (Exception e){
  53. System.out.printf(e.getMessage()) ;
  54. }
  55. if(map.get("SN")==null){
  56. rmap.put("code",-1);
  57. rmap.put("message","SN号不能为空");
  58. return rmap;
  59. }
  60. if(map.get("MO")==null){
  61. rmap.put("code",-1);
  62. rmap.put("message","工单号不能为空");
  63. return rmap;
  64. }
  65. if(map.get("SpecificationName")==null){
  66. rmap.put("code",-1);
  67. rmap.put("message","工序不能为空");
  68. return rmap;
  69. }
  70. if(map.get("UserName")==null){
  71. rmap.put("code",-1);
  72. rmap.put("message","用户不能为空");
  73. return rmap;
  74. }
  75. String specificationName=map.get("SpecificationName").toString();
  76. String MO=map.get("MO").toString();
  77. Map<Object,Object> map1=BaseUtil.parseFormStoreToMap(map.get("SN").toString());
  78. for (Map.Entry<Object, Object> entry : map1.entrySet()) {
  79. Object key = entry.getKey();
  80. Object value = entry.getValue();
  81. SqlRowList rs=baseDao.queryForRowSet("select 1 from makesnlist where msl_sncode='"+value.toString().toUpperCase()+"'" +
  82. " and msl_makecode='"+MO+"' and msl_Radium=-1");
  83. if(rs.next()){
  84. oErrMessage+="序列号"+value.toString().toUpperCase()+"已镭雕,";
  85. }else {
  86. baseDao.execute("update makesnlist set msl_Radium=-1 where msl_sncode='"+value.toString().toUpperCase()+"' and " +
  87. "msl_makecode='"+MO+"'");
  88. }
  89. //启用过站
  90. if(baseDao.getFieldDataByCondition("configs","data","caller='MESSetting' and code='Radium'").toString().equals("1")){
  91. oErrMessage+=GoMo(value.toString().toUpperCase(),MO, specificationName);
  92. if(oErrMessage.equals("null")){
  93. oErrMessage="";
  94. }else{
  95. rmap.put("code",-1);
  96. rmap.put("message",oErrMessage);
  97. return rmap;
  98. }
  99. oErrMessage+=CheckRoutePassed(value.toString().toUpperCase(),specificationName);
  100. if(oErrMessage.equals("null")){
  101. oErrMessage="";
  102. }else{
  103. rmap.put("code",-1);
  104. rmap.put("message",oErrMessage);
  105. return rmap;
  106. }
  107. oErrMessage+=SetPcbaData(value.toString().toUpperCase(),specificationName,UserName,"OK");
  108. if(oErrMessage.equals("null")){
  109. oErrMessage="";
  110. }else{
  111. rmap.put("code",-1);
  112. rmap.put("message",oErrMessage);
  113. return rmap;
  114. }
  115. }
  116. }
  117. if(oErrMessage.equals("")||oErrMessage==null){
  118. rmap.put("code",0);
  119. rmap.put("message","镭射识别绑定成功");
  120. return rmap;
  121. }else{
  122. rmap.put("code",-1);
  123. rmap.put("message",oErrMessage);
  124. return rmap;
  125. }
  126. }
  127. @Override
  128. public Map<Object,Object> SPI(String data) {
  129. Map<Object, Object> rmap = new HashMap<Object, Object>();
  130. try{
  131. DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
  132. DocumentBuilder builder = factory.newDocumentBuilder();
  133. try {
  134. try{
  135. Element root;
  136. NodeList books;
  137. Document document = builder.parse(new InputSource(new StringReader(data)));
  138. root = document.getDocumentElement();
  139. books = root.getChildNodes();
  140. String Username="";
  141. String Shiftname="";
  142. String MachineNO="";
  143. String LineNO="";
  144. String procedure="";
  145. String Moname="";
  146. String Lotsn="";
  147. String Side="";
  148. String Result="";
  149. String Defect="";
  150. String elementQTY="";
  151. String TestQTY="";
  152. String Time="";
  153. for (Node node = books.item(1).getFirstChild(); node != null; node = node.getNextSibling()) {
  154. {
  155. if (node.getNodeName().equals("UpdAOISPIRecord")) {
  156. NodeList books1 = node.getChildNodes();
  157. for (int i = 0; i < books1.getLength(); i++) {
  158. Node node1 = books1.item(i);
  159. if(!node1.getNodeName().equals("#text")){
  160. switch (node1.getNodeName()){
  161. case "Username":{
  162. Username=node1.getTextContent();
  163. break;
  164. }
  165. case "Shiftname":{
  166. Shiftname=node1.getTextContent();
  167. break;
  168. }
  169. case "MachineNO":{
  170. MachineNO=node1.getTextContent(); break;
  171. }
  172. case "LineNO":{
  173. LineNO=node1.getTextContent();
  174. break;
  175. }
  176. case "procedure":
  177. procedure=node1.getTextContent();
  178. break;
  179. case "Moname":
  180. Moname=node1.getTextContent();
  181. break;
  182. case "Lotsn":
  183. Lotsn=node1.getTextContent();
  184. break;
  185. case "Side":
  186. Side=node1.getTextContent();
  187. break;
  188. case "Result":
  189. Result=node1.getTextContent();
  190. break;
  191. case "Defect":
  192. Defect=node1.getTextContent();
  193. break;
  194. case "elementQTY":
  195. elementQTY=node1.getTextContent();
  196. break;
  197. case "TestQTY":
  198. TestQTY=node1.getTextContent();
  199. break;
  200. case "Time":
  201. Time=node1.getTextContent();
  202. break;
  203. default:
  204. break;
  205. }
  206. //System.out.printf("名称:"+node1.getNodeName());
  207. //System.out.printf("值:"+node1.getTextContent());
  208. //System.out.printf("类型:"+node1.getNodeType());
  209. }
  210. }
  211. }
  212. }
  213. }
  214. Time=Time.substring(0,19).replaceAll("T"," ");
  215. baseDao.execute("insert into devicetestinfo(DTI_ID, DTI_SNCODE, DTI_USERNAME, DTI_MACHINE, DTI_LINECODE, DTI_RESULT, DTI_MAKECODE, DTI_SHIFTNAME, DTI_PROGRAM, DTI_DEFECT, " +
  216. "DTI_TESTQTY, DTI_MACHINETYPE, DTI_TYPE, DTI_TIME, DTI_SOURCECONTENT,dti_elementQTY)values(devicetestinfo_seq.nextval,'"+Lotsn+"','"+Username+"','"+MachineNO+"','"+LineNO+"','"+Result+"'" +
  217. ",'"+Moname+"','"+Shiftname+"','"+procedure+"','"+Defect+"','"+TestQTY+"','SPI','SPI',to_date('"+Time+"','yyyy-mm-dd hh24:mi:ss'),'','"+elementQTY+"')");
  218. }catch (IOException e){
  219. System.out.printf(e.getMessage());
  220. }
  221. }
  222. catch (SAXException e){
  223. }
  224. }catch (ParserConfigurationException e){
  225. }
  226. return rmap;
  227. }
  228. @Override
  229. public String AOI(String Username,String Shiftname, String MachineNO, String LineNO, String procedure,String Moname, String Lotsn,String Side,String Result,String Defect,String elementQTY,String TestQTY,String Type,String Time) {
  230. baseDao.execute("insert into devicetestinfo(DTI_ID, DTI_SNCODE, DTI_USERNAME, DTI_MACHINE, DTI_LINECODE, DTI_RESULT, DTI_MAKECODE, DTI_SHIFTNAME, DTI_PROGRAM, DTI_DEFECT, " +
  231. "DTI_TESTQTY, DTI_MACHINETYPE, DTI_TYPE, DTI_TIME, DTI_SOURCECONTENT,dti_elementQTY)values(devicetestinfo_seq.nextval,'"+Lotsn+"','"+Username+"','"+MachineNO+"','"+LineNO+"','"+Result+"'" +
  232. ",'"+Moname+"','"+Shiftname+"','"+procedure+"','"+Defect+"','"+TestQTY+"','"+Type+"','AOI',to_date('"+Time+"','yyyy-mm-dd hh24:mi:ss'),'','"+elementQTY+"')");
  233. return "";
  234. }
  235. @Override
  236. public String UploadSteel(String SteelMeshCode,String scraperCode, String SteelMeshCount, String scraperCount, String datatime) {
  237. String err = CheckSteel(SteelMeshCode);
  238. //判断钢网编号
  239. if(SteelMeshCode!=null&&!"".equals(SteelMeshCode)){
  240. baseDao.execute("insert into devicetestinfo(DTI_ID, DTI_SNCODE,DTI_TESTQTY, DTI_MACHINETYPE, DTI_TYPE, DTI_TIME, DTI_SOURCECONTENT)values(devicetestinfo_seq.nextval,'"+scraperCode+"','"+scraperCount+"','钢网','钢网',to_date('"+datatime+"','yyyy-mm-dd hh24:mi:ss'),'')");
  241. baseDao.execute("update stencil set st_usecount=nvl(st_usecount,0)+"+scraperCount +" where st_code='"+SteelMeshCode+"'");
  242. }
  243. //判断刮刀编号
  244. if(scraperCode!=null&&!"".equals(scraperCode)){
  245. baseDao.execute("insert into devicetestinfo(DTI_ID, DTI_SNCODE,DTI_TESTQTY, DTI_MACHINETYPE, DTI_TYPE, DTI_TIME, DTI_SOURCECONTENT)values(devicetestinfo_seq.nextval,'"+scraperCode+"','"+scraperCount+"','刮刀','刮刀',to_date('"+datatime+"','yyyy-mm-dd hh24:mi:ss'),'')");
  246. baseDao.execute("update stencil set st_usecount=nvl(st_usecount,0)+"+scraperCount +" where st_code='"+scraperCode+"'");
  247. }
  248. return err;
  249. }
  250. @Override
  251. public String CheckSteel(String SteelMeshCode) {
  252. Map<Object, Object> rmap = new HashMap<Object, Object>();
  253. SqlRowList rs=baseDao.queryForRowSet("select st_kind,nvl(st_usecount,0)st_usecount,nvl(st_maxusecount,0)st_maxusecount from stencil where st_code='"+SteelMeshCode+"'");
  254. if(rs.next()){
  255. String st_usecount=rs.getString("st_usecount");
  256. String st_maxusecount=rs.getString("st_maxusecount");
  257. String st_kind=rs.getString("st_kind");
  258. if(Integer.parseInt(st_usecount)>=Integer.parseInt(st_maxusecount)){
  259. return rs.getString("st_kind")+"已使用"+st_usecount+",超出最大使用次数"+st_maxusecount;
  260. }
  261. }else{
  262. return "编号不存在";
  263. }
  264. return "";
  265. }
  266. @Override
  267. public Map<Object,Object> SetupResultDataInterface(String data) {
  268. Map<Object, Object> rmap = new HashMap<Object, Object>();
  269. JSONObject object = JSONObject.fromObject(data);
  270. JSONObject SetupResultDetail=object.getJSONObject("SetupResultDetail");
  271. if(SetupResultDetail!=null){
  272. String ActionType=SetupResultDetail.get("ActionType").toString();
  273. String MessageSendTime=Time(SetupResultDetail.getString("MessageSendTime"));
  274. String LineName=SetupResultDetail.get("LineName").toString();
  275. String MachineName=SetupResultDetail.get("MachineName").toString();
  276. String OrderNumber=SetupResultDetail.get("OrderNumber").toString();
  277. String DockingStationID=SetupResultDetail.get("DockingStationID").toString();
  278. String Operator=SetupResultDetail.get("Operator").toString();
  279. String TableLocation=SetupResultDetail.get("TableLocation").toString();
  280. String TableId=SetupResultDetail.get("TableId").toString();
  281. String Track=SetupResultDetail.get("Track").toString();
  282. String FeederTypeName=SetupResultDetail.get("FeederTypeName").toString();
  283. String FeederID=SetupResultDetail.get("FeederID").toString();
  284. JSONObject PackagingUnitDetail=SetupResultDetail.getJSONObject("PackagingUnit");
  285. if(PackagingUnitDetail!=null){
  286. String PUID=PackagingUnitDetail.getString("PUID");
  287. String ComponentBarcode=PackagingUnitDetail.getString("ComponentBarcode");
  288. String OriginalQuantity=PackagingUnitDetail.getString("OriginalQuantity");
  289. String Quantity=PackagingUnitDetail.getString("Quantity");
  290. String CreateDate=Time(PackagingUnitDetail.getString("CreateDate"));
  291. String DateCode=PackagingUnitDetail.getString("DateCode");
  292. String BatchId=PackagingUnitDetail.getString("BatchId");
  293. String MsdLevel=PackagingUnitDetail.getString("MsdLevel");
  294. JSONObject LockInfoList=null;
  295. try{
  296. LockInfoList=PackagingUnitDetail.getJSONObject("LockInfoList");
  297. }catch (Exception e){
  298. }
  299. JSONObject SplicedPackagingUnitList=null;
  300. try{
  301. SplicedPackagingUnitList=PackagingUnitDetail.getJSONObject("SplicedPackagingUnitList");
  302. }catch (Exception e){
  303. }
  304. int sr_id=baseDao.getSeqId("SETUPRESULTDETAIL_seq");
  305. baseDao.execute("insert into SETUPRESULTDETAIL(sr_id,ACTIONTYPE,LINENAME,ORDERNUMBER,MACHINENAME," +
  306. "TABLEID,DOCKINGSTATIONID,OPERATOR,TableLocation,FeederTypeName,FeederID,MessageSendTime)values('"+sr_id+"'," +
  307. "'"+ActionType+"','"+LineName+"','"+OrderNumber+"','"+MachineName+"','"+TableId+"','"+DockingStationID+"'," +
  308. "'"+Operator+"','"+TableLocation+"','"+FeederTypeName+"','"+FeederID+"',to_date('"+MessageSendTime+"','yyyy-mm-dd hh24:mi:ss'))");
  309. int pu_id=baseDao.getSeqId("PACKAGINGUNIT_seq");
  310. baseDao.execute("insert into PACKAGINGUNIT(PU_ID,PU_SRID,ComponentBarcode,OriginalQuantity,Quantity,CreateDate," +
  311. "DateCode,BatchId,MsdLevel)values('"+pu_id+"','"+sr_id+"','"+ComponentBarcode+"','"+OriginalQuantity+"','"+Quantity+"',to_date('"+CreateDate+"','yyyy-mm-dd hh24:mi:ss')," +
  312. "'"+DateCode+"','"+BatchId+"','"+MsdLevel+"')");
  313. if(LockInfoList!=null){
  314. JSONArray LockInfoItem=LockInfoList.getJSONArray("LockInfoItem");
  315. for(int i=0;i<LockInfoItem.size();i++){
  316. JSONObject map=LockInfoItem.getJSONObject(i);
  317. String Date=Time(map.getString("Date"));
  318. String Message=map.getString("Message");
  319. String Reason=map.getString("Reason");
  320. String Source=map.getString("Source");
  321. baseDao.execute("insert into LOCKINFOLIST(LF_ID,lf_puid,INDATE,MESSAGE,REASON,SOURCE)" +
  322. "values(LOCKINFOLIST_seq.nextval,'"+pu_id+"',to_date('"+Date+"','yyyy-mm-dd hh24:mi:ss'),'"+Message+"'," +
  323. "'"+Reason+"','"+Source+"')");
  324. }
  325. }
  326. if(SplicedPackagingUnitList!=null){
  327. JSONArray SplicedPackagingUnitItem=SplicedPackagingUnitList.getJSONArray("SplicedPackagingUnitItem");
  328. for(int i=0;i<SplicedPackagingUnitItem.size();i++){
  329. JSONObject map=SplicedPackagingUnitItem.getJSONObject(i);
  330. String UID1=map.getString("PUID");
  331. String ComponentBarcode1=map.getString("ComponentBarcode");
  332. String ComponentBarcodeFragment=map.getString("ComponentBarcodeFragment");
  333. String ComponentName=map.getString("ComponentName");
  334. String OriginalQuantity1=map.getString("OriginalQuantity");
  335. String Quantity1=map.getString("Quantity");
  336. String ManufacturePartNumber=map.getString("ManufacturePartNumber");
  337. String Manufacturer=map.getString("Manufacturer");
  338. String Supplier=map.getString("Supplier");
  339. baseDao.execute("insert into SPLICEDPACKAGING (SP_ID,SP_PUID,PUID,COMPONENTBARCODE,ORIGINALQUANTITY,QUANTITY)" +
  340. "values(SPLICEDPACKAGING_seq.nextval,'"+pu_id+"','"+UID1+"','"+ComponentBarcode1+"','"+OriginalQuantity1+"','"+Quantity1+"')");
  341. }
  342. }
  343. }
  344. rmap.put("code","0");
  345. rmap.put("result","OK");
  346. rmap.put("ServerMessage","MES:贴片机数据记录成功");
  347. }
  348. return rmap;
  349. }
  350. @Override
  351. public Map<Object,Object> StateEventDetail(String data) {
  352. Map<Object, Object> rmap = new HashMap<Object, Object>();
  353. JSONObject object = JSONObject.fromObject(data);
  354. JSONObject StateEventDetail=object.getJSONObject("StateEventDetail");
  355. if(StateEventDetail!=null){
  356. int st_id=baseDao.getSeqId("StateEventDetail_seq");
  357. String MessageSendTime=Time(StateEventDetail.getString("MessageSendTime"));
  358. String CompletionStatusType=StateEventDetail.getString("CompletionStatusType");
  359. String LineFullPath=StateEventDetail.getString("LineFullPath");
  360. String LineName=StateEventDetail.getString("LineName");
  361. String MachineFullPath=StateEventDetail.getString("MachineFullPath");
  362. String MachineName=StateEventDetail.getString("MachineName");
  363. String JobFullPath=StateEventDetail.getString("JobFullPath");
  364. String JobName=StateEventDetail.getString("JobName");
  365. String RecipeFullPath=StateEventDetail.getString("RecipeFullPath");
  366. String RecipeName=StateEventDetail.getString("RecipeName");
  367. String SetupFullPath=StateEventDetail.getString("SetupFullPath");
  368. String SetupName=StateEventDetail.getString("SetupName");
  369. String BoardFullPath=StateEventDetail.getString("BoardFullPath");
  370. String BoardName=StateEventDetail.getString("BoardName");
  371. String OrderNumber=StateEventDetail.getString("OrderNumber");
  372. String ConveyorMode=StateEventDetail.getString("ConveyorMode");
  373. String DownloadMode=StateEventDetail.getString("DownloadMode");
  374. String FactoryLayoutPath=StateEventDetail.getString("FactoryLayoutPath");
  375. String MachineId=StateEventDetail.getString("MachineId");
  376. String MachineType=StateEventDetail.getString("MachineType");
  377. String TypeName=StateEventDetail.getString("TypeName");
  378. String ProcessingAreaCount=StateEventDetail.getString("ProcessingAreaCount");
  379. String StationSoftwareVersion=StateEventDetail.getString("StationSoftwareVersion");
  380. String MonitoringServiceVersion=StateEventDetail.getString("MonitoringServiceVersion");
  381. String ComputerAddress=StateEventDetail.getString("ComputerAddress");
  382. baseDao.execute("insert into StateEventDetail(ST_ID, MESSAGESENDTIME, COMPLETIONSTATUSTYPE, LINEFULLPATH, LINENAME, MACHINEFULLPATH, MACHINENAME, JOBFULLPATH, JOBNAME, RECIPEFULLPATH, RECIPENAME, SETUPFULLPATH, SETUPNAME, BOARDFULLPATH, BOARDNAME, ORDERNUMBER, CONVEYORMODE, DOWNLOADMODE, FACTORYLAYOUTPATH, MACHINEID, MACHINETYPE, TYPENAME, PROCESSINGAREACOUNT, STATIONSOFTWAREVERSION, MONITORINGSERVICEVERSION, COMPUTERADDRESS)" +
  383. "values("+st_id+", to_date('"+MessageSendTime+"','yyyy-mm-dd hh24:mi:ss'), '"+CompletionStatusType+"', '"+LineFullPath+"', '"+LineName+"', '"+MachineFullPath+"', '"+MachineName+"', '"+JobFullPath+"', '"+JobName+"', '"+RecipeFullPath+"', '"+RecipeName+"', '"+SetupFullPath+"', '"+SetupName+"', '"+BoardFullPath+"', '"+BoardName+"', '"+OrderNumber+"', '"+ConveyorMode+"', '"+DownloadMode+"', '"+FactoryLayoutPath+"', '"+MachineId+"', '"+MachineType+"', '"+TypeName+"', '"+ProcessingAreaCount+"', '"+StationSoftwareVersion+"', '"+MonitoringServiceVersion+"', '"+ComputerAddress+"')");
  384. JSONArray ProcessingAreaStateList=StateEventDetail.getJSONArray("ProcessingAreaStateList");
  385. for (int i=0;i<ProcessingAreaStateList.size();i++){
  386. JSONObject map1=ProcessingAreaStateList.getJSONObject(i);
  387. String ProcessingArea=map1.getString("ProcessingArea");
  388. String Conveyor=map1.getString("Conveyor");
  389. String CurrentStateBegin=map1.getString("CurrentStateBegin");
  390. String CurrentStateCode=map1.getString("CurrentStateCode");
  391. String CurrentStateDescription=map1.getString("CurrentStateDescription");
  392. String PreviousStateCode=map1.getString("PreviousStateCode");
  393. String PreviousStateDescription=map1.getString("PreviousStateDescription");
  394. baseDao.execute("insert into ProcessingAreaStateList(RAS_ID, RAS_STID, PROCESSINGAREA, CONVEYOR, CURRENTSTATEBEGIN, CURRENTSTATECODE, CURRENTSTATEDESCRIPTION, PREVIOUSSTATECODE, PREVIOUSSTATEDESCRIPTION)" +
  395. "values(ProcessingAreaStateList_seq.nextval,'"+st_id+"','"+ProcessingArea+"','"+Conveyor+"','"+CurrentStateBegin+"'," +
  396. "'"+CurrentStateCode+"','"+CurrentStateDescription+"','"+PreviousStateCode+"','"+PreviousStateDescription+"')");
  397. }
  398. }
  399. rmap.put("code","0");
  400. rmap.put("result","OK");
  401. rmap.put("ServerMessage","MES:贴片机数据记录成功");
  402. return rmap;
  403. }
  404. @Override
  405. public Map<Object,Object> SendPlaceData(String data) {
  406. Map<Object, Object> rmap = new HashMap<Object, Object>();
  407. JSONObject object = JSONObject.fromObject(data);
  408. JSONObject PlacedDataDetail=object.getJSONObject("PlacedDataDetail");
  409. if(PlacedDataDetail!=null){
  410. int pd_id=baseDao.getSeqId("PlacedDataDetail_seq");
  411. String MESSAGESENDTIME=Time(PlacedDataDetail.getString("MessageSendTime"));
  412. String COMPLETIONSTATUSTYPE=PlacedDataDetail.getString("CompletionStatusType");
  413. String LINEFULLPATH=PlacedDataDetail.getString("LineFullPath");
  414. String MACHINEFULLPATH=PlacedDataDetail.getString("MachineFullPath");
  415. String RECIPEFULLPATH=PlacedDataDetail.getString("RecipeFullPath");
  416. String RECIPENAME=PlacedDataDetail.getString("RecipeName");
  417. String SETUPFULLPATH=PlacedDataDetail.getString("SetupName");
  418. String BOARDFULLPATH=PlacedDataDetail.getString("BoardFullPath");
  419. String FACTORYLAYOUTPATH=PlacedDataDetail.getString("FactoryLayoutPath");
  420. String MACHINEID=PlacedDataDetail.getString("MachineId");
  421. String MACHINETYPE=PlacedDataDetail.getString("MachineType");
  422. String STATIONSOFTWAREVERSION=PlacedDataDetail.getString("StationSoftwareVersion");
  423. String MONITORINGSERVICEVERSION=PlacedDataDetail.getString("MonitoringServiceVersion");
  424. String COMPUTERADDRESS=PlacedDataDetail.getString("ComputerAddress");
  425. baseDao.execute("insert into PlacedDataDetail(pd_id,MessageSendTime,CompletionStatusType,LineFullPath,MachineFullPath,RecipeFullPath," +
  426. "RecipeName,SETUPFULLPATH,BoardFullPath,FactoryLayoutPath,MachineId,MachineType,StationSoftwareVersion,MonitoringServiceVersion," +
  427. "ComputerAddress)values('"+pd_id+"',to_date('"+MESSAGESENDTIME+"','yyyy-mm-dd hh24:mi:ss'),'"+COMPLETIONSTATUSTYPE+"'," +
  428. "'"+LINEFULLPATH+"','"+MACHINEFULLPATH+"','"+RECIPEFULLPATH+"','"+RECIPENAME+"','"+SETUPFULLPATH+"','"+BOARDFULLPATH+"'," +
  429. "'"+FACTORYLAYOUTPATH+"','"+MACHINEID+"','"+MACHINETYPE+"','"+STATIONSOFTWAREVERSION+"','"+MONITORINGSERVICEVERSION+"','"+COMPUTERADDRESS+"')");
  430. JSONArray PanelList=PlacedDataDetail.getJSONArray("PlacedComponentList");
  431. for (int i=0;i<PanelList.size();i++){
  432. JSONObject map1=PanelList.getJSONObject(i);
  433. String TABLELOCATION =map1.getString("TableLocation");
  434. String TRACK=map1.getString("Track");
  435. String DIVISION=map1.getString("Division");
  436. String COMPONENTFULLPATH=map1.getString("ComponentFullPath");
  437. String COMPONENTNAME=map1.getString("ComponentName");
  438. String COMPONENTSHAPEFULLPATH=map1.getString("ComponentShapeFullPath");
  439. String FEEDERCATEGORY=map1.getString("FeederCategory");
  440. String FEEDERTYPENAME=map1.getString("FeederTypeName");
  441. String FEEDERID=map1.getString("FeederID");
  442. String ACCESSTOTAL=map1.getString("AccessTotal");
  443. String PlacedComponents=map1.getString("PlacedComponents");
  444. String REJECTQTY=map1.getString("RejectQty");
  445. String REJECTIDENT=map1.getString("RejectIdent");
  446. String REJECTVACUUM=map1.getString("RejectVacuum");
  447. String TRACKEMPTY=map1.getString("TrackEmpty");
  448. String IDENTERRROR=map1.getString("IdentErrror");
  449. String MATERIALDEFECT=map1.getString("MaterialDefect");
  450. String ABSENCEAFTERPICK=map1.getString("AbsenceAfterPick");
  451. String ABSENCEBEFOREPLACEMENT=map1.getString("AbsenceBeforePlacement");
  452. String TREATMENTERROR=map1.getString("TreatmentError");
  453. baseDao.execute("insert into PlacedComponentList(pc_id,pc_pdid,TABLELOCATION,TRACK,DIVISION,COMPONENTFULLPATH," +
  454. "COMPONENTNAME,COMPONENTSHAPEFULLPATH,FEEDERCATEGORY,FEEDERTYPENAME,FEEDERID,ACCESSTOTAL,PlacedComponents," +
  455. "REJECTQTY,REJECTIDENT,REJECTVACUUM,TRACKEMPTY,IDENTERRROR,MATERIALDEFECT,ABSENCEAFTERPICK,ABSENCEBEFOREPLACEMENT,TREATMENTERROR)" +
  456. "values(PlacedComponentList_seq.nextval,'"+pd_id+"','"+TABLELOCATION+"','"+TRACK+"','"+DIVISION+"','"+COMPONENTFULLPATH+"'" +
  457. ",'"+COMPONENTNAME+"','"+COMPONENTSHAPEFULLPATH+"','"+FEEDERCATEGORY+"','"+FEEDERTYPENAME+"','"+FEEDERID+"'," +
  458. "'"+ACCESSTOTAL+"','"+PlacedComponents+"','"+REJECTQTY+"','"+REJECTIDENT+"','"+REJECTVACUUM+"','"+TRACKEMPTY+"'," +
  459. "'"+IDENTERRROR+"','"+MATERIALDEFECT+"','"+ABSENCEAFTERPICK+"','"+ABSENCEBEFOREPLACEMENT+"','"+TREATMENTERROR+"')");
  460. }
  461. JSONArray PickupErrorList=PlacedDataDetail.getJSONArray("PickupErrorList");
  462. for (int i=0;i<PickupErrorList.size();i++){
  463. JSONObject map1=PickupErrorList.getJSONObject(i);
  464. String GANTRY=map1.getString("Gantry");
  465. String HEAD=map1.getString("Head");
  466. String SEGMENT1=map1.getString("Segment");
  467. String NOZZLE=map1.getString("Nozzle");
  468. String TABLELOCATION=map1.getString("TableLocation");
  469. String TRACK=map1.getString("Track");
  470. String DIVISION=map1.getString("Division");
  471. String TOWER=map1.getString("Tower");
  472. String LEVEL1=map1.getString("Level");
  473. String COMPONENTFULLPATH=map1.getString("ComponentFullPath");
  474. String COMPONENTNAME=map1.getString("ComponentName");
  475. String COMPONENTSHAPEFULLPATH=map1.getString("ComponentShapeFullPath");
  476. String COMPONENTSHAPENAME=map1.getString("ComponentShapeName");
  477. String FEEDERCATEGORY=map1.getString("FeederCategory");
  478. String FEEDERTYPENAME=map1.getString("FeederTypeName");
  479. String FEEDERID=map1.getString("FeederID");
  480. String ERRORTYPE=map1.getString("ErrorType");
  481. String ERRORDESCRIPTION=map1.getString("ErrorDescription");
  482. baseDao.execute("insert into PickupErrorList(pe_id,pe_pdid,Gantry,Head,SEGMENT1,NOZZLE,TABLELOCATION,TRACK,DIVISION,TOWER" +
  483. ",LEVEL1,COMPONENTFULLPATH,COMPONENTNAME,COMPONENTSHAPEFULLPATH,COMPONENTSHAPENAME,FEEDERCATEGORY,FEEDERTYPENAME," +
  484. "FEEDERID,ERRORTYPE,ERRORDESCRIPTION)values(PickupErrorList_seq.nextval,'"+pd_id+"','"+GANTRY+"','"+HEAD+"','"+SEGMENT1+"','"+NOZZLE+"'," +
  485. "'"+TABLELOCATION+"','"+TRACK+"','"+DIVISION+"','"+TOWER+"','"+LEVEL1+"','"+COMPONENTFULLPATH+"','"+COMPONENTNAME+"'," +
  486. "'"+COMPONENTSHAPEFULLPATH+"','"+COMPONENTSHAPENAME+"','"+FEEDERCATEGORY+"','"+FEEDERTYPENAME+"','"+FEEDERID+"','"+ERRORTYPE+"'," +
  487. "'"+ERRORDESCRIPTION+"')");
  488. }
  489. }
  490. rmap.put("code","0");
  491. rmap.put("result","OK");
  492. rmap.put("ServerMessage","MES:贴片机数据记录成功");
  493. return rmap;
  494. }
  495. @Override
  496. public Map<Object,Object> TraceabilityDataInterface(String data) {
  497. Integer td_id=baseDao.getSeqId("TRACEDATA_seq");
  498. Map<Object, Object> rmap = new HashMap<Object, Object>();
  499. JSONObject object = JSONObject.fromObject(data);
  500. JSONObject TraceabilityDataDetail=object.getJSONObject("TraceabilityDataDetail");
  501. if(TraceabilityDataDetail!=null){
  502. String DateBegin=Time(TraceabilityDataDetail.get("DateBegin").toString());
  503. String DateCompleted=Time(TraceabilityDataDetail.get("DateCompleted").toString());
  504. String LineName=TraceabilityDataDetail.get("LineName").toString();
  505. String MachineName=TraceabilityDataDetail.get("MachineName").toString();
  506. String BoardName=TraceabilityDataDetail.get("BoardName").toString();
  507. String MachineID=TraceabilityDataDetail.get("MachineID").toString();
  508. String BoardSide=TraceabilityDataDetail.get("BoardSide").toString();
  509. String OrderNumber=TraceabilityDataDetail.get("OrderNumber").toString();
  510. String PCBBarcode=TraceabilityDataDetail.get("PCBBarcode").toString();
  511. baseDao.execute("insert into TRACEDATA(TD_ID,DateBegin,DateCompleted,LineName,MachineName,BoardName,MachineID,BoardSide,OrderNumber,PCBBarcode,TD_INDATE)" +
  512. "values("+td_id+",to_date('"+DateBegin+"','yyyy-mm-dd hh24:mi:ss'),to_date('"+DateCompleted+"','yyyy-mm-dd hh24:mi:ss')," +
  513. "'"+LineName+"','"+MachineName+"','"+BoardName+"','"+MachineID+"','"+BoardSide+"','"+OrderNumber+"','"+PCBBarcode+"',sysdate)");
  514. JSONObject MaterialTraceabilityDetail=null;
  515. try{
  516. MaterialTraceabilityDetail=TraceabilityDataDetail.getJSONObject("MaterialTraceabilityDetail");
  517. }catch (Exception e){
  518. }
  519. JSONObject MaterialConsumptionDetail=null;
  520. try{
  521. MaterialConsumptionDetail=TraceabilityDataDetail.getJSONObject("MaterialConsumptionDetail");
  522. }catch (Exception e){
  523. }
  524. //上料信息
  525. if(MaterialTraceabilityDetail!=null){
  526. JSONArray PanelList=MaterialTraceabilityDetail.getJSONArray("PanelList");
  527. for (int i=0;i<PanelList.size();i++){
  528. JSONObject map=PanelList.getJSONObject(i);
  529. String PanelName=map.get("PanelName").toString();
  530. JSONArray PackagingUnitRefList=map.getJSONArray("PackagingUnitRefList");
  531. System.out.println(PackagingUnitRefList.size());
  532. if(PackagingUnitRefList!=null){
  533. for (int j=0;j<PackagingUnitRefList.size();j++){
  534. String PlaceRefID="";
  535. JSONObject map1=PackagingUnitRefList.getJSONObject(j);
  536. String PUID=map1.getString("PUID");
  537. String TableLocation=map1.getString("TableLocation");
  538. String Track=map1.getString("Track");
  539. String ComponentBarcode=map1.getString("ComponentBarcode");
  540. String OriginalQuantity=map1.getString("OriginalQuantity");
  541. String Quantity=map1.getString("Quantity");
  542. String CreateDate=Time(map1.getString("CreateDate"));
  543. String DateCode=map1.getString("DateCode");
  544. String Batch2=map1.getString("Batch2");
  545. String MsdLevel=map1.getString("MsdLevel");
  546. String VerifiedDate=Time(map1.getString("VerifiedDate"));
  547. String Operator=map1.getString("Operator");
  548. JSONArray PlaceRefList=map1.getJSONArray("PlaceRefList");
  549. if(PlaceRefList!=null){
  550. for (int k=0;k<PlaceRefList.size();k++){
  551. JSONObject map2=PlaceRefList.getJSONObject(k);
  552. PlaceRefID+=map2.getString("PlaceRefID")+",";
  553. }
  554. }
  555. baseDao.execute("insert into MATERIALTRACE(MT_ID,MT_TDID,PANELNAME,PUID,PlaceRefList,TableLocation,Track,ComponentBarcode,OriginalQuantity,Quantity,CreateDate,DateCode,Batch2,MsdLevel,VerifiedDate,Operator)" +
  556. "values(MATERIALTRACE_seq.nextval,'"+td_id+"','"+PanelName+"','"+PUID+"','"+PlaceRefID+"','"+TableLocation+"','"+Track+"','"+ComponentBarcode+"','"+OriginalQuantity+"','"+Quantity+"',to_date('"+CreateDate+"','yyyy-mm-dd hh24:mi:ss'),'"+DateCode+"','"+Batch2+"'," +
  557. "'"+MsdLevel+"',to_date('"+CreateDate+"','yyyy-mm-dd hh24:mi:ss'),'"+Operator+"')");
  558. }
  559. }
  560. }
  561. }
  562. //扣料信息
  563. if(MaterialConsumptionDetail!=null){
  564. JSONArray ConsumedPackagingUnitList=MaterialConsumptionDetail.getJSONArray("ConsumedPackagingUnitList");
  565. for (int i=0;i<ConsumedPackagingUnitList.size();i++){
  566. JSONObject map1=ConsumedPackagingUnitList.getJSONObject(i);
  567. String PUID=map1.getString("PUID");
  568. String AccessTotal=map1.getString("AccessTotal");
  569. String RejectIdent=map1.getString("RejectIdent");
  570. String RejectVacuum=map1.getString("RejectVacuum");
  571. String TrackEmpty=map1.getString("TrackEmpty");
  572. baseDao.execute("insert into CONSUMEDPACKAGING(cp_id,cp_tdid,puid,AccessTotal,RejectIdent,RejectVacuum" +
  573. ",TrackEmpty) values(CONSUMEDPACKAGING_seq.nextval,'"+td_id+"','"+PUID+"','"+AccessTotal+"','"+RejectIdent+"','"+RejectVacuum+"'," +
  574. "'"+TrackEmpty+"')");
  575. }
  576. }
  577. rmap.put("code","0");
  578. rmap.put("result","OK");
  579. rmap.put("ServerMessage","MES:贴片机数据记录成功");
  580. }
  581. return rmap;
  582. }
  583. public Map<Object,Object> XrayTestDataSave(String data){
  584. Map<Object, Object> rmap = new HashMap<Object, Object>();
  585. Map<String, Object> map=null;
  586. JSONObject object = JSONObject.fromObject(data);
  587. Object object1 = object.get("data");
  588. JSONObject obj = JSONObject.fromObject(object1);
  589. JSONArray object2=obj.getJSONArray("NonconformData");
  590. Object Barcode=obj.get("Barcode");
  591. Object EquipmentEncode=obj.get("EquipmentEncode");
  592. Object ModelType=obj.get("ModelType");
  593. Object CheckNumber=obj.get("CheckNumber");
  594. Object NcmNumber=obj.get("NcmNumber");
  595. Object NonconformNumber=obj.get("NonconformNumber");
  596. Object CheckDate=obj.get("CheckDate");
  597. Object ShiftName=obj.get("ShiftName");
  598. Object LineBody=obj.get("LineBody");
  599. Object Inspector=obj.get("Inspector");
  600. int XT_ID = baseDao.getSeqId("xraytest_seq");
  601. baseDao.execute("insert into xraytest(XT_ID, BARCODE, EQUIPMENTENCODE, MODELTYPE, CHECKNUMBER, NCMNUMBER, NONCONFORMNUMBER, CHECKDATE, SHIFTNAME, LINEBODY, INSPECTOR)" +
  602. "values("+XT_ID+",'"+Barcode+"','"+EquipmentEncode+"','"+ModelType+"','"+CheckNumber+"','"+NcmNumber+"','"+NonconformNumber+"',to_date('"+CheckDate+"','yyyy-mm-dd hh24:mi:ss')" +
  603. ",'"+ShiftName+"','"+LineBody+"','"+Inspector+"')");
  604. for (int i=0;i<object2.size();i++){
  605. JSONObject map1=object2.getJSONObject(i);
  606. String NonconformANo=map1.getString("NonconformANo");
  607. String NonconformDescription=map1.getString("NonconformDescription");
  608. baseDao.execute("insert into XrayTestdetail(xtd_xtid,xtd_id,NONCONFORMANO, NONCONFORMDESCRIPTION)" +
  609. "values("+XT_ID+",XrayTestdetail_seq.nextval,'"+NonconformANo+"','"+NonconformDescription+"')");
  610. }
  611. rmap.put("code","0");
  612. rmap.put("result","OK");
  613. rmap.put("ServerMessage","MES:检查数据上传成功!");
  614. return rmap;
  615. }
  616. public String Time(String time){
  617. return time.replaceAll("T"," ").substring(0,19);
  618. }
  619. @Override
  620. public Map<Object,Object> Weigh(String data) {
  621. Map<Object, Object> rmap = new HashMap<Object, Object>();
  622. String oErrMessage="";
  623. String lotSN="";
  624. String specificationName="";
  625. String weight="";
  626. String moName="";
  627. String workcenterName="";
  628. Map<String, Object> map=null;
  629. try{
  630. map =BaseUtil.convertJsonToMap(data);
  631. }catch (Exception e){
  632. System.out.printf(e.getMessage()) ;
  633. }
  634. if(map.get("lotSN")==null){
  635. oErrMessage = "SN不能为空";
  636. rmap.put("oErrMessage",oErrMessage);
  637. return rmap;
  638. }
  639. if(map.get("lotSN")==null){
  640. oErrMessage = "SN不能为空";
  641. rmap.put("oErrMessage",oErrMessage);
  642. return rmap;
  643. }
  644. if(map.get("specificationName")==null){
  645. oErrMessage = "工序不能为空";
  646. rmap.put("oErrMessage",oErrMessage);
  647. return rmap;
  648. }
  649. if(map.get("weight")==null){
  650. oErrMessage = "重量不能为空";
  651. rmap.put("oErrMessage",oErrMessage);
  652. return rmap;
  653. }
  654. lotSN=map.get("lotSN").toString();
  655. SqlRowList rs=baseDao.queryForRowSet("select ms_sncode from makeserial where ms_imei1='"+lotSN+"' or ms_imei2='"+lotSN+"' or ms_imei3='"+lotSN+"'");
  656. if(rs.next()){
  657. lotSN=rs.getString("ms_sncode");
  658. }else{
  659. rs=baseDao.queryForRowSet("select mil_sncode from makeimeilist where mil_imei1='"+lotSN+"' or mil_imei2='"+lotSN+"' or mil_imei3='"+lotSN+"'");
  660. if(rs.next()){
  661. lotSN=rs.getString("mil_sncode");
  662. }
  663. }
  664. specificationName=map.get("specificationName").toString();
  665. weight=map.get("weight").toString().replaceAll("KG","");
  666. oErrMessage=CheckRoutePassed(lotSN,specificationName);
  667. if(oErrMessage!=null){
  668. rmap.put("code",-1);
  669. rmap.put("message",oErrMessage);
  670. Map<String, String> rmap1 = new HashMap<String, String>();
  671. rmap1.put("minWeight","");
  672. rmap1.put("maxWeightc","");
  673. rmap1.put("machineModel","");
  674. rmap.put("dataInfo",rmap1);
  675. return rmap;
  676. }
  677. Object[] obj = baseDao.getFieldsDataByCondition("makeserial left join product on pr_code=ms_prodcode","pr_colorboxminw,pr_colorboxmaxw","ms_id =(select max(ms_id) from makeserial where ms_sncode='"+lotSN+"')");
  678. if(obj[0]!=null&&obj[1]!=null){
  679. //不在设置的重量范围内
  680. if(Double.parseDouble(weight)<Double.parseDouble(obj[0].toString())||Double.parseDouble(weight)>Double.parseDouble(obj[1].toString())){
  681. rmap.put("code",-1);
  682. rmap.put("message","SN["+lotSN+"]重量为"+weight+",不符合重量范围"+obj[0]+"-"+obj[1]);
  683. Map<String, String> rmap1 = new HashMap<String, String>();
  684. rmap1.put("minWeight",obj[0].toString());
  685. rmap1.put("maxWeight",obj[1].toString());
  686. rmap1.put("machineModel","");
  687. rmap.put("dataInfo",rmap1);
  688. return rmap;
  689. }
  690. Object oErr=SetPcbaData(lotSN,specificationName,specificationName,"OK");
  691. if(oErr==null){
  692. rmap.put("code",0);
  693. rmap.put("message","SN["+lotSN+"]重量为"+weight+",符合重量范围"+obj[0]+"-"+obj[1]+",称重通过");
  694. Object ms_id=baseDao.getFieldDataByCondition("makeserial","max(ms_id)","ms_sncode='"+lotSN+"'");
  695. baseDao.execute("update makeserial set ms_grossw ='"+weight+"' where ms_id="+ms_id);
  696. }else{
  697. rmap.put("code",-1);
  698. rmap.put("message",oErr);
  699. }
  700. Map<String, String> rmap1 = new HashMap<String, String>();
  701. rmap1.put("minWeight",obj[0].toString());
  702. rmap1.put("maxWeight",obj[1].toString());
  703. rmap1.put("machineModel","");
  704. rmap.put("dataInfo",rmap1);
  705. return rmap;
  706. }
  707. return rmap;
  708. }
  709. @Override
  710. public Map<Object,Object> DLLMain(String accessKey, String requestId, String data) {
  711. String AE_MASTER = "N_MES";
  712. SpObserver.putSp(AE_MASTER);
  713. Map<Object, Object> map = BaseUtil.parseFormStoreToMap(data);
  714. //解析map
  715. if(!StringUtil.hasText(map.get("type"))){
  716. throw new ApiSystemException(new ApiResult(ErrorMessage.BUSINESS_TYPENULL,requestId));
  717. }
  718. if(!StringUtil.hasText(map.get("detail"))){
  719. throw new ApiSystemException(new ApiResult(ErrorMessage.BUSINESS_DATAILLEGAL,requestId));
  720. }
  721. String type = map.get("type").toString();
  722. JSONObject json = JSONObject.fromObject(map.get("detail"));
  723. HelperType helperType = HelperType.getTypeByCode(type);
  724. if(null == helperType){
  725. throw new ApiSystemException(new ApiResult(ErrorMessage.BUSINESS_TYPEILLEGAL,requestId));
  726. }
  727. int err = 0;
  728. //返回值
  729. Map<Object, Object> remap = new HashMap<Object, Object>();
  730. switch(helperType){
  731. case CheckRoutePassed:
  732. remap = CheckRoutePassed(json);
  733. break;
  734. case CheckUserAndResourcePassed:
  735. remap = CheckUserAndResourcePassed(json);
  736. break;
  737. case GetAddressRangeByMO:
  738. remap = GetAddressRangeByMO(json);
  739. break;
  740. case GetMEIOrNetCodeRange:
  741. remap = GetMEIOrNetCodeRange(json);
  742. break;
  743. case GetRcardMOInfo:
  744. remap = GetRcardMOInfo(json);
  745. break;
  746. case GetMobileAllInfo:
  747. remap = GetMobileAllInfo(json);
  748. break;
  749. case SetAddressInfo:
  750. remap = SetAddressInfo(json);
  751. break;
  752. case GetMaster:
  753. remap = GetMaster(json);
  754. break;
  755. case SetMobileData:
  756. remap = SetMobileData(json);
  757. break;
  758. case SetIMEIInfo:
  759. remap = SetIMEIInfo(json);
  760. break;
  761. case SetTestDetail:
  762. remap = SetTestDetail(json);
  763. break;
  764. case SetPcbaData:
  765. remap = SetPcbaData(json);
  766. break;
  767. case GetInfoByMaterial:
  768. remap = GetInfoByMaterial(json);
  769. break;
  770. case GoMo:
  771. remap = GoMo(json);
  772. break;
  773. case GetMakeInfoBySN:
  774. remap = GetMakeInfoBySN(json);
  775. break;
  776. default:
  777. err = -1;
  778. break;
  779. }
  780. if(err == -1){
  781. throw new ApiSystemException(new ApiResult(ErrorMessage.BUSINESS_TYPEILLEGAL,requestId));
  782. }
  783. SpObserver.putSp(username);
  784. return remap;
  785. }
  786. private Map<Object,Object> GoMo(JSONObject map){
  787. Map<Object, Object> rmap = new HashMap<Object, Object>();
  788. String iSN=null;
  789. String iResCode=null;
  790. String iMo=null;
  791. String oErrMessage=null;
  792. Integer code=0;
  793. if(map.get("iMo")==null){
  794. oErrMessage = "工单号不能为空";
  795. code=-1;
  796. rmap.put("oErrMessage",oErrMessage);
  797. return rmap;
  798. }
  799. if(map.get("iResCode")==null){
  800. oErrMessage = "岗位资源不能为空";
  801. code=-1;
  802. rmap.put("oErrMessage",oErrMessage);
  803. return rmap;
  804. }
  805. if(map.get("iSN")==null){
  806. oErrMessage = "SN不能为空";
  807. code=-1;
  808. rmap.put("oErrMessage",oErrMessage);
  809. return rmap;
  810. }
  811. iSN=map.get("iSN").toString();
  812. iResCode=map.get("iResCode").toString();
  813. iMo=map.get("iMo").toString();
  814. List<String> list = new ArrayList<String>();
  815. list = baseDao.callProcedureWithOut("CS_CHECKSTEPSNANDMACODE", new Object[]{
  816. String.valueOf(iMo),
  817. String.valueOf(iResCode),
  818. String.valueOf(iSN),
  819. String.valueOf("")
  820. }, new Integer[]{1, 2, 3, 4}, new Integer[]{5, 6, 7});
  821. oErrMessage=list.get(2);
  822. 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<>' '))");
  823. String ms_status = "";
  824. String ms_stepcode = "";
  825. String ms_nextstepcode = "";
  826. if(rs.next()){
  827. ms_status= rs.getString("ms_status");
  828. ms_stepcode=rs.getString("ms_stepcode");
  829. ms_nextstepcode=rs.getString("ms_nextstepcode");
  830. }
  831. String stepcode = GetStepCodeBySource(iResCode);
  832. if (oErrMessage == null || (ms_status == "3" && ms_stepcode == stepcode))
  833. {
  834. if (ms_status == "3")
  835. {
  836. oErrMessage = null;
  837. code=0;
  838. }
  839. }else{
  840. code=-1;
  841. }
  842. rmap.put("code",code);
  843. rmap.put("oErrMessage",oErrMessage);
  844. return rmap;
  845. }
  846. private String GoMo(String iSN,String iMo,String iResCode){
  847. Map<Object, Object> rmap = new HashMap<Object, Object>();
  848. String oErrMessage=null;
  849. List<String> list = new ArrayList<String>();
  850. list = baseDao.callProcedureWithOut("CS_CHECKSTEPSNANDMACODE", new Object[]{
  851. String.valueOf(iMo),
  852. String.valueOf(iResCode),
  853. String.valueOf(iSN),
  854. String.valueOf("")
  855. }, new Integer[]{1, 2, 3, 4}, new Integer[]{5, 6, 7});
  856. oErrMessage=list.get(2);
  857. 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<>' '))");
  858. String ms_status = "";
  859. String ms_stepcode = "";
  860. String ms_nextstepcode = "";
  861. if(rs.next()){
  862. ms_status= rs.getString("ms_status");
  863. ms_stepcode=rs.getString("ms_stepcode");
  864. ms_nextstepcode=rs.getString("ms_nextstepcode");
  865. }
  866. String stepcode = GetStepCodeBySource(iResCode);
  867. if ( oErrMessage == null || (ms_status == "3" && ms_stepcode == stepcode))
  868. {
  869. if (ms_status == "3")
  870. {
  871. oErrMessage = null;
  872. }
  873. }
  874. return oErrMessage;
  875. }
  876. private Map<Object,Object> GetInfoByMaterial(JSONObject map){
  877. Map<Object, Object> rmap = new HashMap<Object, Object>();
  878. String iPCBA=null;
  879. String oErrMessage=null;
  880. if(map.get("iPCBA")==null){
  881. oErrMessage = "主板SN不能为空";
  882. rmap.put("oErrMessage",oErrMessage);
  883. return rmap;
  884. }
  885. iPCBA=map.get("iPCBA").toString();
  886. 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");
  887. if(rs.next()){
  888. if(!rs.getString("ms_id").equals("0")){
  889. 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")+"'");
  890. if (rs.next()){
  891. rmap.put("oSN",rs.getString("ms_sncode"));
  892. rmap.put("oBIOS",rs.getString("ma_bios"));
  893. rmap.put("oEC",rs.getString("ma_ec"));
  894. rmap.put("oHardWare",rs.getString("ma_hardware"));
  895. }
  896. }else{
  897. oErrMessage = "主板SN未查询到关联信息";
  898. rmap.put("oErrMessage",oErrMessage);
  899. return rmap;
  900. }
  901. }
  902. return rmap;
  903. }
  904. private Map<Object,Object> CheckRoutePassed(JSONObject map){
  905. //实际业务数据
  906. Map<Object, Object> rmap = new HashMap<>();
  907. String iSN=map.get("iSN").toString();
  908. String iResCode=map.get("iResCode").toString();
  909. String oErrMessage="";
  910. Integer code=0;
  911. if (iSN ==null)
  912. {
  913. oErrMessage = "SN不能为空";
  914. code=-1;
  915. }
  916. List<String> list = new ArrayList<String>();
  917. list = baseDao.callProcedureWithOut("CS_CHECKSTEPSNANDMACODE", new Object[]{
  918. String.valueOf(""),
  919. String.valueOf(iResCode),
  920. String.valueOf(iSN),
  921. String.valueOf("")
  922. }, new Integer[]{1, 2, 3, 4}, new Integer[]{5, 6, 7});
  923. oErrMessage=list.get(2);
  924. if(oErrMessage!=null){
  925. rmap.put("code",-1);
  926. rmap.put("oErrMessage",oErrMessage);
  927. return rmap;
  928. }
  929. 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<>' '))");
  930. String ms_status = "";
  931. String ms_stepcode = "";
  932. String ms_nextstepcode = "";
  933. if(rs.next()){
  934. ms_status= rs.getString("ms_status");
  935. ms_stepcode=rs.getString("ms_stepcode");
  936. ms_nextstepcode=rs.getString("ms_nextstepcode");
  937. }
  938. String stepcode = GetStepCodeBySource(iResCode);
  939. if (ms_nextstepcode != "" && !ms_nextstepcode.equals(stepcode))
  940. {
  941. oErrMessage = "当前序列号下一工序" + ms_nextstepcode;
  942. code=-1;
  943. }
  944. rmap.put("code",code);
  945. rmap.put("oErrMessage",oErrMessage);
  946. return rmap;
  947. }
  948. @Override
  949. public Map<Object,Object> CheckRoutePassed(String data){
  950. //实际业务数据
  951. Map<Object, Object> rmap = new HashMap<>();
  952. Map<String, Object> map=null;
  953. try{
  954. map =BaseUtil.convertJsonToMap(data);
  955. }catch (Exception e){
  956. rmap.put("code",-1);
  957. rmap.put("message",e.getMessage());
  958. System.out.printf(e.getMessage()) ;
  959. return rmap;
  960. }
  961. String iSN=map.get("iSN").toString();
  962. SqlRowList rs=baseDao.queryForRowSet("select ms_sncode from makeserial where ms_imei1='"+iSN+"' or ms_imei2='"+iSN+"' or ms_imei3='"+iSN+"'");
  963. if(rs.next()){
  964. iSN=rs.getString("ms_sncode");
  965. }else{
  966. rs=baseDao.queryForRowSet("select mil_sncode from makeimeilist where mil_imei1='"+iSN+"' or mil_imei2='"+iSN+"' or mil_imei3='"+iSN+"'");
  967. if(rs.next()){
  968. iSN=rs.getString("mil_sncode");
  969. }
  970. }
  971. String iResCode=map.get("iResCode").toString();
  972. String oErrMessage="";
  973. Integer code=0;
  974. if (iSN ==null)
  975. {
  976. oErrMessage = "SN不能为空";
  977. code=-1;
  978. }
  979. List<String> list = new ArrayList<String>();
  980. list = baseDao.callProcedureWithOut("CS_CHECKSTEPSNANDMACODE", new Object[]{
  981. String.valueOf(""),
  982. String.valueOf(iResCode),
  983. String.valueOf(iSN),
  984. String.valueOf("")
  985. }, new Integer[]{1, 2, 3, 4}, new Integer[]{5, 6, 7});
  986. oErrMessage=list.get(2);
  987. if(oErrMessage!=null){
  988. rmap.put("code",-1);
  989. rmap.put("oErrMessage",oErrMessage);
  990. return rmap;
  991. }
  992. 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<>' '))");
  993. String ms_status = "";
  994. String ms_stepcode = "";
  995. String ms_nextstepcode = "";
  996. if(rs.next()){
  997. ms_status= rs.getString("ms_status");
  998. ms_stepcode=rs.getString("ms_stepcode");
  999. ms_nextstepcode=rs.getString("ms_nextstepcode");
  1000. }
  1001. String stepcode = GetStepCodeBySource(iResCode);
  1002. if (ms_nextstepcode != "" && !ms_nextstepcode.equals(stepcode))
  1003. {
  1004. oErrMessage = "当前序列号下一工序" + ms_nextstepcode;
  1005. code=-1;
  1006. }
  1007. rmap.put("code",code);
  1008. rmap.put("oErrMessage",oErrMessage);
  1009. return rmap;
  1010. }
  1011. public String CheckRoutePassed(String iSN,String iResCode){
  1012. //实际业务数据
  1013. Map<Object, Object> rmap = new HashMap<>();
  1014. String oErrMessage;
  1015. Integer code=0;
  1016. if (iSN ==null)
  1017. {
  1018. oErrMessage = "SN不能为空";
  1019. code=-1;
  1020. }
  1021. List<String> list = new ArrayList<String>();
  1022. list = baseDao.callProcedureWithOut("CS_CHECKSTEPSNANDMACODE", new Object[]{
  1023. String.valueOf(""),
  1024. String.valueOf(iResCode),
  1025. String.valueOf(iSN),
  1026. String.valueOf("")
  1027. }, new Integer[]{1, 2, 3, 4}, new Integer[]{5, 6, 7});
  1028. oErrMessage=list.get(2);
  1029. if(oErrMessage!=null){
  1030. return oErrMessage;
  1031. }
  1032. 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<>' '))");
  1033. String ms_status = "";
  1034. String ms_stepcode = "";
  1035. String ms_nextstepcode = "";
  1036. if(rs.next()){
  1037. ms_status= rs.getString("ms_status");
  1038. ms_stepcode=rs.getString("ms_stepcode");
  1039. ms_nextstepcode=rs.getString("ms_nextstepcode");
  1040. }
  1041. String stepcode = GetStepCodeBySource(iResCode);
  1042. if (ms_nextstepcode != "" && !ms_nextstepcode.equals(stepcode))
  1043. {
  1044. oErrMessage = "当前序列号"+iSN+"下一工序" + ms_nextstepcode;
  1045. }
  1046. return oErrMessage;
  1047. }
  1048. private Map<Object,Object> CheckUserAndResourcePassed(JSONObject map){
  1049. //实际业务数据
  1050. Map<Object, Object> rmap = new HashMap<>();
  1051. String oErrMessage = null;
  1052. if (map.get("iUserCode") == null || map.get("iResCode") == null || map.get("iPassWord") == null)
  1053. {
  1054. oErrMessage = "用户名,密码,岗位资源必须填写";
  1055. rmap.put("oErrMessage",oErrMessage);
  1056. return rmap;
  1057. }
  1058. String iUserCode=map.get("iUserCode").toString();
  1059. String iPassWord=map.get("iPassWord").toString();
  1060. String iResCode=map.get("iResCode").toString();
  1061. if (CheckUserLogin(iUserCode, iPassWord))
  1062. {
  1063. String SQL = "select em_code,em_type,em_name from employee where em_code=? ";
  1064. SqlRowList rs = baseDao.queryForRowSet(SQL, iUserCode);
  1065. if (rs.next())
  1066. {
  1067. String em_name = rs.getString("em_name");
  1068. String em_type = rs.getString("em_type");
  1069. if (iResCode ==null)
  1070. {
  1071. oErrMessage = "岗位资源不允许为空";
  1072. rmap.put("oErrMessage",oErrMessage);
  1073. return rmap;
  1074. }
  1075. if (em_type.equals("admin"))
  1076. {
  1077. if (!baseDao.checkIf("Source", "sc_code='" + iResCode + "' and sc_statuscode='AUDITED'"))
  1078. {
  1079. oErrMessage = "岗位资源编号错误或者未审核!";
  1080. }
  1081. }
  1082. else
  1083. {
  1084. SqlRowList rs1=baseDao.queryForRowSet("select ur_resourcecode from cs$empgroup left join cs$userresource on ur_groupcode=eg_groupcode left join source on ur_resourcecode=sc_code where eg_emcode = '"+ iUserCode + "' and sc_statuscode='AUDITED'");
  1085. //如果存在该编号
  1086. if (rs1.next())
  1087. {
  1088. //判断如果多个岗位资源存在,用户输入的只要在其中就行
  1089. while (rs.next())
  1090. {
  1091. if (!rs.getString("ur_resourcecode").equals("iResCode")){
  1092. oErrMessage = "用户不处于当前资源所属分组!";
  1093. }else
  1094. {
  1095. oErrMessage=null;
  1096. continue;
  1097. }
  1098. }
  1099. }
  1100. else
  1101. oErrMessage = "岗位资源编号错误或者未审核!";
  1102. }
  1103. }
  1104. else
  1105. oErrMessage = "用户不存在!";
  1106. }else{
  1107. oErrMessage = "用户名密码不正确!";
  1108. }
  1109. rmap.put("oErrMessage",oErrMessage);
  1110. return rmap;
  1111. }
  1112. @Override
  1113. public Map<Object,Object> CheckUserAndResourcePassed(String data){
  1114. //实际业务数据
  1115. Map<Object, Object> rmap = new HashMap<>();
  1116. Map<String, Object> map=null;
  1117. Integer code=0;
  1118. try{
  1119. map =BaseUtil.convertJsonToMap(data);
  1120. }catch (Exception e){
  1121. rmap.put("code",-1);
  1122. rmap.put("message",e.getMessage());
  1123. System.out.printf(e.getMessage()) ;
  1124. return rmap;
  1125. }
  1126. String oErrMessage = null;
  1127. if (map.get("iUserCode") == null || map.get("iResCode") == null || map.get("iPassWord") == null)
  1128. {
  1129. oErrMessage = "用户名,密码,岗位资源必须填写";
  1130. rmap.put("oErrMessage",oErrMessage);
  1131. return rmap;
  1132. }
  1133. String iUserCode=map.get("iUserCode").toString();
  1134. String iPassWord=map.get("iPassWord").toString();
  1135. String iResCode=map.get("iResCode").toString();
  1136. if (CheckUserLogin(iUserCode, iPassWord))
  1137. {
  1138. String SQL = "select em_code,em_type,em_name from employee where em_code=? ";
  1139. SqlRowList rs = baseDao.queryForRowSet(SQL, iUserCode);
  1140. if (rs.next())
  1141. {
  1142. String em_name = rs.getString("em_name");
  1143. String em_type = rs.getString("em_type");
  1144. if (iResCode ==null)
  1145. {
  1146. code=-1;
  1147. oErrMessage = "岗位资源不允许为空";
  1148. rmap.put("oErrMessage",oErrMessage);
  1149. return rmap;
  1150. }
  1151. if (em_type.equals("admin"))
  1152. {
  1153. if (!baseDao.checkIf("Source", "sc_code='" + iResCode + "' and sc_statuscode='AUDITED'"))
  1154. {
  1155. code=-1;
  1156. oErrMessage = "岗位资源编号错误或者未审核!";
  1157. }
  1158. }
  1159. else
  1160. {
  1161. SqlRowList rs1=baseDao.queryForRowSet("select ur_resourcecode from cs$empgroup left join cs$userresource on ur_groupcode=eg_groupcode left join source on ur_resourcecode=sc_code where eg_emcode = '"+ iUserCode + "' and sc_statuscode='AUDITED'");
  1162. //如果存在该编号
  1163. if (rs1.next())
  1164. {
  1165. //判断如果多个岗位资源存在,用户输入的只要在其中就行
  1166. while (rs.next())
  1167. {
  1168. if (!rs.getString("ur_resourcecode").equals("iResCode")){
  1169. code=-1;
  1170. oErrMessage = "用户不处于当前资源所属分组!";
  1171. }else
  1172. {
  1173. oErrMessage=null;
  1174. continue;
  1175. }
  1176. }
  1177. }
  1178. else{
  1179. code=-1;
  1180. oErrMessage = "岗位资源编号错误或者未审核!";
  1181. }
  1182. }
  1183. }
  1184. else{
  1185. code=-1;
  1186. oErrMessage = "用户不存在!";
  1187. }
  1188. }else{
  1189. code=-1;
  1190. oErrMessage = "用户名密码不正确!";
  1191. }
  1192. rmap.put("code",code);
  1193. rmap.put("oErrMessage",oErrMessage);
  1194. return rmap;
  1195. }
  1196. private Map<Object,Object> GetAddressRangeByMO(JSONObject map){
  1197. //实际业务数据
  1198. Map<Object, Object> rmap = new HashMap<>();
  1199. String iSN="";
  1200. String oErrMessage = null;
  1201. String oWIFI = "";
  1202. String oBT = "";
  1203. String oCode1 = "";
  1204. String oCode2 = "";
  1205. String oCode3 = "";
  1206. if(map.get("iSN")==null){
  1207. oErrMessage = "SN不能为空";
  1208. rmap.put("oErrMessage",oErrMessage);
  1209. return rmap;
  1210. }
  1211. iSN=map.get("iSN").toString();
  1212. //判断工单是否归属
  1213. JSONObject map3=new JSONObject();
  1214. map3.put("iSN",iSN);
  1215. Map<Object, Object> map2=GetRcardMOInfo(map3);
  1216. if(map2.get("oErrMessage")!=null){
  1217. oErrMessage=map2.get("oErrMessage").toString();
  1218. rmap.put("oErrMessage",oErrMessage);
  1219. return rmap;
  1220. }
  1221. List<String> list = new ArrayList<String>();
  1222. list = baseDao.callProcedureWithOut("CS_GETADDRESSBYMAKECODE", new Object[]{
  1223. String.valueOf(iSN),
  1224. String.valueOf(map2.get("oMoCode").toString()),
  1225. }, new Integer[]{1,2}, new Integer[]{3,4,5,6,7,8});
  1226. oWIFI = list.get(0);
  1227. oBT = list.get(1);
  1228. oCode1 = list.get(2);
  1229. oCode2 = list.get(3);
  1230. oCode3 = list.get(4);
  1231. oErrMessage= list.get(5);
  1232. if (oErrMessage == "" || oErrMessage == null || oErrMessage == "null"){
  1233. rmap.put("oWIFI",oWIFI);
  1234. rmap.put("oBT",oBT);
  1235. rmap.put("oCode1",oCode1);
  1236. rmap.put("oCode2",oCode2);
  1237. rmap.put("oCode3",oCode3);
  1238. }
  1239. else
  1240. rmap.put("oErrMessage",oErrMessage);
  1241. return rmap;
  1242. }
  1243. private Map<Object,Object> GetMEIOrNetCodeRange(JSONObject map){
  1244. //实际业务数据
  1245. Map<Object, Object> rmap = new HashMap<>();
  1246. String iSN="";
  1247. String oErrMessage = null;
  1248. String oIMEI1 = "";
  1249. String oIMEI2 = "";
  1250. String oMEID = "";
  1251. String oNetCode = "";
  1252. String oPSN = "";
  1253. String oID1 = "";
  1254. String oID2 = "";
  1255. String oID3 = "";
  1256. String oID4 = "";
  1257. String oID5 = "";
  1258. if(map.get("iSN")==null){
  1259. oErrMessage = "SN不能为空";
  1260. rmap.put("oErrMessage",oErrMessage);
  1261. return rmap;
  1262. }
  1263. if(map.get("iIMEI1")!=null){
  1264. oIMEI1=map.get("iIMEI1").toString();
  1265. }
  1266. if(map.get("iNetCode")!=null){
  1267. oNetCode=map.get("iNetCode").toString();
  1268. }
  1269. iSN=map.get("iSN").toString();
  1270. List<String> list = new ArrayList<String>();
  1271. list = baseDao.callProcedureWithOut("CS_GETIMEIORNETCODERANGE", new Object[]{
  1272. String.valueOf(iSN),
  1273. String.valueOf(""),
  1274. String.valueOf(oIMEI1),
  1275. String.valueOf(oNetCode),
  1276. }, new Integer[]{1,2,3,4}, new Integer[]{5,6,7,8,9,10,11,12,13,14});
  1277. oIMEI1 = list.get(0);
  1278. oIMEI2 = list.get(1);
  1279. oMEID = list.get(2);
  1280. oNetCode = list.get(3);
  1281. oID1 = list.get(4);
  1282. oID2 = list.get(5);
  1283. oID3 = list.get(6);
  1284. oID4 = list.get(7);
  1285. oID5 = list.get(8);
  1286. oErrMessage= list.get(9);
  1287. if (oErrMessage == "" || oErrMessage == null || oErrMessage == "null"){
  1288. rmap.put("oIMEI1",oIMEI1);
  1289. rmap.put("oIMEI2",oIMEI2);
  1290. rmap.put("oMEID",oMEID);
  1291. rmap.put("oNetCode",oNetCode);
  1292. rmap.put("oPSN",oPSN);
  1293. rmap.put("oID1",oID1);
  1294. rmap.put("oID2",oID2);
  1295. rmap.put("oID3",oID3);
  1296. rmap.put("oID4",oID4);
  1297. rmap.put("oID5",oID5);
  1298. }
  1299. else
  1300. rmap.put("oErrMessage",oErrMessage);
  1301. return rmap;
  1302. }
  1303. private Map<Object,Object> GetRcardMOInfo(JSONObject map){
  1304. //实际业务数据
  1305. Map<Object, Object> rmap = new HashMap<>();
  1306. //取MakeProcess表中的执行记录ID最大的一个工单的号码
  1307. String oErrMessage = null;
  1308. if(map.get("iSN")==null){
  1309. oErrMessage = "SN不能为空";
  1310. rmap.put("oErrMessage",oErrMessage);
  1311. return rmap;
  1312. }
  1313. String iSN=map.get("iSN").toString();
  1314. StringBuffer sql=new StringBuffer();
  1315. sql.append("select max(ms_id)ms_id from makeserial where ms_sncode in (select '" + iSN + "' from dual union select sn from ");
  1316. sql.append("makesnrelation where beforesn='" + iSN + "' and sn<>' ' union select beforesn from makesnrelation where sn='" + iSN + "' and beforesn<>' ')");
  1317. SqlRowList rs = baseDao.queryForRowSet(sql.toString());
  1318. String ms_id="";
  1319. if(rs.next()){
  1320. if(rs.getString("ms_id")==null){
  1321. oErrMessage = "序列号:" + iSN + " 未归属工单";
  1322. rmap.put("oErrMessage",oErrMessage);
  1323. return rmap;
  1324. }
  1325. else{
  1326. ms_id= rs.getString("ms_id");
  1327. }
  1328. }
  1329. Object oMoCode = baseDao.getFieldDataByCondition("MakeSerial", "ms_makecode", "ms_id='" + ms_id + "'");
  1330. if (oMoCode != null){
  1331. rmap.put("oMoCode",oMoCode);
  1332. oErrMessage= null;
  1333. }
  1334. else
  1335. {
  1336. oErrMessage = "序列号:" + iSN + " 未归属工单";
  1337. }
  1338. rmap.put("oErrMessage",oErrMessage);
  1339. return rmap;
  1340. }
  1341. private Map<Object,Object> GetMobileAllInfo(JSONObject map){
  1342. //实际业务数据
  1343. Map<Object, Object> rmap = new HashMap<>();
  1344. String iSN="";
  1345. String oErrMessage = null;
  1346. String oIMEI1 = "";
  1347. String oIMEI2 = "";
  1348. String oMEID = "";
  1349. String oNetCode = "";
  1350. String oPSN = "";
  1351. String oID1 = "";
  1352. String oID2 = "";
  1353. String oID3 = "";
  1354. String oID4 = "";
  1355. String oID5 = "";
  1356. String oWIFI = "";
  1357. String oBT = "";
  1358. String oCode1 = "";
  1359. String oCode2 = "";
  1360. String oCode3 = "";
  1361. if(map.get("iSN")==null){
  1362. oErrMessage = "SN不能为空";
  1363. rmap.put("oErrMessage",oErrMessage);
  1364. return rmap;
  1365. }
  1366. iSN=map.get("iSN").toString();
  1367. Object ms_id =baseDao.getFieldDataByCondition("makeserial", "max(ms_id)", "ms_sncode='" + iSN + "'");
  1368. if(ms_id!=null)
  1369. {
  1370. 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());
  1371. if(rs.next()){
  1372. oWIFI = rs.getString("ms_mac");
  1373. oBT = rs.getString("ms_bt");
  1374. oPSN = rs.getString("ms_psn");
  1375. oNetCode = rs.getString("ms_netcode");
  1376. oMEID = rs.getString("ms_meid");
  1377. oIMEI1 = rs.getString("ms_imei1");
  1378. oIMEI2 = rs.getString("ms_imei2");
  1379. oCode1 = rs.getString("ms_othcode1");
  1380. oCode2 = rs.getString("ms_othcode2");
  1381. oCode3 = rs.getString("ms_othcode3");
  1382. oID1 = rs.getString("ms_othid3");
  1383. oID2 = rs.getString("ms_othid3");
  1384. oID3 = rs.getString("ms_othid3");
  1385. }
  1386. }else
  1387. {
  1388. oErrMessage = "序列号" + iSN + "不存在";
  1389. rmap.put("oErrMessage",oErrMessage);
  1390. return rmap;
  1391. }
  1392. if (oErrMessage == "" || oErrMessage == null || oErrMessage == "null"){
  1393. rmap.put("oIMEI1",oIMEI1);
  1394. rmap.put("oIMEI2",oIMEI2);
  1395. rmap.put("oMEID",oMEID);
  1396. rmap.put("oNetCode",oNetCode);
  1397. rmap.put("oPSN",oPSN);
  1398. rmap.put("oID1",oID1);
  1399. rmap.put("oID2",oID2);
  1400. rmap.put("oID3",oID3);
  1401. rmap.put("oID4",oID4);
  1402. rmap.put("oID5",oID5);
  1403. rmap.put("oWIFI",oWIFI);
  1404. rmap.put("oBT",oBT);
  1405. rmap.put("oCode1",oCode1);
  1406. rmap.put("oCode2",oCode2);
  1407. rmap.put("oCode3",oCode3);
  1408. }
  1409. else
  1410. rmap.put("oErrMessage",oErrMessage);
  1411. return rmap;
  1412. }
  1413. private Map<Object,Object> SetAddressInfo(JSONObject map){
  1414. //实际业务数据
  1415. Map<Object, Object> rmap = new HashMap<>();
  1416. String oErrMessage = null;
  1417. if(map.get("iSN")==null){
  1418. oErrMessage = "SN不能为空";
  1419. rmap.put("oErrMessage",oErrMessage);
  1420. return rmap;
  1421. }
  1422. String iSN=map.get("iSN").toString();
  1423. String iWIFI = null;
  1424. String iBT = null;
  1425. String iCode1 = null;
  1426. String iCode2 = null;
  1427. String iCode3 = null;
  1428. if(map.get("iWIFI")!=null){
  1429. iWIFI=map.get("iWIFI").toString();
  1430. }
  1431. if(map.get("iBT")!=null){
  1432. iBT=map.get("iBT").toString();
  1433. }
  1434. if(map.get("iCode1")!=null){
  1435. iCode1=map.get("iCode1").toString();
  1436. }
  1437. if(map.get("iCode2")!=null){
  1438. iCode2=map.get("iCode2").toString();
  1439. }
  1440. if(map.get("iCode3")!=null){
  1441. iCode3=map.get("iCode3").toString();
  1442. }
  1443. List<String> list = new ArrayList<String>();
  1444. list = baseDao.callProcedureWithOut("CS_SETADDRESSINFO", new Object[]{
  1445. String.valueOf(iSN),
  1446. String.valueOf(iWIFI),
  1447. String.valueOf(iBT),
  1448. String.valueOf(iCode1),
  1449. String.valueOf(iCode2),
  1450. String.valueOf(iCode3)
  1451. }, new Integer[]{1, 2, 3, 4, 5, 6}, new Integer[]{7});
  1452. oErrMessage = list.get(0);
  1453. rmap.put("oErrMessage",oErrMessage);
  1454. return rmap;
  1455. }
  1456. private Map<Object,Object> GetMaster(JSONObject map){
  1457. //实际业务数据
  1458. Map<Object, Object> rmap = new HashMap<>();
  1459. SqlRowList rs=baseDao.queryForRowSet("select ma_user from mes.master");
  1460. while(rs.next())
  1461. {
  1462. rmap.put(rs.getString("ma_user"),rs.getString("ma_user"));
  1463. }
  1464. return rmap;
  1465. }
  1466. private Map<Object,Object> SetMobileData(JSONObject map){
  1467. //实际业务数据
  1468. Map<Object, Object> rmap = new HashMap<>();
  1469. String oErrMessage = null;
  1470. if(map.get("iSN")==null||map.get("iTSN")==null){
  1471. oErrMessage = "SN不能为空";
  1472. rmap.put("oErrMessage",oErrMessage);
  1473. return rmap;
  1474. }
  1475. String iSN=map.get("iSN").toString();
  1476. String iTSN=map.get("iTSN").toString();
  1477. String iSourceCode = null;
  1478. String iOperater = null;
  1479. String iResult = null;
  1480. String flag = null;
  1481. String iErrCode = null;
  1482. if(map.get("iSourceCode")!=null){
  1483. iSourceCode=map.get("iSourceCode").toString();
  1484. }
  1485. if(map.get("iOperater")!=null){
  1486. iOperater=map.get("iOperater").toString();
  1487. }
  1488. if(map.get("iResult")!=null){
  1489. iResult=map.get("iResult").toString();
  1490. }
  1491. if(map.get("flag")!=null){
  1492. flag=map.get("flag").toString();
  1493. }
  1494. if(map.get("iErrCode")!=null){
  1495. iErrCode=map.get("iErrCode").toString();
  1496. }
  1497. List<String> list = new ArrayList<String>();
  1498. list = baseDao.callProcedureWithOut("CS_DLLSNCHANGE", new Object[]{
  1499. String.valueOf(iTSN),
  1500. String.valueOf(iSN),
  1501. String.valueOf(iSourceCode),
  1502. String.valueOf(iOperater),
  1503. String.valueOf(iResult),
  1504. String.valueOf(iErrCode),
  1505. }, new Integer[]{1, 2, 3, 4, 5, 6}, new Integer[]{7});
  1506. oErrMessage = list.get(0);
  1507. rmap.put("oErrMessage",oErrMessage);
  1508. return rmap;
  1509. }
  1510. private Map<Object,Object> SetIMEIInfo(JSONObject map){
  1511. //实际业务数据
  1512. Map<Object, Object> rmap = new HashMap<>();
  1513. String oErrMessage = null;
  1514. if(map.get("iSN")==null){
  1515. oErrMessage = "SN不能为空";
  1516. rmap.put("oErrMessage",oErrMessage);
  1517. return rmap;
  1518. }
  1519. String iSN=map.get("iSN").toString();
  1520. String iIMEI1=null;
  1521. String iIMEI2 = null;
  1522. String iIMEI3 = null;
  1523. String iMEID = null;
  1524. String iNET = null;
  1525. String iID1 = null;
  1526. String iID2 = null;
  1527. String iID3 = null;
  1528. if(map.get("iIMEI1")!=null){
  1529. iIMEI1=map.get("iIMEI1").toString();
  1530. }
  1531. if(map.get("iIMEI2")!=null){
  1532. iIMEI2=map.get("iIMEI2").toString();
  1533. }
  1534. if(map.get("iIMEI3")!=null){
  1535. iIMEI3=map.get("iIMEI3").toString();
  1536. }
  1537. if(map.get("iMEID")!=null){
  1538. iMEID=map.get("iMEID").toString();
  1539. }
  1540. if(map.get("iNET")!=null){
  1541. iNET=map.get("iNET").toString();
  1542. }
  1543. if(map.get("iID1")!=null){
  1544. iID1=map.get("iID1").toString();
  1545. }
  1546. if(map.get("iID2")!=null){
  1547. iID2=map.get("iID2").toString();
  1548. }
  1549. if(map.get("iID3")!=null){
  1550. iID3=map.get("iID3").toString();
  1551. }
  1552. List<String> list = new ArrayList<String>();
  1553. list = baseDao.callProcedureWithOut("CS_SETIMEIINFO", new Object[]{
  1554. String.valueOf(iSN),
  1555. String.valueOf(iIMEI1),
  1556. String.valueOf(iIMEI2),
  1557. String.valueOf(iIMEI3),
  1558. String.valueOf(iMEID),
  1559. String.valueOf(iNET),
  1560. String.valueOf(""),
  1561. String.valueOf(iID1),
  1562. String.valueOf(iID2),
  1563. String.valueOf(iID3),
  1564. }, new Integer[]{1, 2, 3, 4, 5, 6,7,8,9,10}, new Integer[]{11});
  1565. oErrMessage = list.get(0);
  1566. rmap.put("oErrMessage",oErrMessage);
  1567. return rmap;
  1568. }
  1569. private Map<Object,Object> SetTestDetail(JSONObject map){
  1570. //实际业务数据
  1571. Map<Object, Object> rmap = new HashMap<>();
  1572. String oErrMessage=null;
  1573. if(map.get("iSN")==null){
  1574. oErrMessage = "SN不能为空";
  1575. rmap.put("oErrMessage",oErrMessage);
  1576. return rmap;
  1577. }
  1578. String iSN=map.get("iSN").toString();
  1579. String iTestResult= "";
  1580. String iResCode= "";
  1581. String iClassName="";
  1582. String iTestDetail= "";
  1583. if(map.get("iTestResult")!=null){
  1584. iTestResult=map.get("iTestResult").toString();
  1585. }
  1586. if(map.get("iClassName")!=null){
  1587. iClassName=map.get("iClassName").toString();
  1588. }
  1589. if(map.get("iResCode")!=null){
  1590. iResCode=map.get("iResCode").toString();
  1591. }
  1592. if(map.get("iTestDetail")!=null){
  1593. iTestDetail=map.get("iTestDetail").toString();
  1594. }
  1595. JSONObject map3=new JSONObject();
  1596. map3.put("iSN",iSN);
  1597. Map<Object, Object> map2=GetRcardMOInfo(map3);
  1598. String omakeCode = "";
  1599. StringBuffer sql=new StringBuffer();
  1600. String[] name=iClassName.split("\\|");
  1601. String[] result=iTestResult.split("\\|");
  1602. String[] value=iTestDetail.split("\\|");
  1603. if(name.length!=value.length||name.length!=result.length){
  1604. rmap.put("oErrMessage","测试项目名称和值的项次不一致");
  1605. return rmap;
  1606. }
  1607. for (int i=0;i<name.length;i++){
  1608. sql.setLength(0);
  1609. sql.append("Insert into STEPTESTDETAIL (STD_ID,STD_CLASS,STD_SN,STD_MAKECODE,STD_ACTUALVALUE,STD_TESTRESULT,STD_INDATE,STD_RESCODE)");
  1610. sql.append("values(STEPTESTDETAIL_SEQ.nextval,'"+name[i]+"','" + iSN + "','" + map2.get("oMoCode") + "','" + value[i] + "','" + result[i] + "',sysdate,'" + iResCode + "')");
  1611. baseDao.execute(sql.toString());
  1612. }
  1613. rmap.put("oErrMessage",oErrMessage);
  1614. return rmap;
  1615. }
  1616. @Override
  1617. public Map<Object,Object> SetPcbaData(String data){
  1618. //实际业务数据
  1619. Map<Object, Object> rmap = new HashMap<>();
  1620. Map<String, Object> map=null;
  1621. try{
  1622. map =BaseUtil.convertJsonToMap(data);
  1623. }catch (Exception e){
  1624. rmap.put("code",-1);
  1625. rmap.put("message",e.getMessage());
  1626. System.out.printf(e.getMessage()) ;
  1627. return rmap;
  1628. }
  1629. String oErrMessage = null;
  1630. Integer code=0;
  1631. if(map.get("iSN")==null){
  1632. code=-1;
  1633. oErrMessage = "SN不能为空";
  1634. rmap.put("code",code);
  1635. rmap.put("oErrMessage",oErrMessage);
  1636. return rmap;
  1637. }
  1638. String iSN=map.get("iSN").toString();
  1639. SqlRowList rs=baseDao.queryForRowSet("select ms_sncode from makeserial where ms_imei1='"+iSN+"' or ms_imei2='"+iSN+"' or ms_imei3='"+iSN+"'");
  1640. if(rs.next()){
  1641. iSN=rs.getString("ms_sncode");
  1642. }else{
  1643. rs=baseDao.queryForRowSet("select mil_sncode from makeimeilist where mil_imei1='"+iSN+"' or mil_imei2='"+iSN+"' or mil_imei3='"+iSN+"'");
  1644. if(rs.next()){
  1645. iSN=rs.getString("mil_sncode");
  1646. }
  1647. }
  1648. String iResCode = null;
  1649. String iOperator = null;
  1650. String iResult = null;
  1651. String iErrCode = null;
  1652. if(map.get("iResCode")!=null){
  1653. iResCode=map.get("iResCode").toString();
  1654. }
  1655. if(map.get("iOperater")!=null){
  1656. iOperator=map.get("iOperater").toString();
  1657. }
  1658. if(map.get("iResult")!=null){
  1659. iResult=map.get("iResult").toString();
  1660. }
  1661. if(map.get("iErrCode")!=null){
  1662. iErrCode=map.get("iErrCode").toString();
  1663. }
  1664. JSONObject map3=new JSONObject();
  1665. map3.put("iSN",iSN);
  1666. Map<Object, Object> map2=GetRcardMOInfo(map3);
  1667. String oMoCode=null;
  1668. if(map2.get("oMoCode")!=null){
  1669. oMoCode=map2.get("oMoCode").toString();
  1670. }
  1671. if (map2.get("oErrMessage")==null)
  1672. return SetStepFinish(oMoCode, iResCode, iSN, "", iResult, iOperator, iErrCode);
  1673. return rmap;
  1674. }
  1675. private Map<Object,Object> SetPcbaData(JSONObject map){
  1676. //实际业务数据
  1677. Map<Object, Object> rmap = new HashMap<>();
  1678. String oErrMessage = null;
  1679. Integer code=0;
  1680. if(map.get("iSN")==null){
  1681. code=-1;
  1682. oErrMessage = "SN不能为空";
  1683. rmap.put("code",code);
  1684. rmap.put("oErrMessage",oErrMessage);
  1685. return rmap;
  1686. }
  1687. String iSN=map.get("iSN").toString();
  1688. String iResCode = null;
  1689. String iOperator = null;
  1690. String iResult = null;
  1691. String iErrCode = null;
  1692. if(map.get("iResCode")!=null){
  1693. iResCode=map.get("iResCode").toString();
  1694. }
  1695. if(map.get("iOperater")!=null){
  1696. iOperator=map.get("iOperater").toString();
  1697. }
  1698. if(map.get("iResult")!=null){
  1699. iResult=map.get("iResult").toString();
  1700. }
  1701. if(map.get("iErrCode")!=null){
  1702. iErrCode=map.get("iErrCode").toString();
  1703. }
  1704. JSONObject map3=new JSONObject();
  1705. map3.put("iSN",iSN);
  1706. Map<Object, Object> map2=GetRcardMOInfo(map3);
  1707. String oMoCode=null;
  1708. if(map2.get("oMoCode")!=null){
  1709. oMoCode=map2.get("oMoCode").toString();
  1710. }
  1711. if (map2.get("oErrMessage")==null)
  1712. return SetStepFinish(oMoCode, iResCode, iSN, "", iResult, iOperator, iErrCode);
  1713. return rmap;
  1714. }
  1715. private Object SetPcbaData(String iSN,String iResCode,String iOperator,String iResult){
  1716. //实际业务数据
  1717. Map<Object, Object> rmap = new HashMap<>();
  1718. String iErrCode = null;
  1719. if(iSN==null){
  1720. iErrCode = "SN不能为空";
  1721. return iErrCode;
  1722. }
  1723. JSONObject map3=new JSONObject();
  1724. map3.put("iSN",iSN);
  1725. Map<Object, Object> map2=GetRcardMOInfo(map3);
  1726. String oMoCode=null;
  1727. if(map2.get("oMoCode")!=null){
  1728. oMoCode=map2.get("oMoCode").toString();
  1729. }
  1730. if (map2.get("oErrMessage")==null)
  1731. map2= SetStepFinish(oMoCode, iResCode, iSN, "", iResult, iResCode, iErrCode);
  1732. return map2.get("oErrMessage");
  1733. }
  1734. /// <summary>
  1735. /// 获取步骤代码
  1736. /// </summary>
  1737. /// <param name="Source"></param>
  1738. /// <returns></returns>
  1739. private String GetStepCodeBySource(String Source)
  1740. {
  1741. Object o=baseDao.getFieldDataByCondition("source", "sc_stepcode", "sc_code='" + Source + "'");
  1742. if(o!=null)
  1743. return o.toString();
  1744. else
  1745. return "";
  1746. }
  1747. private Boolean CheckUserLogin(String iUserCode, String iPassWord)
  1748. {
  1749. SqlRowList rs =baseDao.queryForRowSet("select em_code from employee where em_code='"+iUserCode+"' and em_password =?",iPassWord);
  1750. if (rs.next())
  1751. return true;
  1752. else
  1753. {
  1754. return false;
  1755. }
  1756. }
  1757. private Map<Object,Object> GetMakeInfoBySN(JSONObject map)
  1758. {
  1759. Map<Object, Object> rmap = new HashMap<Object, Object>();
  1760. String iSN=null;
  1761. String oErrMessage=null;
  1762. if(map.get("iSN")==null){
  1763. oErrMessage = "SN不能为空";
  1764. rmap.put("oErrMessage",oErrMessage);
  1765. return rmap;
  1766. }
  1767. iSN=map.get("iSN").toString();
  1768. 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 from make " +
  1769. "left join makeserial on ms_makecode=ma_code where ms_sncode='"+iSN+"'");
  1770. if(rs.next()){
  1771. rmap.put("oMaremark1",rs.getString("ma_remark1"));
  1772. rmap.put("oMaremark2",rs.getString("ma_remark2"));
  1773. rmap.put("oMaremark3",rs.getString("ma_remark3"));
  1774. rmap.put("oMaremark4",rs.getString("ma_remark4"));
  1775. rmap.put("oMaremark5",rs.getString("ma_remark5"));
  1776. rmap.put("oMaremark6",rs.getString("ma_remark6"));
  1777. rmap.put("oMaremark7",rs.getString("ma_remark7"));
  1778. rmap.put("oMaremark8",rs.getString("ma_remark8"));
  1779. rmap.put("oMaremark9",rs.getString("ma_remark9"));
  1780. rmap.put("oMaremark10",rs.getString("ma_remark10"));
  1781. rmap.put("oMaremark11",rs.getString("ma_remark11"));
  1782. rmap.put("oMaremark12",rs.getString("ma_remark12"));
  1783. rmap.put("oMaremark13",rs.getString("ma_remark13"));
  1784. rmap.put("oMaremark14",rs.getString("ma_remark14"));
  1785. rmap.put("oMaremark15",rs.getString("ma_remark15"));
  1786. rmap.put("oMaremark16",rs.getString("ma_remark16"));
  1787. return rmap;
  1788. }else{
  1789. oErrMessage = "SN未查询到关联信息";
  1790. rmap.put("oErrMessage",oErrMessage);
  1791. return rmap;
  1792. }
  1793. }
  1794. public Map<Object,Object> SetStepFinish(String iMakeCode, String iSourceCode, String iSN, String iMPKind, String iResult, String iUserCode, String iErrCode)
  1795. {
  1796. String oErrMessage = null;
  1797. Object StepCode = baseDao.getFieldDataByCondition("Makeserial", "ms_stepcode", "ms_sncode='" + iSN + "' and ms_makecode='" + iMakeCode + "'");
  1798. String CurrentStep = GetStepCodeBySource(iSourceCode);
  1799. Object BgCode = baseDao.getFieldDataByCondition("step", "nvl(st_badgroupcode,' ')", "st_code='" + CurrentStep + "'");
  1800. Map<Object, Object> rmap = new HashMap<>();
  1801. Integer code=0;
  1802. switch (iResult)
  1803. {
  1804. case "OK":
  1805. break;
  1806. case "NG":
  1807. if (iErrCode == "")
  1808. {
  1809. oErrMessage = "测试结果为NG时必须传递不良代码";
  1810. code=-1;
  1811. rmap.put("code",code);
  1812. rmap.put("oErrMessage",oErrMessage);
  1813. return rmap;
  1814. }
  1815. else
  1816. {
  1817. baseDao.updateByCondition("makebad", "mb_status=-1", "mb_sncode='" + iSN + "' and mb_makecode='" + iMakeCode + "' and mb_stepcode='" + CurrentStep + "' and mb_status=0");
  1818. String[] BadCode = iErrCode.split(",");
  1819. StringBuffer sql=new StringBuffer();
  1820. for (int i = 0; i < BadCode.length; i++)
  1821. {
  1822. if(!baseDao.checkIf("badcode","bc_code='"+ BadCode[i]+"'")){
  1823. oErrMessage = "不良代码"+BadCode[i]+"不存在";
  1824. code=-1;
  1825. rmap.put("code",code);
  1826. rmap.put("oErrMessage",oErrMessage);
  1827. return rmap;
  1828. }
  1829. int mb_id = baseDao.getSeqId("makebad_seq");
  1830. sql.setLength(0);
  1831. sql.append("insert into makebad(mb_id,mb_makecode,mb_mscode,mb_sncode,mb_inman,mb_indate,mb_stepcode");
  1832. sql.append(",mb_sourcecode,mb_badcode,mb_badtable,mb_bgcode,mb_soncode,mb_status) select '" + mb_id + "'");
  1833. sql.append(",ma_code,ms_code,ms_sncode,'" + iUserCode + "',sysdate,'" + CurrentStep + "','" + iSourceCode + "','" + BadCode[i] + "','',");
  1834. sql.append("'" + BgCode + "',sp_soncode,'0' from make left join makeSerial on ms_makecode=ma_code left join stepProduct on ");
  1835. sql.append("sp_mothercode=ma_prodcode and sp_stepcode=ms_nextstepcode where ms_sncode='" + iSN + "' and ms_makecode='" + iMakeCode + "'");
  1836. baseDao.execute(sql.toString());
  1837. }
  1838. //将不良的序列号的状态码设为3
  1839. baseDao.execute("update makeserial set ms_status='3' where ms_sncode='" + iSN + "' and ms_makecode='" + iMakeCode + "'");
  1840. }
  1841. break;
  1842. default:
  1843. oErrMessage = "测试结果必须为NG或者OK";
  1844. code=-1;
  1845. rmap.put("code",code);
  1846. rmap.put("oErrMessage",oErrMessage);
  1847. return rmap;
  1848. }
  1849. //不良采集为良品是更新
  1850. if (StepCode!=null &&StepCode.toString().equals(CurrentStep) && iResult == "OK")
  1851. {
  1852. Object[] ob = baseDao.getFieldsDataByCondition("makeserial", "ms_status,ms_craftcode,ms_prodcode", "ms_sncode='" + iSN + "' and ms_makecode='" + iMakeCode + "'");
  1853. if (ob!=null)
  1854. {
  1855. String ms_status =ob[0].toString();
  1856. String ms_craftcode= ob[1].toString();
  1857. String ms_prodcode = ob[2].toString();
  1858. if (ms_status == "3")
  1859. {
  1860. String nextstepcode =baseDao.getFieldDataByCondition("craft left join craftdetail on cr_id=cd_crid ", "cd_nextstepcode", "cr_code='" + ms_craftcode + "' and cr_prodcode='" + ms_prodcode + "' and cd_stepcode='" + CurrentStep + "'").toString();
  1861. baseDao.updateByCondition("makeserial", "ms_status=1,ms_nextstepcode='" + nextstepcode + "'", "ms_sncode='" + iSN + "' and ms_makecode='" + iMakeCode + "'");
  1862. baseDao.updateByCondition("makebad", "mb_status=-1", "mb_sncode='" + iSN + "' and mb_makecode='" + iMakeCode + "'");
  1863. }
  1864. }
  1865. }
  1866. return CS_SetFinish(iMakeCode, iSourceCode, iSN, iUserCode, iResult);
  1867. }
  1868. private Map<Object,Object> CS_SetFinish(String iMakeCode, String iSourceCode, String iSN, String iUserCode, String iResult)
  1869. {
  1870. Map<Object, Object> rmap = new HashMap<>();
  1871. String oErrMessage=null;
  1872. List<String> list = new ArrayList<String>();
  1873. list = baseDao.callProcedureWithOut("CS_SETSTEPRESULT", new Object[]{
  1874. String.valueOf(iMakeCode),
  1875. String.valueOf(iSourceCode),
  1876. String.valueOf(iSN),
  1877. String.valueOf(iUserCode),
  1878. String.valueOf(iResult),
  1879. }, new Integer[]{1, 2, 3, 4, 5}, new Integer[]{6});
  1880. oErrMessage = list.get(0);
  1881. if(oErrMessage==null){
  1882. rmap.put("code",0);
  1883. }else{
  1884. rmap.put("code",-1);
  1885. }
  1886. rmap.put("oErrMessage",oErrMessage);
  1887. return rmap;
  1888. }
  1889. private String checkAccessKey(String accessKey,String requestId){
  1890. Object accessSecret_O = baseDao.getFieldDataByCondition("APIEMPLOYEE", "AE_SECRET", "AE_KEY='" + accessKey + "'");
  1891. Object AE_MASTER = baseDao.getFieldDataByCondition("APIEMPLOYEE", "AE_MASTER", "AE_KEY='" + accessKey + "'");
  1892. String accessSecret = accessSecret_O == null ? "" : accessSecret_O.toString();
  1893. // 检查KEY是否合理
  1894. if (StringUtils.isEmpty(accessKey) || StringUtils.isEmpty(accessSecret) || AE_MASTER== null || "".equals(AE_MASTER.toString())) {
  1895. ApiResult apiResult = new ApiResult(ErrorMessage.ACCESSKEY_ILLEGAL.getCode(),ErrorMessage.ACCESSKEY_ILLEGAL.getMessage(),requestId);
  1896. throw new ApiSystemException(apiResult);
  1897. }
  1898. return AE_MASTER.toString();
  1899. }
  1900. @Override
  1901. public Map<Object,Object> getMESSnCode(String data) {
  1902. Map<String, Object> map=null;
  1903. Map<Object, Object> rmap = new HashMap<Object, Object>();
  1904. try{
  1905. map =BaseUtil.convertJsonToMap(data);
  1906. }catch (Exception e){
  1907. rmap.put("code",-1);
  1908. rmap.put("message",e.getMessage());
  1909. System.out.printf(e.getMessage()) ;
  1910. return rmap;
  1911. }
  1912. String macode = map.get("moid") == null ? "" : String.valueOf(map.get("moid"));
  1913. if("".equals(macode)){
  1914. rmap.put("code",-1);
  1915. rmap.put("message","工单不能为空");
  1916. return rmap;
  1917. }
  1918. if (!baseDao.checkIf("make","ma_code='"+macode+"'")){
  1919. rmap.put("code",-1);
  1920. rmap.put("message","工单不存在");
  1921. return rmap;
  1922. }
  1923. if (baseDao.checkIf("make","nvl(ma_statuscode,' ')<>'STARTED' and ma_code='"+macode+"'")){
  1924. rmap.put("code",-1);
  1925. rmap.put("message","工单不是已下放状态");
  1926. return rmap;
  1927. }
  1928. if (!baseDao.checkIf("MakeSnList","msl_makecode='"+macode+"'")){
  1929. rmap.put("code",-1);
  1930. rmap.put("message","工单未维护SN");
  1931. return rmap;
  1932. }
  1933. double sncount = map.get("count") == null ? 0 : Double.parseDouble(map.get("count").toString());
  1934. if(sncount<=0){
  1935. rmap.put("code",-1);
  1936. rmap.put("message","SN数量必须大于0");
  1937. return rmap;
  1938. }
  1939. int count = baseDao.getCountByCondition("MakeSnList", "msl_makecode='" + macode + "' and nvl(msl_status,0)=0");
  1940. if (count<sncount){
  1941. rmap.put("code",-1);
  1942. rmap.put("message","SN不足!");
  1943. return rmap;
  1944. }
  1945. List<String> sqls = new ArrayList<>();
  1946. List<Map<String, Object>> maps = new ArrayList<>();
  1947. Map<String, Object> snmap=null;
  1948. SqlRowList rs = baseDao.queryForRowSet("select msl_sncode,msl_id from (select msl_sncode,msl_id from MakeSnList where msl_makecode='" + macode + "' and nvl(msl_status,0)=0 order by msl_sncode) where rownum<="+sncount +" order by msl_sncode ");
  1949. String mainbarcode="";
  1950. String msl_id="";
  1951. while (rs.next()){
  1952. snmap=new HashMap<String, Object>();
  1953. snmap.put("serialNo",rs.getGeneralString("msl_sncode"));
  1954. mainbarcode=rs.getGeneralString("msl_sncode");
  1955. maps.add(snmap);
  1956. sqls.add("update MakeSnList set msl_signtime=sysdate,msl_status=-1 where msl_id="+rs.getGeneralInt("msl_id"));
  1957. msl_id+=rs.getGeneralInt("msl_id")+",";
  1958. }
  1959. msl_id+="0";
  1960. baseDao.execute("update MakeSnList set msl_mainbarcode='"+mainbarcode+"' where msl_id in ("+msl_id+")");
  1961. if (sqls!=null&&sqls.size()>0){
  1962. baseDao.execute(sqls);
  1963. }
  1964. rmap.put("code",0);
  1965. rmap.put("data",maps);
  1966. return rmap;
  1967. }
  1968. }