From ff2b6e2329ae2c5d3fede2f9413170fd6e87c46c Mon Sep 17 00:00:00 2001 From: Junjie <540245094@qq.com> Date: 星期五, 08 十二月 2023 09:27:52 +0800 Subject: [PATCH] #输送线读取 --- src/main/java/com/zy/core/thread/BarcodeThread.java | 95 +++++++++++++++++++++++------------------------ 1 files changed, 46 insertions(+), 49 deletions(-) diff --git a/src/main/java/com/zy/core/thread/BarcodeThread.java b/src/main/java/com/zy/core/thread/BarcodeThread.java index 6623a1a..fe43a35 100644 --- a/src/main/java/com/zy/core/thread/BarcodeThread.java +++ b/src/main/java/com/zy/core/thread/BarcodeThread.java @@ -1,7 +1,9 @@ package com.zy.core.thread; +import com.alibaba.fastjson.JSONObject; import com.core.common.Cools; import com.core.common.DateUtils; +import com.zy.core.News; import com.zy.core.Slave; import com.zy.core.ThreadHandler; import com.zy.core.cache.OutputQueue; @@ -15,7 +17,6 @@ import java.net.Socket; import java.net.SocketAddress; import java.net.SocketTimeoutException; -import java.text.MessageFormat; import java.util.Date; /** @@ -27,35 +28,32 @@ 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; } - @Override - @SuppressWarnings("InfiniteLoopStatement") - public void run() { - connect(); - while (true) { - try { - byte[] read = read(8, 100); - if (null != read) { - String s = new String(read); - if (!Cools.isEmpty(s)) { - barcode = new String(read); - log.info("{}鍙锋潯鐮佸櫒锛屾绱㈡暟鎹細{}", slave.getId(), this.barcode); - OutputQueue.CRN.offer(MessageFormat.format("銆恵0}銆戝爢鍨涙満plc杩炴帴澶辫触锛侊紒锛� ===>> [id:{1}] [ip:{2}] [port:{3}] ", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort())); - } - } - Thread.sleep(100); - } catch (SocketTimeoutException ignore) { - } catch (Exception e) { -// e.printStackTrace(); + 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)) { + News.info("{}鍙锋潯鐮佸櫒锛屾绱㈡暟鎹細{}", slave.getId(), this.barcode); + JSONObject jsonObject = new JSONObject(); + jsonObject.put("time", DateUtils.convert(new Date(), DateUtils.yyyyMMddHHmmss_F)); + jsonObject.put("barcode", barcode); + if (OutputQueue.BARCODE.size() >= 32) { + OutputQueue.BARCODE.poll(); } + OutputQueue.BARCODE.offer(jsonObject); } } @@ -64,7 +62,6 @@ try { close(); //1.涓诲姩閲婃斁杩炴帴 //2.鏌愪簺鏈嶅姟鍣ㄥ鎸囧畾ip鏈夐摼璺暟闄愬埗 socket = new Socket(); - //socket.setKeepAlive(true); SocketAddress socketAddress = new InetSocketAddress(slave.getIp(), slave.getPort()); socket.connect(socketAddress, 1000); //鏌愪簺鏈嶅姟鍣╬ing寤惰繜楂樻椂瑕佸鍔�,鍚﹀垯浼氭姤閿檆onnect timeout dataOutputStream = new DataOutputStream(socket.getOutputStream()); @@ -87,9 +84,6 @@ if (null != dataInputStream) { dataInputStream.close(); } -// if (null != socket && !socket.isClosed()) { -// socket.close(); -// } if (null != socket){ socket.close(); } @@ -99,19 +93,35 @@ } } - 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, 5000); + if (null != read) { + String s = new String(read); + if (!Cools.isEmpty(s)) { + setBarcode(new String(read)); + } + } + Thread.sleep(50); + } catch (SocketTimeoutException ignore) { + connCount++; + } catch (Exception e) { + setBarcode(""); + e.printStackTrace(); + } } } public byte[] read(int bufferSize, int timeOut) throws IOException { -// if (socket == null) { -// connect(); -// } - connect(); + if (socket == null || !socket.isConnected() || socket.isClosed() || connCount > 120) { + connect(); + connCount = 0; + return null; + } socket.setSoTimeout(timeOut); byte[] bytes = new byte[bufferSize]; int len = dataInputStream.read(bytes); @@ -119,24 +129,11 @@ if (len > 0) { 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; - } } -- Gitblit v1.9.1