|  |  |  | 
|---|
|  |  |  | package com.zy.core.thread; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.alibaba.fastjson.JSONObject; | 
|---|
|  |  |  | import com.core.common.Cools; | 
|---|
|  |  |  | import com.core.common.DateUtils; | 
|---|
|  |  |  | import com.core.common.SpringUtils; | 
|---|
|  |  |  | import com.zy.asrs.service.AgvBasDevpService; | 
|---|
|  |  |  | import com.zy.asrs.service.BasDevpService; | 
|---|
|  |  |  | import com.zy.core.News; | 
|---|
|  |  |  | import com.zy.core.Slave; | 
|---|
|  |  |  | import com.zy.core.ThreadHandler; | 
|---|
|  |  |  | import com.zy.core.cache.OutputQueue; | 
|---|
|  |  |  | import lombok.Data; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.io.DataInputStream; | 
|---|
|  |  |  | import java.io.DataOutputStream; | 
|---|
|  |  |  | 
|---|
|  |  |  | import java.net.InetSocketAddress; | 
|---|
|  |  |  | import java.net.Socket; | 
|---|
|  |  |  | import java.net.SocketAddress; | 
|---|
|  |  |  | import java.net.SocketTimeoutException; | 
|---|
|  |  |  | import java.util.Date; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 条码扫描仪线程 | 
|---|
|  |  |  | 
|---|
|  |  |  | public class BarcodeThread implements Runnable, ThreadHandler { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private Slave slave; | 
|---|
|  |  |  | private String barcode; | 
|---|
|  |  |  | private StringBuffer barcode = new StringBuffer(); | 
|---|
|  |  |  | private Socket socket; | 
|---|
|  |  |  | private DataOutputStream dataOutputStream; | 
|---|
|  |  |  | private DataInputStream dataInputStream; | 
|---|
|  |  |  | public Integer connCount = 0; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public BarcodeThread(Slave slave) { | 
|---|
|  |  |  | this.slave = slave; | 
|---|
|  |  |  | connect(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @SuppressWarnings("InfiniteLoopStatement") | 
|---|
|  |  |  | public void run() { | 
|---|
|  |  |  | while (true) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | write("T".getBytes(), "T".length()); | 
|---|
|  |  |  | byte[] read = read(11, 1000); | 
|---|
|  |  |  | if (null != read) { | 
|---|
|  |  |  | barcode = new String(read); | 
|---|
|  |  |  | public String getBarcode() { | 
|---|
|  |  |  | return barcode.toString(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public void setBarcode(String barcode) { | 
|---|
|  |  |  | this.barcode.delete(0, this.barcode.length()); | 
|---|
|  |  |  | this.barcode.append(barcode); | 
|---|
|  |  |  | if(!Cools.isEmpty(barcode)) { | 
|---|
|  |  |  | AgvBasDevpService agvBasDevpService = SpringUtils.getBean(AgvBasDevpService.class); | 
|---|
|  |  |  | News.info("{}号条码器,检索数据:{}", slave.getId(), this.barcode); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | String devNo = slave.getId() == 13 ? "310-1" : slave.getId() == 15 ? "312-2" : slave.getId() == 17 ? "314-1" : slave.getId() == 19 ? "316-1" : null; | 
|---|
|  |  |  | if(!Cools.isEmpty(devNo)){ | 
|---|
|  |  |  | barcode = barcode.substring(3,barcode.length()); | 
|---|
|  |  |  | int updateBarcode = agvBasDevpService.updateBarcode(devNo, barcode); | 
|---|
|  |  |  | if (updateBarcode <= 0) { | 
|---|
|  |  |  | News.info("{}号条码器,检索数据:{},更新站点条码失败", slave.getId(), this.barcode); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Thread.sleep(1000); | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | News.info("{}号条码器,更新成功", slave.getId()); | 
|---|
|  |  |  | JSONObject jsonObject = new JSONObject(); | 
|---|
|  |  |  | jsonObject.put("time", DateUtils.convert(new Date(), DateUtils.yyyyMMddHHmmss_F)); | 
|---|
|  |  |  | jsonObject.put("barcode", barcode); | 
|---|
|  |  |  | jsonObject.put("id", slave.getId()); | 
|---|
|  |  |  | if (OutputQueue.BARCODE.size() >= 32) { | 
|---|
|  |  |  | OutputQueue.BARCODE.poll(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | OutputQueue.BARCODE.offer(jsonObject); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | close();  //1.主动释放连接 //2.某些服务器对指定ip有链路数限制 | 
|---|
|  |  |  | socket = new Socket(); | 
|---|
|  |  |  | //socket.setKeepAlive(true); | 
|---|
|  |  |  | SocketAddress socketAddress = new InetSocketAddress(slave.getIp(), slave.getPort()); | 
|---|
|  |  |  | socket.connect(socketAddress, 1000); //某些服务器ping延迟高时要增加,否则会报错connect timeout | 
|---|
|  |  |  | socket.connect(socketAddress, 10000); //某些服务器ping延迟高时要增加,否则会报错connect timeout | 
|---|
|  |  |  | dataOutputStream = new DataOutputStream(socket.getOutputStream()); | 
|---|
|  |  |  | dataInputStream = new DataInputStream(socket.getInputStream()); | 
|---|
|  |  |  | //            log.info("条码扫描仪连接成功 ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort()); | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | socket = null; | 
|---|
|  |  |  | log.error("socket connect error ip:"); | 
|---|
|  |  |  | log.error("条码扫描仪连接失败!!! ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort()); | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void close() { | 
|---|
|  |  |  | log.debug("Entry Method:close()"); | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | if (null != dataOutputStream) { | 
|---|
|  |  |  | dataOutputStream.close(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (null != dataInputStream) { | 
|---|
|  |  |  | dataInputStream.close(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (null != socket && !socket.isClosed()) { | 
|---|
|  |  |  | socket.close(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | socket = null; | 
|---|
|  |  |  | dataOutputStream.close(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (null != dataInputStream) { | 
|---|
|  |  |  | dataInputStream.close(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (null != socket){ | 
|---|
|  |  |  | socket.close(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | socket = null; | 
|---|
|  |  |  | } catch (IOException e) { | 
|---|
|  |  |  | log.error("SocketClient close Exception:" + e.getMessage()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | log.debug("Exit Method:close()"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public void write(byte[] msg, int len) throws IOException { | 
|---|
|  |  |  | if (null != dataInputStream) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | dataOutputStream.write(msg, 0, len); | 
|---|
|  |  |  | dataOutputStream.flush(); | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @SuppressWarnings("InfiniteLoopStatement") | 
|---|
|  |  |  | public void run() { | 
|---|
|  |  |  | connect(); | 
|---|
|  |  |  | while (true) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | byte[] read = read(14, 3 * 60 * 1000); | 
|---|
|  |  |  | if (null != read) { | 
|---|
|  |  |  | String s = new String(read); | 
|---|
|  |  |  | log.warn("ip:{},id:{},读取到条码:{}",slave.getIp(),slave.getId(),s); | 
|---|
|  |  |  | if (!Cools.isEmpty(s)) { | 
|---|
|  |  |  | setBarcode(new String(read)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Thread.sleep(50); | 
|---|
|  |  |  | }catch (Exception e) { | 
|---|
|  |  |  | log.warn("ip:{},id:{},读取条码异常:{}",slave.getIp(),slave.getId(),e); | 
|---|
|  |  |  | setBarcode(""); | 
|---|
|  |  |  | log.error("run" + e); | 
|---|
|  |  |  | //                e.printStackTrace(); | 
|---|
|  |  |  | connect(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public byte[] read(int bufferSize, int timeOut) throws IOException { | 
|---|
|  |  |  | if (socket == null) { | 
|---|
|  |  |  | if (socket == null || !socket.isConnected() || socket.isClosed() || connCount > 120) { | 
|---|
|  |  |  | connect(); | 
|---|
|  |  |  | connCount = 0; | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | socket.setSoTimeout(timeOut * 1000); | 
|---|
|  |  |  | socket.setSoTimeout(timeOut); | 
|---|
|  |  |  | byte[] bytes = new byte[bufferSize]; | 
|---|
|  |  |  | log.trace("dataInputStream.read"); | 
|---|
|  |  |  | int len = dataInputStream.read(bytes); | 
|---|
|  |  |  | log.debug("readLen:" + len); | 
|---|
|  |  |  | byte[] tempBytes = null; | 
|---|
|  |  |  | if (len > 0) { | 
|---|
|  |  |  | tempBytes = new byte[len]; | 
|---|
|  |  |  | System.arraycopy(bytes, 0, tempBytes, 0, len); | 
|---|
|  |  |  | tempBytes = new byte[len]; | 
|---|
|  |  |  | System.arraycopy(bytes, 0, tempBytes, 0, len); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | connect(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return tempBytes; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public boolean valid() throws Exception { | 
|---|
|  |  |  | if (null == socket || socket.isClosed() || socket.isInputShutdown() || socket.isOutputShutdown()) { | 
|---|
|  |  |  | if (dataInputStream != null) { | 
|---|
|  |  |  | dataInputStream.close(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (dataOutputStream != null) { | 
|---|
|  |  |  | dataOutputStream.close(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (socket != null) { | 
|---|
|  |  |  | socket.close(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public static void main(String[] args) throws Exception { | 
|---|
|  |  |  | BarcodeThread barcodeThread = new BarcodeThread(new Slave()); | 
|---|
|  |  |  | barcodeThread.getSlave().setIp("192.168.2.150"); | 
|---|
|  |  |  | barcodeThread.getSlave().setPort(51236); | 
|---|
|  |  |  | boolean connect = barcodeThread.connect(); | 
|---|
|  |  |  | System.out.println(connect); | 
|---|
|  |  |  | barcodeThread.write("T".getBytes(), "T".length()); | 
|---|
|  |  |  | byte[] read = barcodeThread.read(11, 1000); | 
|---|
|  |  |  | System.out.println(new String(read)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|