一、UDP

  UDP的全称是User Datagram Protocol(用户数据报协议),是一种无连接的不安全的传输协议,

  传输数据时发送方和接收方无需建立连接,所以是不安全的。

  发送时不建立连接直接发送,发送后不关注接受方能否接到。UDP只负责发出去,后续的事情与之无关。

  1)、使用UDP发送和接受数据的过程:

  1接收数据:

    1.1创建数据包实例,用于接收数据。(指定接收方IP,端口)

    1.2创建接收容器

    1.3将接收容器封装成包

    1.4接收包

    1.5处理包(可以看做拆包,将包中数据拿出来)

    1.6释放资源

  2.发送数据

    2.1创建数据报实例,用于发送数据。(指定发送IP,端口)

    2.2创建发送资源

    2.3将发送资源封装成包(包加上发送目的地,端口)

    2.4发送包

    2.5释放资源

  2)、DatagramSocket & DatagramPacket

    java中将UDP封装成DatagramSocket类,用于发送和接收数据报。

    2.1构造方法:

    DatagramSocket(int port)//创建数据报,并绑定到本地主机的指定端口

    DatagramSocket(int port, InetAddress laddr)//创建数据报,绑定到指定地址的指定端口

    2.2主要方法

    void send(DatagramPacket p)//发送数据包
    void receive(DatagramPacket p)//接收数据包

  

    数据需要打包后才能发送,而接收数据也是以包的形式接收,java中使用DatagramPacket将数据打包。

    构造方法:

    DatagramPacket(byte[] buf, int length)//构造接收数据包及其长度,(设置接收数据包)

    DatagramPacket(byte[] buf, int length, InetAddress address, int port)//构造一个数据包,指定发送主机及端口信息(设置发送数据包)

    主要方法:

    int getLength()//返回要发送的或者要接受的数据长度

    byte[] getData()//获取发生或接受的数据,相当于拆包,获取包内数据。

Server:(接收数据) 

import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.net.SocketException; public class Server {
public static void main(String[] args) throws IOException {
DatagramSocket server = new DatagramSocket(8888,InetAddress.getByName("localhost"));
byte[] r = new byte[1024];//接收容器
DatagramPacket packet = new DatagramPacket(r,r.length);//打包
server.receive(packet);//接收包
System.out.println(new String(packet.getData(),0,packet.getLength()));//拆包并解析包
server.close();
}
}

Client:(发送数据)   

import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.net.SocketException;
import java.net.UnknownHostException; public class Client { public static void main(String[] args) throws IOException {
// TODO Auto-generated method stub
DatagramSocket client = new DatagramSocket(8887,InetAddress.getByName("localhost"));
String msg = "hello udp";
byte[] b_msg = msg.getBytes();//数据-->字节
     //打包,并加上目的地信息
DatagramPacket packet = new DatagramPacket(b_msg,b_msg.length,InetAddress.getByName("localhost"),8888);
client.send(packet);//发送包
client.close();//释放资源
}
}
运行结果:
hello udp

先运行Server,Server会等待数据,之后运行Client发送数据,Server接收到数据后就会解析。

想象成寄快递1.东西准备好(准备数据),

      2.转换为固定格式(数据转换为字节)

      3.然后打包,包上贴快递单(邮寄的目的地(IP)和接收人(端口))

      4.然后发送,

      5.接收方接收

      6.然后拆快递(拆包)

      7.然后拿到东西。(字节转换数据)

  

  

上面的数据是字符串可以直接转换为字节,但如果有时候传输的数据不能直接转换为字节这时该怎么办呢?

这就要用到IO流的知识,主要使用ByteArrayStream(toByteArray()方法)、DataStream(WriteXxxx()方法)。

数据-->字节:

先将数据及其格式通过DataOutputStream写入ByteArrayOutputStream中,再通过ByteArrayOutputStream中的toByteArray()方法将的字节拿出。

字节-->数据:

将字节数组放入ByteArrayInputStream中,然后通过DataInputStream中的readXxx读取ByteArrayInputStream中字节数组,将其转换为对应数据类型。

Server:

import java.io.ByteArrayInputStream;
import java.io.DataInputStream;
import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress; public class Server {
public static void main(String[] args) throws IOException {
DatagramSocket server = new DatagramSocket(8888,InetAddress.getByName("localhost"));
byte[] r = new byte[1024];
DatagramPacket packet = new DatagramPacket(r,r.length);
server.receive(packet);
System.out.println(byteToDouble(packet.getData()));//字节转换为数组
server.close();
} public static double byteToDouble(byte[] b) throws IOException{
ByteArrayInputStream bis = new ByteArrayInputStream(b);//将字节放入ByteArratInputStream中
DataInputStream dis = new DataInputStream(bis);//通过dis读取bis中字节
double data = dis.readDouble();//通过dis.readXxxx读取bis中的字节数组。
return data;
}
}

Client:

import java.io.ByteArrayOutputStream;
import java.io.DataOutputStream;
import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress; public class Client { public static void main(String[] args) throws IOException {
// TODO Auto-generated method stub
DatagramSocket client = new DatagramSocket(8887,InetAddress.getByName("localhost"));
// String msg = "hello udp";
Double data = 9.1;
byte[] b_data = doubleToByte(data);//数据转换为字节
DatagramPacket packet = new DatagramPacket(b_data,b_data.length,InetAddress.getByName("localhost"),8888);
client.send(packet);
client.close();
} public static byte[] doubleToByte(double dou) throws IOException{
ByteArrayOutputStream bos = new ByteArrayOutputStream();//创建字节数组输入流
DataOutputStream dos = new DataOutputStream(bos);//通过dos想bos中写入
dos.writeDouble(dou);//通过dos中的write.Xxxx将dou写入bos中
dos.flush();
dos.close();
byte[] data = bos.toByteArray();//将bos中字节取出。
return data;
}
}
运行结果:
9.1

7.3(java学习笔记)网络编程之UDP的更多相关文章

  1. java学习之网络编程之echo程序

    服务端的实现 package com.gh.echo; import java.io.*; import java.net.*; /** * echo服务器程序 * 实现 不断接收字符串 ,然后返回一 ...

  2. java 25 - 4 网络编程之 UDP协议传输的代码优化

    UDP协议的输出端: /* UDP发送数据: A:创建Socket发送端对象 B:创建数据报包(把数据打包) C:调用Socket对象发送数据报包 D:释放资源(底层是IO流) */ public c ...

  3. java 25 - 4 网络编程之 UDP协议传输思路

    UDP传输 两个类:DatagramSocket与DatagramPacket(具体看API) A:建立发送端,接收端. B:建立数据包. C:调用Socket的发送接收方法. D:关闭Socket. ...

  4. Java网络编程之UDP

    Java网络编程之UDP 一.C/S架构中UDP网络通信流程 ①创建DatagramSocket与DatagramPacket对象 ②建立发送端,接收端 ③建立数据包 ④调用Socket的发送.接收方 ...

  5. 网络编程之UDP编程

    网络编程之UDP编程 UDP协议是一种不可靠的网络协议,它在通信的2端各建立一个Socket,但是这个Socket之间并没有虚拟链路,这2个Socket只是发送和接受数据的对象,Java提供了Data ...

  6. Java学习笔记-网络编程

    Java提供了网络编程,并且在实际中有着大量运用 网络编程 网络编程概述 网络模型 OSI参考模型 TCP/IP参考模型 网络通讯要素 IP地址 端口号 传输协议 网络参考模型 网络通讯要素 IP地址 ...

  7. java网络编程之UDP通讯

    详细介绍了java中的网络通信机制,尤其是UDP协议,通过对UDP的基本使用进行举例说明如何使用UDP进行数据的发送接收,并举了两个小demo说明UDP的使用注意事项. UDP协议原理图解: UDP协 ...

  8. Java 学习笔记 网络编程 使用Socket传输文件 CS模式

    Socket的简单认识 Socket是一种面向连接的通信协议,Socket应用程序是一种C/S(Client端/Server端)结构的应用程序 Socket是两台机器间通信的端点. Socket是连接 ...

  9. java 26 - 9 网络编程之 TCP协议多用户上传文件

    TCP实现多用户上传文件: 需要同时给多用户上传文件,这样就得用多线程来实现. 实际上,这样的话,上传的先后顺序和速度就跟客户端的带宽有关:带宽够,就容易抢占到线程的执行权: 首先,创建个线程类:(这 ...

随机推荐

  1. sls文件

    http://www.ituring.com.cn/article/42238 只是数据而已 深入学习之前,明白SLS文件只是结构化的数据而已是很有用的.看懂和编写SLS文件不需要理解这一点,但会让你 ...

  2. [CVPR2017]Online Video Object Segmentation via Convolutional Trident Network

    基于三端卷积网络的在线视频目标分割 针对半监督视频目标分割任务,作者采取了和MaskTrace类似的思路,以optical flow为主. 本文亮点在于: 1. 使用共享backbone,三输出的自编 ...

  3. 解决设置了background-size: cover; 但是图片在ios下显示不完整的问题

    设置 background-size: % 99.9%:

  4. React.js基础知识

    一. react.js的基本使用方法 (1)快速使用,hello world <div id="app"></div> <script src=&qu ...

  5. O(n^2)以及O(nlogn)时间复杂度的排序算法

    O(n^2)的算法 都是做的升序. 简单选择排序 思路:每次选择还未排序的区间的最小值和未排序区间的第一个值交换. function selectSort(arr){ for(let i = 0; i ...

  6. 如何打开小米,oppo,华为等手机的系统应用的指定页面

    如题,拿Oppo 手机做个示例,小米 华为也是如此. 在编写Android应用的时候,我们经常会有这样的需求,我们想直接打开系统应用的某个页面.比如在Oppo R9 手机上我们想打开某个应用的通知管理 ...

  7. bzoj 1942 斜率优化DP

    首先我们贪心的考虑,对于某一天来说,我们只有3中策略,第一种为不做任何行动,这时的答案与前一天相同,第二种为将自己的钱全部换成a,b货币,因为如果换a,b货币,代表在之后的某一天卖出去后会赚钱,那么当 ...

  8. docker push 镜像到本地仓库

    root@ubuntu:# uname -a Linux ubuntu --generic #-Ubuntu SMP Mon Feb :: UTC x86_64 x86_64 x86_64 GNU/L ...

  9. kvm的vmcall

    这几个接口的区别在于参数个数的不用,本质是一样的.挑个参数最多的看下: static inline long kvm_hypercall4(unsigned int nr, unsigned long ...

  10. JSP 基础之 JSTL <c:choose>用法 if else

    <c:choose> <c:when test="${condition1}"> condition1为true </c:when> <c ...