1. //服务端
    import com.hl.bluetooth.util.CRC16;
  2. import com.hl.bluetooth.util.FrameCheckFailedException;
  3. import com.hl.bluetooth.util.stream.StreamUtils;
  4. import com.hl.bluetooth.util.util;
  5. import lombok.SneakyThrows;
  6. import org.slf4j.Logger;
  7. import org.slf4j.LoggerFactory;
  8.  
  9. import java.io.*;
  10. import java.net.ServerSocket;
  11. import java.net.Socket;
  12. import java.nio.ByteBuffer;
  13. import java.util.Arrays;
  14.  
  15. /**
  16. * @author hwx
  17. * @date 2021/11/4
  18. */
  19. public class TcpServer extends ServerSocket {
  20.  
  21. private static final Logger logger = LoggerFactory.getLogger(TcpServer.class);
  22.  
  23. public TcpServer(int serverPort) throws IOException {
  24. super(serverPort);
  25. try {
  26. while (true) {
  27. Socket socket = accept();
  28. new ServerThread(socket);
  29. }
  30. } catch (Exception e) {
  31. logger.error("tcp服务器已停止监听");
  32. } finally {
  33. close();
  34. }
  35. }
  36.  
  37. class ServerThread extends Thread /*建立服务端线程*/ {
  38. private Socket socket;
  39. private DataInputStream inputStream;
  40. private InputStream in;
  41. private InputStream i;
  42. private byte[] bytes;
  43.  
  44. private DataOutputStream out;
  45.  
  46. public ServerThread(Socket s) throws Exception {
  47. logger.info("tcp服务器开始监听......");
  48. this.socket = s;
  49. in = socket.getInputStream();
  50. inputStream = new DataInputStream(in);
  51. /* in = new BufferedReader(new InputStreamReader(
  52. socket.getInputStream(), "GB2312")); *//*国标码*/
  53. out = new DataOutputStream(socket.getOutputStream());
  54. String str = s.getInetAddress().getHostAddress();
  55. StreamUtils.setOutputStream(s.getInetAddress().getHostAddress(), new DataOutputStream(socket.getOutputStream()));
  56. StreamUtils.setInputStream(s.getInetAddress().getHostAddress(), new DataInputStream(socket.getInputStream()));
  57.  
  58. // 开始线程
  59. start();
  60. }
  61.  
  62. @SneakyThrows
  63. @Override
  64. public void run() {
  65. try {
              Scanner scanner = new Scanner(System.in);// 装饰标准输入流,用于从控制台输入
  66. while (true) {

              String send = scanner.nextLine();//读取控制台输入的内容
              System.out.println("客户端:" + send);//输出键盘输出内容提示 ,也就是客户端向服务器端发送的消息
              // 把从控制台得到的信息传送给服务器
              out.writeUTF("客户端:" + send);//将客户端的信息传递给服务器
              String accpet = in.readUTF();// 读取来自服务器的信息
              System.out.println(accpet);//输出来自服务器的信息

  1. }
  2. } catch (Exception e) {
  3. logger.error(socket.getInetAddress().getHostAddress() + "连接断开-----" + e.getMessage(), e);
  4. } finally {
  5. DataOutputStream outputStream = StreamUtils.getOutputStream(socket.getInetAddress().getHostAddress());
  6. outputStream.close();
  7. inputStream.close();
  8. socket.close();
  9. }
  10.  
  11. }
  1. //客户端
    import java.io.*;
  2. import java.net.Socket;
  3. import java.net.UnknownHostException;
  4.  
  5. /**
  6. * @author hwx
  7. * @date 2021/11/4
  8. */
  9. public class TcpClient {
  10. /**
  11. * 定义socket连接
  12. */
  13. private Socket socket;
  14. private DataInputStream inputStream;
  15. /**
  16. * 打印到文本输出流
  17. */
  18. private PrintWriter writer;
  19. private OutputStream outputStream;
  20.  
  21. public TcpClient(int serverPort) { /*定义客户端端口号*/
  22. try { /*抛异常*/
  23. socket = new Socket("192.168.153.202", serverPort);
  24. inputStream = new DataInputStream(
  25. /*标准输入输出流*/
  26. socket.getInputStream());
  27. writer = new PrintWriter(socket.getOutputStream());
  28. outputStream = socket.getOutputStream();
  29. while (true) {
  30. BufferedReader in = new BufferedReader(
  31. new InputStreamReader(System.in));
  32. String message = in.readLine();if ("finish".equals(message)) {
  33. System.out.println("服务器已停止监听");
  34. break;
  35. }
  36. }
  37. outputStream.close();
  38. writer.close();
  39. inputStream.close(); /*关闭流*/
  40. socket.close();
  41.  
  42. } catch (UnknownHostException ex) {
  43. ex.printStackTrace();
  44. } catch (IOException ex) {
  45. ex.printStackTrace(); /*在命令行打印异常信息在程序中出错的位置及原因*/
  46. }
  47. }
  48.  
  49. }

java实现 TCP通信的更多相关文章

  1. Java 之 TCP 通信程序

    一.概述 TCP 通信能实现两台计算机之间的数据交互,通信的两端,要严格区分为客户端(Client)与服务端(Server). 两端通信时步骤: 1.服务端程序,需要事先启动,等待客户端的连接: 2. ...

  2. java实现TCP通信(带界面)

    服务端: package NetWork; import java.io.*;import java.net.*;import java.awt.event.*;import java.awt.*;i ...

  3. java 网络编程之TCP通信和简单的文件上传功能

    */ .hljs { display: block; overflow-x: auto; padding: 0.5em; color: #333; background: #f8f8f8; } .hl ...

  4. TCP通信实现对接硬件发送与接收十六进制数据 & int与byte的转换原理 & java中正负数的表示

    今天收到的一份需求任务是对接硬件,TCP通信,并给出通信端口与数据包格式,如下: 1.首先编写了一个简单的十六进制转byte[]数组与byte[]转换16进制字符串的两个方法,如下: /** * 将十 ...

  5. 【Java】同步阻塞式(BIO)TCP通信

    TCP BIO 背景 网络编程的基本模型是Clien/Server模型,也就是两个进程之间进行相互通信,其中服务端提供位置信息(绑定的IP地址和监听端口),客户端通过连接操作向服务端监听的地址发起连接 ...

  6. Java网络编程之TCP通信

    一.概述 Socket类是Java执行客户端TCP操作的基础类,这个类本身使用代码通过主机操作系统的本地TCP栈进行通信.Socket类的方法会建立和销毁连接,设置各种Socket选项. Server ...

  7. 【Java TCP/IP Socket】深入剖析socket——TCP通信中由于底层队列填满而造成的死锁问题(含代码)

    基础准备 首先需要明白数据传输的底层实现机制,在http://blog.csdn.net/ns_code/article/details/15813809这篇博客中有详细的介绍,在上面的博客中,我们提 ...

  8. 【Java TCP/IP Socket】基于NIO的TCP通信(含代码)

    NIO主要原理及使用 NIO采取通道(Channel)和缓冲区(Buffer)来传输和保存数据,它是非阻塞式的I/O,即在等待连接.读写数据(这些都是在一线程以客户端的程序中会阻塞线程的操作)的时候, ...

  9. 实验09——java基于TCP实现客户端与服务端通信

    TCP通信         需要先创建连接 - 并且在创建连接的过程中 需要经过三次握手        底层通过 流 发送数据 数据没有大小限制        可靠的传输机制 - 丢包重发 包的顺序的 ...

随机推荐

  1. redis的使用场景和优缺点

    使用场景和优缺点: 2 Redis用来做什么? 通常局限点来说,Redis也以消息队列的形式存在,作为内嵌的List存在,满足实时的高并发需求.而通常在一个电商类型的数据处理过程之中,有关商品,热销, ...

  2. Kafka connector (kafka核心API)

    前言 Kafka Connect是一个用于将数据流输入和输出Kafka的框架.Confluent平台附带了几个内置connector,可以使用这些connector进行关系数据库或HDFS等常用系统到 ...

  3. 通过HTML+CSS+Javascript实现向下滚动滚动条出现导航栏并出现回到顶部按钮点击按钮回到顶部(一)

    回到顶部实例一 效果:默认隐藏导航栏,当滚动条滚到超过300px后导航栏和按钮出现,点击回到顶部按钮回到顶部,并隐藏导航栏和按钮(导航栏和按钮都是固定定位) <!doctype html> ...

  4. 常用字符的ASCII码

    字母    ASCII码      十进制数 0         00110000      48 9           00111001        57 A          01000001 ...

  5. 流言粉碎机:JAVA使用 try catch 会严重影响性能

    目录 一.JVM 异常处理逻辑 二.关于JVM的编译优化 1. 分层编译 2. 即时编译器 1. 解释模式 2. 编译模式 3. 提前编译器:jaotc 三.关于测试的约束 执行用时统计 编译器优化的 ...

  6. Tomcat-IDEA整合Tomcat服务器

    Tomcat(IDEA整合Tomcat服务器) 可以加多个版本tomcat

  7. python3 .format()函数

    Python 3.5.2实验 >>> print('{0},{1}'.format('kzc',18) ) kzc,18 >>> print('{},{}'.for ...

  8. 手把手教你用Strace诊断问题

    手把手教你用Strace诊断问题 发表于2015-10-16 早些年,如果你知道有个 strace 命令,就很牛了,而现在大家基本都知道 strace 了,如果你遇到性能问题求助别人,十有八九会建议你 ...

  9. tmux 入门教程

    tmux 本教程是基于ACWing的<Linux基础课>所做,希望大家支持ACWing 功能 分屏 当需要同时运行两个终端,并且进行比对着输入时,来回切换比较麻烦,就可以利用分屏 可以在一 ...

  10. CDNDrive 第一个版本发布 & 布客新知第二次备份完成

    CDNDrive 第一个版本发布,新适配五个图床 https://github.com/apachecn/CDNDrive 另外,布客新知第二次备份完成 TutorialsPoint:http://i ...