MESHelperServiceImpl.java 89 KB

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