| | |
| | | import com.zy.common.utils.DateUtils; |
| | | import com.zy.common.utils.RedisUtil; |
| | | import com.zy.core.News; |
| | | import com.zy.core.enums.RedisKeyType; |
| | | import com.zy.core.model.DeviceCommandMsgModel; |
| | | import com.zy.core.model.DeviceMsgModel; |
| | | import com.zy.core.properties.DeviceConfig; |
| | |
| | | import com.zy.core.cache.OutputQueue; |
| | | import com.zy.core.enums.SlaveType; |
| | | import com.zy.core.thread.ShuttleThread; |
| | | import com.zy.core.utils.FakeDeviceUtils; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | |
| | | import java.io.*; |
| | |
| | | return true; |
| | | } |
| | | |
| | | InetAddress address = InetAddress.getByName(deviceConfig.getIp()); |
| | | if (address.isReachable(10000)) { |
| | | Socket deviceSocket = new Socket(deviceConfig.getIp(), deviceConfig.getPort()); |
| | | deviceSocket.setSoTimeout(10000); |
| | | deviceSocket.setKeepAlive(true); |
| | | |
| | | if (this.deviceConfig.getFake()) { |
| | | //虚拟设备需要上报设备信息 |
| | | HashMap<String, Object> map = new HashMap<>(); |
| | | map.put("msgType", "fakeDeviceFirstConnect"); |
| | | map.put("deviceConfig", this.deviceConfig); |
| | | |
| | | // 获取输出流 |
| | | OutputStreamWriter writer = new OutputStreamWriter(deviceSocket.getOutputStream()); |
| | | writer.write(JSON.toJSONString(map) + "\r\n"); |
| | | writer.flush(); |
| | | |
| | | // 获取输入流 |
| | | BufferedReader reader = new BufferedReader(new InputStreamReader(deviceSocket.getInputStream())); |
| | | // 读取服务器的响应 |
| | | StringBuffer sb = new StringBuffer(); |
| | | char[] chars = new char[2048];//缓冲区 |
| | | while (true) { |
| | | reader.read(chars); |
| | | String trim = new String(chars); |
| | | sb.append(trim); |
| | | if (trim.lastIndexOf("\r\n") != -1) { |
| | | break; |
| | | } |
| | | } |
| | | |
| | | JSONObject result = null; |
| | | try { |
| | | result = JSON.parseObject(sb.toString());//得到响应结果集 |
| | | }catch (Exception e){} |
| | | |
| | | if(result == null) { |
| | | return false; |
| | | } |
| | | |
| | | if(result.getInteger("deviceNo") != deviceConfig.getDeviceNo()) { |
| | | return false; |
| | | } |
| | | |
| | | if(!result.getString("status").equals("success")) { |
| | | return false; |
| | | } |
| | | |
| | | if(this.deviceConfig.getFake()) { |
| | | return fakeConnect(); |
| | | }else { |
| | | InetAddress address = InetAddress.getByName(deviceConfig.getIp()); |
| | | if (address.isReachable(10000)) { |
| | | Socket deviceSocket = new Socket(deviceConfig.getIp(), deviceConfig.getPort()); |
| | | deviceSocket.setSoTimeout(10000); |
| | | deviceSocket.setKeepAlive(true); |
| | | this.socket = deviceSocket; |
| | | }else { |
| | | this.socket = deviceSocket; |
| | | log.info(MessageFormat.format("【{0}】四向穿梭车Socket链接成功 ===>> [id:{1}] [ip:{2}] [port:{3}]", DateUtils.convert(new Date()), deviceConfig.getDeviceNo(), deviceConfig.getIp(), deviceConfig.getPort())); |
| | | } |
| | | log.info(MessageFormat.format("【{0}】四向穿梭车Socket链接成功 ===>> [id:{1}] [ip:{2}] [port:{3}]", DateUtils.convert(new Date()), deviceConfig.getDeviceNo(), deviceConfig.getIp(), deviceConfig.getPort())); |
| | | } |
| | | } catch (Exception e) { |
| | | OutputQueue.SHUTTLE.offer(MessageFormat.format("【{0}】四向穿梭车Socket链接失败 ===>> [id:{1}] [ip:{2}] [port:{3}]", DateUtils.convert(new Date()), deviceConfig.getDeviceNo(), deviceConfig.getIp(), deviceConfig.getPort())); |
| | |
| | | return true; |
| | | } |
| | | |
| | | private boolean fakeConnect() { |
| | | try { |
| | | FakeDeviceUtils fakeDeviceUtils = SpringUtils.getBean(FakeDeviceUtils.class); |
| | | if(fakeDeviceUtils == null) { |
| | | return false; |
| | | } |
| | | |
| | | boolean applyResult = fakeDeviceUtils.applyShuttleConnect(deviceConfig.getDeviceNo()); |
| | | if(!applyResult) { |
| | | return false; |
| | | } |
| | | |
| | | InetAddress address = InetAddress.getByName(deviceConfig.getIp()); |
| | | if (address.isReachable(10000)) { |
| | | Socket deviceSocket = new Socket(deviceConfig.getIp(), deviceConfig.getPort()); |
| | | deviceSocket.setSoTimeout(10000); |
| | | deviceSocket.setKeepAlive(true); |
| | | |
| | | //虚拟设备需要上报设备信息 |
| | | HashMap<String, Object> map = new HashMap<>(); |
| | | map.put("msgType", "fakeDeviceFirstConnect"); |
| | | map.put("deviceConfig", this.deviceConfig); |
| | | |
| | | // 获取输出流 |
| | | OutputStreamWriter writer = new OutputStreamWriter(deviceSocket.getOutputStream()); |
| | | writer.write(JSON.toJSONString(map) + "\r\n"); |
| | | writer.flush(); |
| | | |
| | | // 获取输入流 |
| | | BufferedReader reader = new BufferedReader(new InputStreamReader(deviceSocket.getInputStream())); |
| | | // 读取服务器的响应 |
| | | StringBuffer sb = new StringBuffer(); |
| | | char[] chars = new char[2048];//缓冲区 |
| | | while (true) { |
| | | reader.read(chars); |
| | | String trim = new String(chars); |
| | | sb.append(trim); |
| | | if (trim.lastIndexOf("\r\n") != -1) { |
| | | break; |
| | | } |
| | | } |
| | | |
| | | JSONObject result = null; |
| | | try { |
| | | result = JSON.parseObject(sb.toString());//得到响应结果集 |
| | | }catch (Exception e){} |
| | | |
| | | if(result == null) { |
| | | return false; |
| | | } |
| | | |
| | | if(result.getInteger("deviceNo") != deviceConfig.getDeviceNo()) { |
| | | return false; |
| | | } |
| | | |
| | | if(!result.getString("status").equals("success")) { |
| | | return false; |
| | | } |
| | | |
| | | this.socket = deviceSocket; |
| | | |
| | | log.info(MessageFormat.format("【{0}】四向穿梭车Socket链接成功 ===>> [id:{1}] [ip:{2}] [port:{3}]", DateUtils.convert(new Date()), deviceConfig.getDeviceNo(), deviceConfig.getIp(), deviceConfig.getPort())); |
| | | return true; |
| | | } |
| | | }catch (Exception e){ |
| | | e.printStackTrace(); |
| | | } |
| | | return false; |
| | | } |
| | | |
| | | @Override |
| | | public void close() { |
| | | |