OSI 7层参考模型

物理层 --> 数据链路层 --> 网络层 --> 传输层 --> 会话层 --> 表示层 --> 应用层

按此顺序称为拆包,反之为封包。

TCP/IP参考模型

主机至网络层 --> 网际层 --> 传输层 --> 应用层

IP地址:127.0.0.1默认IP,主机名是localhost,每台PC都有的

端口号:应用程序的标识

传输协议:TCP/UDP

  • UDP:不需建立连接,速度快,不可靠,可能丢包,如对讲机。可以及时通信而不管对方在不在。
  • TCP:需要建立连接。三次握手,效率稍低,可靠。不在后,停止传输。比如打电话,下载数据。

Socket:数据在两个Socket之间通过I/O传输,通信两方都有。

TCP传输中:有一个客户端(client),有一个服务端(server),两方传输经过Socket。Socket是底层建立好了的,既可以输入又可以输出。

UDP传输例子

发送端

// 发送端
package Test;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.net.SocketException;
// 实现Runnable并覆盖run方法实现多线程
public class Send implements Runnable {
    private DatagramSocket ds;
    // 发送端和接收端都有各自的Socket来传输
    public Send(DatagramSocket ds) {
        this.ds = ds;
    }

    @Override
    public void run() {
        System.out.println("发送端启动");

        try {
          // 从键盘读入
            BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
            String line;
            while ((line = br.readLine()) != null) {
              // 读到的字符变成字节数组
                byte[] buf = line.getBytes();
              // 数据打包,传入ip地址和端口
                DatagramPacket dp = new DatagramPacket(buf, buf.length, InetAddress.getByName("10.175.214.114"), 10005);
              // 通过Socket传输数据包
                ds.send(dp);
              // 发送端输入88,就下线
                if (line.equals("88")) {
                    System.out.println("退出聊天");
                    break;
                }
            }
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            ds.close();
        }

    }
}

接收端

package Test;

import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.SocketException;

public class Rec implements Runnable {
    private DatagramSocket ds;

    public Rec(DatagramSocket ds) {
        this.ds = ds;
    }

    @Override
    public void run() {
        System.out.println("接收端启动");

        try {
            while (true) {
                byte[] buf = new byte[1024];
                DatagramPacket dp = new DatagramPacket(buf, buf.length);
              // 这个Socket指定端口号,就能收到发送端发过来的数据
                ds.receive(dp); // 阻塞式的,等待

                String ip = dp.getAddress().getHostAddress();
                int port = dp.getPort();
                String text = new String(dp.getData(), 0, dp.getLength());
                System.out.println(ip + ":" + port + ":" + text);
                if (text.equals("88")) {
                    System.out.println(ip + ": 退出聊天室");
                }
            }
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            ds.close();
        }
    }
}

运行试试

package Test;

import java.net.DatagramSocket;
import java.net.SocketException;

public class UDPDemo {
    public static void main(String[] args) throws SocketException {
      // 接收端和发送端有各自的Socket
        DatagramSocket se = new DatagramSocket();
        DatagramSocket re = new DatagramSocket(10005);
        new Thread(new Rec(re)).start();
        new Thread(new Send(se)).start();
    }
}

TCP传输例子

客户端

package Test;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.net.Socket;

public class TransClient {
    public static void main(String[] args) throws IOException {
        Socket s = new Socket("10.175.160.121", 10003);
        // 读取键盘输入
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        // 获取socket输出流,写给服务端
        PrintWriter out = new PrintWriter(s.getOutputStream(), true);

        String line;
        // socket输入流,读取服务端发来的
        BufferedReader bufIn = new BufferedReader(new InputStreamReader(s.getInputStream()));
      // 从键盘读取后写给服务端
        while ((line = br.readLine()) != null) {
            if (line.equals("over"))
                break;
            out.println(line);
            // 读取服务端发回的大写字母
            String uper = bufIn.readLine();
            System.out.println(uper);
        }
        s.close();
    }
}

服务端

package Test;

import java.io.*;
import java.net.ServerSocket;
import java.net.Socket;

public class TransServer {
    public static void main(String[] args) throws IOException {
        ServerSocket ss = new ServerSocket(10003);
        // 接收从客户端发来的socket
        Socket socket = ss.accept();
        // 获取ip
        String ip = socket.getInetAddress().getHostAddress();
        // 获取socket读取流
        BufferedReader bufr = new BufferedReader(new InputStreamReader(socket.getInputStream()));
        // socket输出流,将大写后的写到客户端
        PrintWriter out = new PrintWriter(socket.getOutputStream(), true);
        String line;
        while ((line=bufr.readLine()) != null) {
          // 服务端打印从客户端发来的数据
            System.out.println(line);
          // 服务端发送给客户端转化大写后的数据
            out.println(line.toUpperCase());
        }
        socket.close();
        ss.close();
    }
}

by @sunhaiyu

2016.1.13

Java基础之TCP与UDP的更多相关文章

  1. java学习之tcp与udp的实现

    package com.gh.socket; import java.io.BufferedReader; import java.io.IOException; import java.io.Inp ...

  2. JAVA基础知识|TCP/IP协议

    虽然写代码也有一定的年头了,但是对于一些基础概念,还是很模糊.这在后来的学习过程中,带来了很大的痛苦,所以痛定思痛,决心重新学习这些概念.并把自己的理解和查询的资料做一些整合,便于以后查阅! 一.什么 ...

  3. 计算机网络基础:TCP和UDP

    UDP(用户数据报协议) 应用场景:一个数据包就能完成数据通信:不需要建立会话和流量控制:多播.广播:是一种不可靠传输.(例如QQ聊天,屏幕广播) UDP协议特点: UDP是无连接的,即发送数据之前不 ...

  4. 【JAVA网络流之TCP与UDP 】

    一.ServerSocket java.lang.Object |-java.net.ServerSocket 有子类SSLServerSocket. 此类实现服务器套接字.服务器套接字等待请求通过网 ...

  5. java基础篇---网络编程(UDP程序设计)

    UDP程序设计 在TCP的索引操作都必须建立可靠地连接,这样一来肯定会浪费大量的系统性能,为了减少这种开销,在网络中又提供了另外一种传输协议---UDP,不可靠的连接,这种协议在各个聊天工具中被广泛的 ...

  6. Java中的TCP/UDP网络通信编程

    127.0.0.1是回路地址,用于测试,相当于localhost本机地址,没有网卡,不设DNS都可以访问. 端口地址在0~65535之间,其中0~1023之间的端口是用于一些知名的网络服务和应用,用户 ...

  7. JAVA基础知识|Socket

    一.什么是Socket? Socket本身并不是协议,是一套完成TCP.UDP协议的调用接口(API),通过socket我们才能使用TCP/IP协议(JAVA基础知识|TCP/IP协议).Socket ...

  8. 【Python网络编程】利用Python进行TCP、UDP套接字编程

    之前实现了Java版本的TCP和UDP套接字编程的例子,于是决定结合Python的学习做一个Python版本的套接字编程实验. 流程如下: 1.一台客户机从其标准输入(键盘)读入一行字符,并通过其套接 ...

  9. JAVA基础学习day24--Socket基础一UDP与TCP的基本使用

    一.网络模型 1.1.OIS参考模型 1.2.TCP/IP参考模型 1.3.网络通讯要素 IP地址:IPV4/IPV6 端口号:0-65535,一般0-1024,都被系统占用,mysql:3306,o ...

随机推荐

  1. webpack3新特性介绍

    6月20号webpack推出了3.0版本,官方也发布了公告.根据公告介绍,webpack团队将未来版本的改动聚焦在社区提出的功能需求,同时将保持一个快速.稳定的发布节奏.本文主要依据公告内容,简单介绍 ...

  2. kaggle Titanic心得

    Titanic是kaggle上一个练手的比赛,kaggle平台提供一部分人的特征,以及是否遇难,目的是预测另一部分人是否遇难.目前抽工作之余,断断续续弄了点,成绩为0.79426.在这个比赛过程中,接 ...

  3. 类型转换之 PropertyEditorSupport类

    这个类可以用于自定义的类型转换, 子类继承这个类之后可以重写子类的方法 ,其中比较重要的是setAsText和setValue方法,setAsText 子自己的方式处理转换,setValue将转换的结 ...

  4. Example017简单的下拉框

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. Java多线程(二) —— 线程安全、线程同步、线程间通信(含面试题集)

    一.线程安全 多个线程在执行同一段代码的时候,每次的执行结果和单线程执行的结果都是一样的,不存在执行结果的二义性,就可以称作是线程安全的. 讲到线程安全问题,其实是指多线程环境下对共享资源的访问可能会 ...

  6. MySQL实例

    建表实例: CREATE TABLE command_content( ID ) PRIMARY KEY NOT NULL AUTO_INCREMENT, CONTENT ), COMMAND_ID ...

  7. 在两个ASP.NET页面之间传递变量【转】

    ASP.NET提供了事件驱动编程模型,使开发者简化了应用程序的总体设计,但是这个也造成了它固有的一些问题,例如,在传统的ASP里,我们可以通过使用POST方法很容易地实现页面间传递变量,同样的事情,在 ...

  8. H3CNE实验:配置基于端口划分的VLAN及Trunk

    配置准备数据 | 设备名称 | IP地址 | VLAN网关 | 接口 | VLAN | |--------------|------------|-------------|----------|-- ...

  9. Java面试常考------------------------垃圾收集算法

    对于Java系学生而言,Java虚拟机中的垃圾收集算法是一个很重要的面试考点. 常用的垃圾收集算法主要可划分为以下三类: 1. 标记-清除算法 标记清除算法是一种比较简单的方法,直接标记内存中待回收的 ...

  10. centos 7 安装MySQL 5.6

    本文根据mysql的官方文档操作:https://dev.mysql.com/doc/mysql-yum-repo-quick-guide/en/ 由于Centos7 默认数据库是mariabd(网上 ...