UDP数据交互

服务器端:

public static void main(String[] args) {
        // 1、创建一个服务器 套接字
        DatagramSocket server = null;
        try {
            server = new DatagramSocket(18899);
            // 2、定一个字节 数组来接收数据
            byte[] data = new byte[1024];
            // 3、定义一个数据包对象
            DatagramPacket recePacket = new DatagramPacket(data, data.length);
            // 4、阻塞式的接收
            server.receive(recePacket);
            System.out.println("*************客户端来消息了***********");
            // 5、打印消息
            String msg = new String(recePacket.getData(), 0,
                    recePacket.getLength());
            // 6、向发过来的那个客户端回复点消息
            InetAddress addr = recePacket.getAddress(); // 客户端的IP
            int port = recePacket.getPort(); // 客户端的端口号
            System.out.println(addr.toString()+"-"+port+":客户端发过来的消息是:" + msg);
            // 7、回复 :收到了
            String str = "收到了";
            byte[] buf = str.getBytes();
            // 8、创建一个发送的报文
            DatagramPacket sendPacket = new DatagramPacket(buf, buf.length,
                    addr, port);
            server.send(sendPacket);
        } catch (SocketException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if (server != null) {
                server.close();
            }
        }
    }

客户端:

public static void main(String[] args) {
        //创建一个客户端
        DatagramSocket client=null;
        try {
            client=new DatagramSocket();
            //向服务器发送消息
            String str="客户端测试消息!";
            byte[] buf=str.getBytes();
            //3、定义服务器的IP
            InetAddress addr=InetAddress.getByName("192.168.16.171");
            //4、创建一个数据报对象
            DatagramPacket sendPacket=new DatagramPacket(buf, buf.length, addr, 18899);
            //5、发送消息
            client.send(sendPacket);
            //6、客户端等待服务器发送过来的消息
            byte[] data=new byte[1024];
            DatagramPacket recePacket=new DatagramPacket(data, data.length);
            //7、客户阻止式的接收消息
            client.receive(recePacket);
            //8、把消息转换成字符串
            String msg=new String(recePacket.getData(),0,recePacket.getLength()  );
            System.out.println("服务器回复的消息是:"+msg);
        } catch (SocketException e) {
            e.printStackTrace();
        } catch (UnknownHostException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }finally{
            if(client!=null){
                client.close();
            }
        }
    }
时间: 2024-10-27 19:07:39

UDP数据交互的相关文章

《TCP/IP详解》之二:流式数据交互

和UDP这种“滚珠”式的协议不同(一份数据就是一个udp packet),TCP以报文段的方式传递数据,其大小受网络链路的限制.在SYN报文段中互相通告最大报文段长(MSS).所以业务层交付的数据,会被TCP拆分/合并为合适的报文段(这也就是为嘛TCP数据跟水流似的,没有边界). 对于每个报文段而言,就很像UDP的“滚珠”了,不保证顺序.不保证到达.TCP要对收到的报文重新排序,再才交给应用层.发出一个报文段后,会启动一个定时器,等待对端ACK确认收到,否则将重传该报文.由于重传机制,报文段可能

X-Plane数据交互

要用X-Plane进行二次开发,免不了需要进行参数的传递,下面我们来看看与X-Plane进行数据交互都有哪些方式 一.X-Plane原生支持的通信方式 1.通过Plugin进行数据交互 2.通过UDP进行通信 XXXX\X-Plane 10\Instructions\Sending Data to X-Plane.rtf目录下TXT.rtf 文档. 二.第三方通信工具 1.GitHub上的开源项目 1)NASA的X-Plane Connect(https://github.com/nasa/XP

“ping”命令的原理就是向对方主机发送UDP数据包,HTTP在每次请求结束后都会主动释放连接,因此HTTP连接是一种“短连接”

Socket  是一套建立在TCP/IP协议上的接口不是一个协议 应用层:  HTTP  FTP  SMTP  Web 传输层:  在两个应用程序之间提供了逻辑而不是物理的通信(TCP  UDP) TCP  可靠的  面向连接的服务 UDP  不可靠的  无连接的服务 只要底层实现TCP IP协议  都可以用socket进行通信 1.TCP和UDP 1.1 TCP连接 TCP协议能为应用程序提供可靠的通信连接,使一台计算机发出的字节流无差错地发往网络上的其他计算机,对可靠性要求高的数据通信系统往

AJAX+REA实现前后台数据交互的加密解密

AJAX+REA实现前后台数据交互的加密解密 1.创建js文件Encryption.js /**  * 加密解密  */ /** RSA加密用 生成key */ function bodyRSA(){ /** 1024位的key参数写130,2014位的key参数写260 */ setMaxDigits(130); /** ajax 调用后台方法,取回公钥 */ var keyR ;     $.ajax({      url: "/GHGL/Key/pk",//请求后台的url,本例

IP包、TCP报文、UDP数据段格式的汇总

一.IP包格式 IP数据包是一种可变长分组,它由首部和数据负载两部分组成.首部长度一般为20-60字节(Byte),其中后40字节是可选的,长度不固定,前20字节格式为固定.数据负载部分的长度一般可变,整个IP数据包的最大长度为65535B. 1.版本号(Version) 长度为4位(bit),IP v4的值为0100,IP v6的值为0110. 2.首部长度 指的是IP包头长度,用4位(bit)表示,十进制值就是[0,15],一个IP包前20个字节是必有的,后40个字节根据情况可能有可能没有.

浅谈混合开发与Android,JS数据交互

本文是作者原创,如转载请注明出处! 一.概论 现在时代已经走过了移动互联网的超级火爆阶段,市场上移动开发人员已经趋于饱和,显然,只会原生APP的开发已不能满足市场的需求,随着H5的兴起与火爆,H5在原生APP中的使用越来越广泛,也就是我们常说的混合开发(Hybrid APP).最新很火的微信小程序相信大家都是知道的,实际上微信小程序加载的界面就是一个HTML5的界面,HTML5界面在一些电商类的APP中主要承担展示数据的作用,但是他的作用并不仅限于此,最起码js调用原生方法和原生调用js的方法是

Struts2基本使用(三)--数据交互

Struts2中的数据交互 在Struts2中我们不必再使用request.getParameter()这种方式来获取前台发送到服务器的参数. 我们可以在服务器端的Java类中直接声明一个和前台发送数据的同名变量即可,然后生成它的set/get方法即可以实现前后台数据的交互. 假如我们在前台页面中的表单如下: <form method="post" action="demo!register.action"> username:<input typ

004.原始套接字,拼接UDP数据包,通信

大致流程: 建立一个client端,一个server端,自己构建IP头和UDP头,写入数据(hello,world!)后通过原始套接字(SOCK_RAW)将包发出去. server端收到数据后,打印UDP数据并发送确认消息(yes),client收到yes后将其打印. 其中: client端IP:192.168.11.104 端口:8600 server端IP:192.168.11.105 端口:8686 注意事项: 1.运行原始套接字socket需要有root权限. 2.注意主机字节序和网络字

JavaScript模板引擎实现数据交互

经过1年的磨练,近期终于稍微明白到,前端是怎么做到企业要求的:数据交互. 1,ajax+json这个是必须学的,但没问题,我们可以通过这个博客来慢慢了解怎么回事? 2,可以通过JS框架和JS模板来实现,但最后还是要用到ajax+json的. 注意:个人建议 假如项目页面数量是少于50-100个的,那么推荐使用JS模板:如果大于100个的用JS框架.各有各优势嘛. 今晚的博客分几次写完,看到这句话删除就证明已经写完了. 先分享JS模板的内容:我这次推荐使用百度的模板引擎,因为他比腾讯的art运行速