原文链接: http://blog.csdn.net/yudajun/article/details/8477149

udp 是一种网络通信协议,不需要客户端和服务器端建立连接即可进行通讯功能。相对于Tcp协议它有着tcp用很多优点,例如广播功能。udp的广播功能可以指定特定网段进行广播内容,而无需知道接收者是谁,只有接受者在广播范围内即可接收广播内容。其实基于这个功能可以实现一个局域网群聊室的功能。

udp广播发送有两种形式,

方式一:通过DatagramSocket实现

方式二:通过MulticastSocket 实现

方式一:demo;

1,数据发送端:

  1. import java.io.IOException;
  2. import java.net.DatagramPacket;
  3. import java.net.DatagramSocket;
  4. import java.net.InetAddress;
  5. import java.net.SocketException;
  6. import java.net.UnknownHostException;
  7. public class SendIP {
  8. public static void main(String args[]) {
  9. new SendIP().lanchApp();
  10. }
  11. private void lanchApp(){
  12. SendThread th=new SendThread();
  13. th.start();
  14. }
  15. private class SendThread extends Thread{
  16. @Override
  17. public void run() {
  18. while(true){
  19. try {
  20. Thread.sleep(1000);
  21. } catch (InterruptedException e) {
  22. e.printStackTrace();
  23. }
  24. try {
  25. BroadcastIP();
  26. } catch (Exception e) {
  27. e.printStackTrace();
  28. }
  29. }
  30. }
  31. private void BroadcastIP()throws Exception{
  32. DatagramSocket dgSocket=new DatagramSocket();
  33. byte b[]="你好,这是我发给你的消息".getBytes();
  34. DatagramPacket dgPacket=new DatagramPacket(b,b.length,InetAddress.getByName("255.255.255.255"),8989);
  35. dgSocket.send(dgPacket);
  36. dgSocket.close();
  37. System.out.println("send message is ok.");
  38. }
  39. }
  40. }

2,数据接收端:

  1. import java.net.DatagramPacket;
  2. import java.net.DatagramSocket;
  3. import java.net.SocketException;
  4. import java.util.regex.Matcher;
  5. import java.util.regex.Pattern;
  6. public class SearchIP{
  7. public static void main(String args[])throws Exception{
  8. new SearchIP().lanchApp();
  9. }
  10. private void lanchApp(){
  11. receiveThread th=new receiveThread();
  12. th.start();
  13. }
  14. private class receiveThread extends Thread{
  15. @Override
  16. public void run() {
  17. while(true){
  18. try {
  19. Thread.sleep(1000);
  20. } catch (InterruptedException e) {
  21. e.printStackTrace();
  22. }
  23. try {
  24. receiveIP();
  25. } catch (Exception e) {
  26. e.printStackTrace();
  27. }
  28. }
  29. }
  30. private void receiveIP() throws Exception{
  31. DatagramSocket dgSocket=new DatagramSocket(8989);
  32. byte[] by=new byte[1024];
  33. DatagramPacket packet=new DatagramPacket(by,by.length);
  34. dgSocket.receive(packet);
  35. String str=new String(packet.getData(),0,packet.getLength());
  36. System.out.println("接收到数据大小:"+str.length());
  37. System.out.println("接收到的数据为:"+str);
  38. dgSocket.close();
  39. System.out.println("recevied message is ok.");
  40. }
  41. }
  42. }

方式二demo;

1,数据发送端:

  1. import java.io.IOException;
  2. import java.net.DatagramPacket;
  3. import java.net.InetAddress;
  4. import java.net.MulticastSocket;
  5. public class MulBroadcast extends Thread{
  6. String info ="节目预告: 恭喜您中500w彩票了";
  7. int port =9898;
  8. InetAddress address;
  9. MulticastSocket socket;
  10. public MulBroadcast(){
  11. try{
  12. address=InetAddress.getByName("233.0.0.0");
  13. socket=new MulticastSocket(port);
  14. socket.setTimeToLive(1);
  15. socket.joinGroup(address);
  16. }catch(IOException e){
  17. e.printStackTrace();
  18. }
  19. }
  20. @Override   //最简单的方法也就是建立一个线程来运行
  21. public void run(){
  22. while(true){
  23. byte[] data=info.getBytes();
  24. DatagramPacket packet=new DatagramPacket(data,data.length,address,port);
  25. try {
  26. socket.send(packet);
  27. Thread.sleep(3000);
  28. } catch (Exception e) {
  29. e.printStackTrace();
  30. }
  31. System.out.println("消息已发送:");
  32. }
  33. }
  34. public static void main(String[] args){
  35. new MulBroadcast().start();
  36. }
  37. }

2,数据接收端:

  1. import java.io.IOException;
  2. import java.net.DatagramPacket;
  3. import java.net.InetAddress;
  4. import java.net.MulticastSocket;
  5. public class MulReceiverIP extends Thread{
  6. int port=9898;
  7. InetAddress group;
  8. MulticastSocket socket; //socket sends and receives the packet.
  9. DatagramPacket packet;
  10. byte[] buf=new byte[30];// If the message is longer than the packet's length, the message is truncated.
  11. public MulReceiverIP(){
  12. try {
  13. socket=new MulticastSocket(port);
  14. group=InetAddress.getByName("233.0.0.0");
  15. socket.joinGroup(group);    //加入广播组,加入group后,socket发送的数据报,可以被加入到group中的成员接收到。
  16. packet=new DatagramPacket(buf,buf.length);
  17. } catch (IOException e) {
  18. e.printStackTrace();
  19. }
  20. }
  21. @Override
  22. public void run(){
  23. while(true){
  24. try {
  25. socket.receive(packet);
  26. } catch (IOException e) {
  27. e.printStackTrace();
  28. }
  29. //      String message=new String(buf);
  30. String message=new String(packet.getData(),0,packet.getLength());//very important !!
  31. System.out.println("接受消息内容: "+message);
  32. }
  33. }
  34. public static void main(String[] args) {
  35. new MulReceiverIP().start();
  36. }
  37. }

java udp 广播的更多相关文章

  1. Android杂谈--HTC等手机接收不到UDP广播报文的解决方案

    最近遇到个问题,在android手机上发送UDP报文的时候,HTC等机型(测试用HTC new one)接收不到广播报文,而其他的samsung, huawei, xiaomi, nexus等等均没有 ...

  2. 通过UDP广播实现Android局域网Peer Discovering

    本文是对个人笔记中内容的整理,部分代码及图片来自互联网,由于不好找到原始出处,所以未加注明. 如有痛感,联系删除. 本文将介绍以下知识点: TCP与UDP的区别: 单播.多播.广播: Java中实现U ...

  3. socket udp广播和多播的简单实现

    UDP广播与多播 作者:legend QQ:1327706646 使用UDP协议进行信息的传输之前不需要建议连接.换句话说就是客户端向服务器发送信息,客户端只需要给出服务器的ip地址和端口号,然后将信 ...

  4. 利用Docker技术实现UDP广播效果(网络编程python版)

    docker的安装见官方文档 我使用的系统为Ubuntu16.04 Ubuntu系统安装docker文档地址:https://docs.docker.com/engine/installation/l ...

  5. 给Hi3518e的Uboot添加UDP广播收发功能

    基于个人兴趣,决定实现一个和方案公司提供的uboot收发广播的功能.记录笔记如下. SDK版本:Hi3518E_V100R001C01SPC081 1. 由于我手头的板子的Phy是RMII模式,因此先 ...

  6. NetworkComms V3 之发送UDP广播消息

    NetworkComms网络通信框架序言 NetworkComms通信框架,是一款来自英国的c#语言编写的通信框架,历时6年研发,成熟稳定,性能可靠. NetworkComms v3目前只支持基本的U ...

  7. Java UDP网络编程 - 最简单示例

    UDP也是网络通讯中的一个重要协议,与TCP区别可参见浅谈TCP/IP 和 UDP的区别,本文就对Java UDP通讯做一个简单例子介绍 服务端: package wyf; import java.i ...

  8. [C# 网络编程系列]专题七:UDP编程补充——UDP广播程序的实现

    转自:http://www.cnblogs.com/zhili/archive/2012/09/03/2666974.html 上次因为时间的关系,所以把上一个专题遗留下的一个问题在本专题中和大家分享 ...

  9. c# socket udp广播

    一.广播消息 由于Tcp是有连接的,所以不能用来发送广播消息.发送广播消息,必须用到Udp,Udp可以不用建立连接而发送消息.广播消息的目的IP地址是一种特殊IP地址,称为广播地址.广播地址由IP地址 ...

随机推荐

  1. C#.NET常见问题(FAQ)-如何让TabControl可以动态增加或删除

    动态插入可以使用TabPages.Insert方法   动态删除可以用Remove方法   更多教学视频和资料下载,欢迎关注以下信息: 我的优酷空间: http://i.youku.com/aceta ...

  2. Skyline开发4-IProject接口

    IProject接口可以访问工程设置和打开保存工程的基本方法. 属性 FileVersion:返回 ITEVersionInfo.表示当前运行的TerraExplorer的版本,可通过ITEVersi ...

  3. advertisingIdentifier

    iOS 7后Mac 地址就不能用了. 不过可以用advertisingIdentifier来取,再多个project 里测试是唯一的,但如果遇到系统升级或是重刷这个就不一定能唯一了.. 这里还要加一个 ...

  4. 微信小程序 - 滚动公告组件

    支持横轴.纵轴滚动. 点击下载:speaker

  5. vsphere 5.1 改进和SSO理解

    虚拟交换器 以5.1版的vSphere而言,VMware在VDS上提供一些新功能.例如,现在可以用快照的方式,来备份还原VDS组态及网络端口群组(port group)的组态,以因应vCenter S ...

  6. 001-Go JSON处理

    在golang中提供的encoding/json包可以编码JSON以及解码JSON数据. 1.编码JSON 使用json包中的Marshal函数进行编码,源码如下: func Marshal(v in ...

  7. HttpLuaModule——翻译(Nginx API for Lua)

    现在我已经将翻译的内容放到:http://wiki.nginx.org/HttpLuaModuleZh Nginx API for Lua Introduction 各种各样的*_by_lua和*_b ...

  8. ACE中对于不同类型数据的最大值最小值管理ACE_Numeric_Limits

    对于不同类型的变量,这里定义了其最大最小值来提供给ACE_Utils等使用 template <typename T> struct ACE_Numeric_Limits; // ---- ...

  9. 使用fuel6.0自己主动安装openstack-juno版本号(2)

    上篇中fuel_master已经安装完毕.接下来我们介绍怎样新建一个openstack环境. 1,在web界面中新建openstack环境: 点击主界面的加入button,新建openstack环境. ...

  10. java 怎么实现接收控制台输入?

    //接收键盘输入: //怎么实现接收控制台输入? import java.util.Scanner; //Test.java import java.util.Scanner; public clas ...