ref:http://blog.chinaunix.net/uid-20771867-id-3416509.html
         cmd:telnet localhost 5554
        redir add udp:8002:8001 (将PC 8002端口映射为模拟器 8001端口)
         模拟器-SERVER:ServerSocket server = new ServerSocket(8001);//zcl:7100改为2888
            public static void ReceiveUDP() throws IOException {
             // TODO Auto-generated method stub
ReliableUDP udp = new ReliableUDP(null, "172.17.21.231", 8001, 8001);
             byte[] revBuf = new byte[1024];
             int res = udp.ReadFixedLength(revBuf, 1);
            }                     
         PC-CLIENT:Socket socket = new Socket("127.0.0.1", 8002); 
          《TCP/UDP测试工具》 UDP:127.0.0.1 port 8002 (注意:8002是PC的映射端口)

ok ——》 最终找到原因:是redir add会抢占端口:          
ok ——》解决方法:环境设置——关键是一定要使用remotePC,单靠本机无法实现调试

      +++++++++++++++++++++++++++++++++++++++++          +++++++++++++++++++++++++++++++++++++++++
+ localPC + + remotePC +
+ ip:172.17.22.8 + + ip:172.17.21.54 +
+ redir udp:: + + +
+ + + +
+ +++++++++++++++++++++++++++++ + + +
+ + android vm + + + +
+ + + + + +
+ + + + + +
+ + send(DestIP=remotePC, + + + Receive(localPort=) +
+ + localPort=) + + + +
+ + DestPort=) + + + +
+ + --------------------------------------> -
+ + + + + +
+ + + + + +
+ + Receive(localPort=), + + + send( DestIP=localPC +
+ + + + + localPort=) +
+ + + + + DestPort=) +
+ + + + + +
+ + <----------+---<----------+----- +
+ + + + + +
+ + + + + +
+ +++++++++++++++++++++++++++++ + + +
+ + + +
+++++++++++++++++++++++++++++++++++++++++ +++++++++++++++++++++++++++++++++++++++++

ok ——》code:
   public class LEDControlerDriver {
    public static void SendUDP() {
     // TODO Auto-generated method stub
     ReliableUDP udp = new ReliableUDP(null, DestIP, 8001, 8001);//to lydsw 前一个8001是模拟器-SERVER port,后一个8001是pc 接收消息的port,注意!不是pc映射给模拟器的端口(8002)
     String s= "32323213";
     int res = udp.SendFixedLength(s.getBytes(), s.length()); 
     
    }
    
    public static void ReceiveUDP() throws IOException {
     // TODO Auto-generated method stub
     ReliableUDP udp = new ReliableUDP(null, DestIP, 8001, 8001);//to lydsw 前一个8001是模拟器-SERVER port,后一个8001是pc 接收消息的port,注意!不是pc映射给模拟器的端口(8002)
     byte[] revBuf = new byte[1];
     int res = udp.ReadFixedLength(revBuf, 1);
    }
                 
   public class ReliableUDP {
    public int SendFixedLength(byte[] sendBuf,int nSendLen){
     Log.i("UDP Demo", "发送数据(1):");
     // check
        int res = 1;
        if (sendBuf.length!=nSendLen) {
      return -2;
     } 
       
        // create socket
        DatagramSocket socket = null;
     try {
      socket = new DatagramSocket(null);   // 指定Null很重要,否则Java会自动随机选个可用端口来绑定
      socket.setReuseAddress(true); // DatagramSocket的setReuseAddress(true)方法执行后,可以允许多个DatagramSocket
              // 绑定到相同的IP地址和端口,那么发送到此IP地址和端口的数据能够被复制到多个DatagramSocket
      socket.setSoTimeout(10000);
      socket.bind(new InetSocketAddress(this.LocalPort)); 
     } catch (SocketException e) {
      Log.i("UDP Demo", "SendFixedLength:socket create failed1:"+e.getMessage());
      return -3;
     }     
       
        Log.i("UDP Demo", "发送数据(2):");
        // 定义一个用于发送的DatagramPacket对象 
        DatagramPacket outPacket = null;
        try {
                outPacket = new DatagramPacket(sendBuf , nSendLen  , InetAddress.getByName(this.IPaddr) , this.TargetPort); 
                   socket.send(outPacket); 
                   Log.i("UDP Demo", "SendData:UDP发送数据:"+StringHexbyteTransform.bytesToHexString(sendBuf));
     } catch (IOException e2) {
      Log.i("UDP Demo", "SendData:io failed:"+e2.toString()+":"+e2.getMessage());
      res = -52;
     }  
       
        socket.close();
        return res;
    }
                                                   
                                                  
    public int ReadFixedLength(byte[] revBuf,int nRecvLen, int timeout)
    {
     Log.i("UDP Demo", "Read数据(1):");
     // check
        int res = 1;
        int len = nRecvLen;
        if (-1 == nRecvLen) {
         len = revBuf.length;
     } 
       
        // create socket
        DatagramSocket socket = null;
     try {
      socket = new DatagramSocket(null);   // 指定Null很重要,否则Java会自动随机选个可用端口来绑定
      socket.setReuseAddress(true); // DatagramSocket的setReuseAddress(true)方法执行后,可以允许多个DatagramSocket
              // 绑定到相同的IP地址和端口,那么发送到此IP地址和端口的数据能够被复制到多个DatagramSocket
      socket.setSoTimeout(timeout);
      socket.bind(new InetSocketAddress(this.LocalPort)); 
     } catch (SocketException e) {
      Log.i("UDP Demo", "SendFixedLength:socket create failed1:"+e.getMessage());
      return -3;
     }     
       
        Log.i("UDP Demo", "Read数据(2):");
        // 定义一个用于发送的DatagramPacket对象 
        DatagramPacket inPacket = null;
        try {
          inPacket = new DatagramPacket(revBuf , len);
          socket.receive(inPacket); 
          ExpandRevBuffer(revBuf);
                   Log.i("UDP Demo", "receive:"+StringHexbyteTransform.bytesToHexString(revBuf)); 
     } catch (IOException e2) {
      Log.i("UDP Demo", "SendData:io failed:"+e2.toString()+":"+e2.getMessage());
      res = -52;
     }  
       
        socket.close();
        return res;
    }

DatagramSocket总是发送UDP数据后无法接收数据的更多相关文章

  1. Android上UDP组播无法接收数据的问题

    最近,想做一个跨平台的局域网的文件传输软件,思路是组播设备信息,TCP连接传输文件.于是进行了一次简单的UDP组播测试,发现Android对于UDP组播接收数据的支持即极为有限. 部分代码如下 pac ...

  2. sql server中新增一条数据后返回该数据的ID

    开发中遇到的问题:在新增一条数据后往往不需要返回该数据的ID,但是有的时候可能需要返回该数据的ID以便后面的编程使用. 在这里介绍两种方法: 其一:使用存储过程: create procedure a ...

  3. JQuery Ajax 发送请求成功后却接收不到任何响应数据问题

    问题描述 使用 JQuery Ajax 向后端服务器发送请求,服务器也收到请求返回了响应数据,但是 Ajax 却收不到任何响应数据. 举例如下: $.ajax({ type: "post&q ...

  4. QTcpSocket的连续发送数据和连续接收数据

    关于这个问题折腾了我好久,以前做些小练习的时候,用QTcpSocket的write()一数据,然后接收方只要emit一个readyread()信号然后就用QTcpSocket的read()去读.本以为 ...

  5. sql清空表数据后重新添加数据存储过程

    ALTER PROCEDURE [dbo].[sp_add_Jurisdiction] @CTableName varchar(20), --当前要删除.新增的表 @filedkeyValue var ...

  6. Java基础知识强化之网络编程笔记03:UDP之UDP协议发送数据 和 接收数据

    1. UDP协议发送数据 和 接收数据 UDP协议发送数据: • 创建发送端的Socket对象 • 创建数据,并把数据打包 • 调用Socket对象的发送方法,发送数据包 • 释放资源  UDP协议接 ...

  7. STM32移植RT-Thread后的串口在调试助手上出现:(mq != RT_NULL) assert failed at rt_mq_recv:2085和串口只发送数据不能接收数据问题

    STM32移植RT-Thread后的串口在调试助手上出现:(mq != RT_NULL) assert failed at rt_mq_recv:2085的问题讨论:http://www.rt-thr ...

  8. Java基础知识强化之网络编程笔记06:TCP之TCP协议发送数据 和 接收数据

    1. TCP协议发送数据 和 接收数据 TCP协议接收数据:• 创建接收端的Socket对象• 监听客户端连接.返回一个对应的Socket对象• 获取输入流,读取数据显示在控制台• 释放资源 TCP协 ...

  9. android蓝牙(二)——接收数据

    在蓝牙开发中,我们有这种一个需求:我们的androidclient要始终保持和蓝牙的连接,当蓝牙有数据返回的时候,androidclient就要及时的收取数据,当蓝牙没有数据返回的时候我们就要保持an ...

随机推荐

  1. react-native 项目实战 -- 新闻客户端(7) -- 新闻详情页

    http://c.3g.163.com/nc/article/BUH64L0J00031H2L/full.html 观察这个地址,BUH64L0J00031H2L 就是每条新闻数据里的postid.  ...

  2. 使用Gulp定制前端开发环境

    1.安装package.json中依赖了的组件 npm install 2.来到本地路径,创建工程配置文件 npm init 3.本地安装gulp npm install gulp --save-de ...

  3. <p>在我们的实际软件项目中,管理团队事实上比写代码或者实现一个客户的需求更为的有挑战性。由于编程实际上是和机器打交道,而和机器打交道,仅仅要你符合机器预定的逻辑,</p>

    在我们的实际软件项目中,管理团队事实上比写代码或者实现一个客户的需求更为的有挑战性. 由于编程实际上是和机器打交道.而和机器打交道,仅仅要你符合机器预定的逻辑, 一步步迈向解决这个问题的道路上一点都不 ...

  4. JavsScript中DOM的基本操作

    节点及其类型 元素节点 属性节点: 元素的属性, 可以直接通过属性的方式来操作. 文本节点: 是元素节点的子节点, 其内容为文本. 在 html 文档的什么位置编写 js 代码 直接在 html 页面 ...

  5. 事件驱动模型实例详解(Java篇)

    或许每个软件从业者都有从学习控制台应用程序到学习可视化编程的转变过程,控制台应用程序的优点在于可以方便的练习某个语言的语法和开发习惯(如.net和java),而可视化编程的学习又可以非常方便开发出各类 ...

  6. 大师养成计划之二:hibernate框架的使用------实例演示

    搭建hibernate项目框架的步骤: 一.导入jar包 二.new    .cfg.xml配置文件 <?xml version="1.0" encoding="U ...

  7. 基于日志处理的ElasticSearch的学(gen)习(feng)

    最近学了点solr,然后有听说了ElasticSearch,就想着也学一下ElasticSearch,然后看见了ElasticSearch用于日志的收集的分析,这里就来学习一下. 百度一下Elasti ...

  8. 使用MongoDB 记录业务日志

    最近公司有个需求,要对业务日志进行记录并根据日志排查问题,以前都是使用log4net之类的日志组件来记录到文件,这种方式已经不能满足业务的需要,因为日志文件会很大,即使进行分割后,查找也是很不方便,何 ...

  9. 第二篇:Filebeat 安装配置

    Filebeat 简介:Filebeat 是一款轻量型日志收集工具,可转发汇总日志.文件等内容.                         其主要特点为:1. 断点续传.(如遇日志转发过程中网络 ...

  10. Exception in thread "main" java.util.ConcurrentModificationException

    package test; import java.util.ArrayList; import java.util.Iterator; import java.util.List; public c ...