• java学习 网络编程 tcp


    有客户端和服务端,使用tcp传输 day26  27

    //客户端发数据到服务端
    /*
    * Tcp传输,客户端建立的过程。
    * 1,创建tcp客户端socket服务。使用的是Socket对象。
    * 建议该对象一创建就明确目的地。要连接的主机。
    * 2,如果连接建立成功,说明数据传输通道已建立。
    * 该通道就是socket流 ,是底层建立好的。 既然是流,说明这里既有输入,又有输出。
    * 想要输入或者输出流对象,可以找Socket来获取。
    * 可以通过getOutputStream(),和getInputStream()来获取两个字节流。
    * 3,使用输出流,将数据写出。
    * 4,关闭资源。
    */

    Socket socket = new Socket("192.168.1.100",10002);
    OutputStream out = socket.getOutputStream();
    out.write("tcp演示:哥们又来了!".getBytes());
    //读取服务端返回的数据,使用socket读取流。
    InputStream in = socket.getInputStream();
    byte[] buf = new byte[1024];
    int len = in.read(buf);
    String text = new String(buf,0,len);
    System.out.println(text);
    //关闭资源。
    socket.close();

    // 服务端接收客户端发送过来的数据,并打印在控制台上。
    /*
    * 建立tcp服务端的思路:
    * 1,创建服务端socket服务。通过ServerSocket对象。
    * 2,服务端必须对外提供一个端口,否则客户端无法连接。
    * 3,获取连接过来的客户端对象。
    * 4,通过客户端对象获取socket流读取客户端发来的数据
    * 并打印在控制台上。
    * 5,关闭资源。关客户端,关服务端。
    */
    //1创建服务端对象。
    ServerSocket ss = new ServerSocket(10002);
    //2,获取连接过来的客户端对象。
    Socket s = ss.accept();
    String ip = s.getInetAddress().getHostAddress();
    //3,通过socket对象获取输入流,要读取客户端发来的数据
    InputStream in = s.getInputStream();
    byte[] buf = new byte[1024];
    int len = in.read(buf);         //in.read()方法是有返回值的,返回值就是你读取了多少个字节
    String text = new String(buf,0,len);
    System.out.println(ip+":"+text);
    //使用客户端socket对象的输出流给客户端返回数据
    OutputStream out = s.getOutputStream();
    out.write("收到".getBytes());
    s.close();
    ss.close();

    输出流可采用PrinterWriter 创建时如果有参数true时,会有行刷新。PrintWriter调用println()方法有行刷新

    PrintWriter out = new PrintWriter(s.getOutputStream(),true);

    out.println("上传成功");

    告诉服务端,客户端写完了。
    s.shutdownOutput();

  • 相关阅读:
    Hadoop脚本:自动搜集所有节点上的异常信息
    Hadoop脚本:重新初始化所有节点
    Hadoop入门:最应该看的几篇文章
    Hadoop脚本:用Streaming方式使用Hadoop
    [SaaS研究] SaaS在中国 / 中国的Salesforce / 阿里巴巴 / 阿里软件 [ 转 ]
    Hadoop常见问题与解决方法汇总
    Hadoop:你所不知道的一些相关项目
    Hadoop MapReduce 学习
    有多少项目准备和Hadoop比拼?
    开放源码的云计算平台:触手可及的云计算 [ 原 ]
  • 原文地址:https://www.cnblogs.com/doyi111/p/10643789.html
Copyright © 2020-2023  润新知