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 | 133 ++++++++++++++++++++++++++++++++++---------- 1 files changed, 103 insertions(+), 30 deletions(-) diff --git a/src/main/java/com/zy/core/thread/BarcodeThread.java b/src/main/java/com/zy/core/thread/BarcodeThread.java index 5974a9a..fe43a35 100644 --- a/src/main/java/com/zy/core/thread/BarcodeThread.java +++ b/src/main/java/com/zy/core/thread/BarcodeThread.java @@ -1,11 +1,23 @@ package com.zy.core.thread; -import HslCommunication.Core.Types.OperateResult; -import HslCommunication.Enthernet.SimplifyNet.NetSimplifyClient; +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; import lombok.Data; import lombok.extern.slf4j.Slf4j; + +import java.io.DataInputStream; +import java.io.DataOutputStream; +import java.io.IOException; +import java.net.InetSocketAddress; +import java.net.Socket; +import java.net.SocketAddress; +import java.net.SocketTimeoutException; +import java.util.Date; /** * 鏉$爜鎵弿浠嚎绋� @@ -16,51 +28,112 @@ public class BarcodeThread implements Runnable, ThreadHandler { private Slave slave; - private String barcode; - private NetSimplifyClient netSimplifyClient; + 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 { -// Task task = MessageQueue.poll(SlaveType.Barcode, slave.getId()); - barcode = "10001136"; - Thread.sleep(3000); - } 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); } } @Override public boolean connect() { - boolean result = false; - netSimplifyClient = new NetSimplifyClient(slave.getIp(), slave.getPort()); - OperateResult connect = netSimplifyClient.ConnectServer(); - if (connect.IsSuccess) { - result = true; - log.info("鏉$爜鎵弿浠繛鎺ユ垚鍔� ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort()); - } else { - log.info("鏉$爜鎵弿浠繛鎺ュけ璐ワ紒锛侊紒 ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort()); + try { + close(); //1.涓诲姩閲婃斁杩炴帴 //2.鏌愪簺鏈嶅姟鍣ㄥ鎸囧畾ip鏈夐摼璺暟闄愬埗 + socket = new Socket(); + SocketAddress socketAddress = new InetSocketAddress(slave.getIp(), slave.getPort()); + socket.connect(socketAddress, 1000); //鏌愪簺鏈嶅姟鍣╬ing寤惰繜楂樻椂瑕佸鍔�,鍚﹀垯浼氭姤閿檆onnect 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("鏉$爜鎵弿浠繛鎺ュけ璐ワ紒锛侊紒 ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort()); + return false; } - return result; + return true; } @Override public void close() { - + try { + if (null != dataOutputStream) { + dataOutputStream.close(); + } + if (null != dataInputStream) { + dataInputStream.close(); + } + if (null != socket){ + socket.close(); + } + socket = null; + } catch (IOException e) { + log.error("SocketClient close Exception:" + e.getMessage()); + } } - public static void main(String[] args) { - BarcodeThread barcodeThread = new BarcodeThread(); - boolean connect = barcodeThread.connect(); - System.out.println(connect); + @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 || !socket.isConnected() || socket.isClosed() || connCount > 120) { + connect(); + connCount = 0; + return null; + } + socket.setSoTimeout(timeOut); + byte[] bytes = new byte[bufferSize]; + int len = dataInputStream.read(bytes); + byte[] tempBytes = null; + if (len > 0) { + tempBytes = new byte[len]; + System.arraycopy(bytes, 0, tempBytes, 0, len); + } else { + connect(); + } + return tempBytes; + } + + } -- Gitblit v1.9.1