From ebdd75dca3413179ec8dfbc2d3d5aae3844144ee Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@163.com> Date: 星期四, 13 八月 2020 10:40:17 +0800 Subject: [PATCH] # --- src/main/java/com/zy/core/thread/BarcodeThread.java | 106 +++++++++++++++++++++++++++++++++++++++++++--------- 1 files changed, 87 insertions(+), 19 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..876c826 100644 --- a/src/main/java/com/zy/core/thread/BarcodeThread.java +++ b/src/main/java/com/zy/core/thread/BarcodeThread.java @@ -1,11 +1,16 @@ package com.zy.core.thread; -import HslCommunication.Core.Types.OperateResult; -import HslCommunication.Enthernet.SimplifyNet.NetSimplifyClient; import com.zy.core.Slave; import com.zy.core.ThreadHandler; 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; /** * 鏉$爜鎵弿浠嚎绋� @@ -17,7 +22,9 @@ private Slave slave; private String barcode; - private NetSimplifyClient netSimplifyClient; + private Socket socket; + private DataOutputStream dataOutputStream; + private DataInputStream dataInputStream; public BarcodeThread(Slave slave) { this.slave = slave; @@ -29,38 +36,99 @@ public void run() { while (true) { try { -// Task task = MessageQueue.poll(SlaveType.Barcode, slave.getId()); - barcode = "10001136"; - Thread.sleep(3000); + write("T".getBytes(), "T".length()); + byte[] read = read(11, 1000); + barcode = new String(read); + Thread.sleep(1000); } catch (Exception e) { e.printStackTrace(); } - } } @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(); + //socket.setKeepAlive(true); + 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()); + } catch (Exception e) { + socket = null; + log.error("socket connect error ip:"); + return false; } - return result; + 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; + } catch (IOException e) { + log.error("SocketClient close Exception:" + e.getMessage()); + } + log.debug("Exit Method:close()"); } - public static void main(String[] args) { - BarcodeThread barcodeThread = new BarcodeThread(); + public void write(byte[] msg, int len) throws IOException { + log.trace("dataOutputStream.write"); + dataOutputStream.write(msg, 0, len); + log.trace("dataOutputStream.flush"); + dataOutputStream.flush(); + } + + public byte[] read(int bufferSize, int timeOut) throws IOException { + socket.setSoTimeout(timeOut * 1000); + 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); + } + 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)); } } -- Gitblit v1.9.1