package com.ra.car.utils;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.Socket;
import java.net.UnknownHostException;
import java.util.HashMap;
import java.util.Map; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import com.alibaba.fastjson.JSON; public class JavaTCPClient { protected static final Logger logger = LoggerFactory
.getLogger(JavaTCPClient.class); public static void main(String[] args) { try {/*
// 创建Socket对象
Socket socket = new Socket("a.mintaian.com", 8903); logger.info("11111111111111");
// 根据输入输出流和服务端连接
OutputStream outputStream = socket.getOutputStream();// 获取一个输出流,向服务端发送信息
logger.info("2222222222222222222");
PrintWriter printWriter = new PrintWriter(outputStream);// 将输出流包装成打印流
logger.info("3333333333333333333");
printWriter.print("服务端你好,我是客户1,这是我的第"+i+"次请求");
logger.info("444444444444444");
printWriter.flush();
socket.shutdownOutput();// 关闭输出流
logger.info("55555555555");
InputStream inputStream = socket.getInputStream();// 获取一个输入流,接收服务端的信息
logger.info("666666666666666666");
InputStreamReader inputStreamReader = new InputStreamReader(
inputStream);// 包装成字符流,提高效率
logger.info("777777777777777777");
BufferedReader bufferedReader = new BufferedReader(
inputStreamReader);// 缓冲区
logger.info("888888888888888888888");
String info = "";
String temp = null;// 临时变量
while ( (temp=bufferedReader.readLine())!= null) {
logger.info("9999999999999");
info += temp;
logger.info("客户端接收服务端发送信息:" + info+i);
}
logger.info("这是我的第"+i+"次调用!");
// 关闭相对应的资源
bufferedReader.close();
inputStream.close();
printWriter.close();
outputStream.close();
socket.close();
*/
Socket socket = new Socket("a.mintaian.com", 8903);
OutputStream os = socket.getOutputStream();
PrintWriter printWriter = new PrintWriter(os);
Map<String, Object> map=new HashMap<String, Object>();
Map<String, Object> m=new HashMap<String, Object>();
Map<String, Object> m1=new HashMap<String, Object>();
m1.put("subAlarmName", "左边虚线");
String[] str=new String[]{"1","2","3"};
m1.put("adasRes", str);
m.put("imei", "862465030008629");
m.put("deviceData", m1);
map.put("id", "862465030008629-1509354778289");
map.put("dataPackage", m);
map.put("isAdas", "1");
String msg = JSON.toJSONString(map)+"\n";
printWriter.write(msg);
printWriter.flush();
// socket.shutdownOutput();
InputStream is = socket.getInputStream();
InputStreamReader inputStreamReader = new InputStreamReader(
is);
BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
logger.info("发送的消息是:" + msg);
msg = null;
while ((msg = bufferedReader.readLine()) != null) {
logger.info("msg:" + msg);
}
logger.info("999999999999999999999999");
// 关闭相对应的资源
// bufferedReader.close();
// is.close();
// printWriter.close();
// os.close();
//socket.close();
} catch (UnknownHostException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}

基于TCP/IP协议的socket通讯client的更多相关文章

  1. 基于TCP/IP协议的socket通讯server

    思路: socket必须要随项目启动时启动,所以需用Spring自带的监听器,需要保持长连接,要用死循环,所以必须另外起线程,不能阻碍主线程运行 1.在项目的web.xml中配置listener &l ...

  2. http、TCP/IP协议与socket之间的区别

    http.TCP/IP协议与socket之间的区别     网络由下往上分为:  www.2cto.com   物理层--                       数据链路层-- 网络层--   ...

  3. 基于TCP/IP协议的C++网络编程(API函数版)

    源代码:http://download.csdn.net/detail/nuptboyzhb/4169959 基于TCP/IP协议的网络编程 定义变量——获得WINSOCK版本——加载WINSOCK库 ...

  4. http、TCP/IP协议与socket之间的区别(转载)

    http.TCP/IP协议与socket之间的区别  https://www.cnblogs.com/iOS-mt/p/4264675.html http.TCP/IP协议与socket之间的区别   ...

  5. c# TCP/IP协议利用Socket Client通信(只含客户端Demo)

    完全是基础,新手可以随意看看,大牛可以关闭浏览页了,哈哈. TCP/IP协议 TCP/IP是一系列网络通信协议的统称,其中最核心的两个协议是TCP和IP.TCP称为传输控制协议,IP称为互联网络协议. ...

  6. JAVA基础知识之网络编程——-TCP/IP协议,socket通信,服务器客户端通信demo

    OSI模型分层 OSI模型是指国际标准化组织(ISO)提出的开放系统互连参考模型(Open System Interconnection Reference Model,OSI/RM),它将网络分为七 ...

  7. TCP/IP协议与Socket

    1.计算机网络体系结构分层 OSI 参考模型注重"通信协议必要的功能是什么", TCP/IP 则更强调"在计算机上实现协议应该开发哪种程序". 2.TCP/IP ...

  8. 读书笔记——网络编程与开发技术(3)基于TCP/IP协议的网络编程相关知识

    TCP/IP协议:数据链路层,网络层,传输层,应用层. IP地址分为5类:A类.B类.C类.D类.E类. (A类.B类.C类是基本类,D类多用于多播传送,E类为保留类.) "*"表 ...

  9. 基于TCP/UDP协议的socket

    基于TCP协议的socket tcp是基于链接的,必须先启动服务端,然后再启动客户端去链接服务端 server端 import socket sk = socket.socket() sk.bind( ...

随机推荐

  1. 《Nginx - 指令》- Rewrite/If/Set

    一:Rewrite - 概述 - flag 作用 - last / break 实现对 Url 的重写. - redirect / permanent 实现对 Url 的重定向. - 使用范围 - s ...

  2. fork多线程进程时的坑(转)

    add : 在fork多线程的进程时,创建的子进程只包含一个线程,该线程是调用fork函数的那个线程的副本.在man fork中,有The child process is created with ...

  3. opencv图片拼接报错cv::Stitcher::ERR_NEED_MORE_IMGS (1)

    #include "opencv2/imgcodecs.hpp" #include "opencv2/highgui.hpp" #include "o ...

  4. oracle表空间的管理

    1.创建表空间 CREATE TABLESPACE TBS_TR_DATA DATAFILE '/oradata/rTBS_TR_DATA_001.dbf' SIZE 64G EXTENT MANAG ...

  5. env:bash \r解决

    1.brew install dos2unix2.find . -type f -exec dos2unix {} \;

  6. linux dmesg 查看系统故障信息

    dmesg 可以查看linux 内核信息 dmesg’命令设备故障的诊断是非常重要的.在‘dmesg’命令的帮助下进行硬件的连接或断开连接操作时,我们可以看到硬件的检测或者断开连接的信息.‘dmesg ...

  7. OC屏幕手势解锁

    感觉屏幕解锁好像很牛的样子,所以试着写了一个,代码很简单,手势用到的也是原生的,如果该代码帮助了你,记得点赞,如果该代码有任何问题,也可以随时和我联系.改代码用到的两张图片,是我随便找的两张,可以自行 ...

  8. kafka6 编写使用自定义分区的生产者

    一 客户端 在上一篇博客创建的简单生产者的基础上,进行两个修改操作: 1.新建SimplePartitioner.java,修改返回分区为1. SimplePartitioner.java代码如下 p ...

  9. TCP路由网络通信

    路由器 实现跨网段通信   路由器的工作原理是基于路由器中的路由表来实现数据包的路径选择 当路由器收到一个数据包的时候,会读取数据包的目标IP地址,根据目标IP地址来匹配路由表中的规则 单个路由器不会 ...

  10. Marathon1.5以上版本配置

    今天部署marathon还按照之前的方式配置,结果启动时报错 Dec 03 23:51:36 bigdata01.zetyun.com marathon[12311]: No start hook f ...