热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Android中实现TCP和UDP传输实例

这篇文章主要介绍了Android中实现TCP和UDP传输实例,本文给出了TCP服务器端代码、TCP客户端代码、UDP服务器端代码、UDP客户端代码等代码实例,需要的朋友可以参考下

TCP和UDP在网络传输中非常重要,在Android开发中同样重要。

首先我们来看一下什么是TCP和UDP。

什么是TCP?

TCP:Transmission Control Protocol 传输控制协议TCP是一种面向连接(连接导向)的、可靠的、基于字节流的运输层(Transport layer)通信协议,由IETF的RFC 793说明(specified)。在简化的计算机网络OSI模型中,它完成第四层传输层所指定的功能。应用层向TCP层发送用于网间传输的、用8位字节表示的数据流,然后TCP把数据流分割成适当长度的报文段(通常受该计算机连接的网络的数据链路层的最大传送单元(MTU)的限制)。之后TCP把结果包传给IP层,由它来通过网络将包传送给接收端实体的TCP层。TCP为了保证不发生丢包,就给每个字节一个序号,同时序号也保证了传送到接收端实体的包的按序接收。然后接收端实体对已成功收到的字节发回一个相应的确认(ACK);如果发送端实体在合理的往返时延(RTT)内未收到确认,那么对应的数据(假设丢失了)将会被重传。TCP用一个校验和函数来检验数据是否有错误;在发送和接收时都要计算校验和。

首先,TCP建立连接之后,通信双方都同时可以进行数据的传输,其次,他是全双工的;在保证可靠性上,采用超时重传和捎带确认机制。

在流量控制上,采用滑动窗口协议[1],协议中规定,对于窗口内未经确认的分组需要重传。

在拥塞控制上,采用慢启动算法。

什么是UDP?

UDP 是User Datagram Protocol的简称, 中文名是用户数据包协议,是 OSI 参考模型中一种无连接的传输层协议,提供面向事务的简单不可靠信息传送服务。它是IETF RFC 768是UDP的正式规范。在网络中它与TCP协议一样用于处理数据包。在OSI模型中,在第四层——传输层,处于IP协议的上一层。UDP有不提供数据报分组、组装和不能对数据包的排序的缺点,也就是说,当报文发送之后,是无法得知其是否安全完整到达的。 UDP用来支持那些需要在计算机之间传输数据的网络应用。包括网络视频会议系统在内的众多的客户/服务器模式的网络应用都需要使用UDP协议。UDP协议从问世至今已经被使用了很多年,虽然其最初的光彩已经被一些类似协议所掩盖,但是即使是在今天,UDP仍然不失为一项非常实用和可行的网络传输层协议。

与所熟知的TCP(传输控制协议)协议一样,UDP协议直接位于IP(网际协议)协议的顶层。根据OSI(开放系统互连)参考模型,UDP和TCP都属于传输层协议。

UDP协议的主要作用是将网络数据流量压缩成数据报的形式。一个典型的数据报就是一个二进制数据的传输单位。每一个数据报的前8个字节用来包含报头信息,剩余字节则用来包含具体的传输数据。

TCP和UDP在android中的使用和在Java里是完全一样的。

首先我们看看TCP连接,下图为TCP连接的一个示意图:

是不是很好理解,这里就不多说了,直接看代码吧!实践出真知。

TCP服务器端代码:

代码如下:

try { 
            Boolean endFlag = false; 
            ServerSocket ss = new ServerSocket(12345); 
            while (!endFlag) { 
                // 等待客户端连接 
                Socket s = ss.accept(); 
                BufferedReader input = new BufferedReader(newInputStreamReader(s.getInputStream())); 
                //注意第二个参数据为true将会自动flush,否则需要需要手动操作output.flush() 
                PrintWriter output = newPrintWriter(s.getOutputStream(),true); 
                String message = input.readLine(); 
                Log.d("Tcp Demo", "message from Client:"+message); 
                output.println("message received!"); 
                //output.flush(); 
                if("shutDown".equals(message)){ 
                    endFlag=true; 
                } 
                s.close(); 
            } 
            ss.close(); 

        } catch (UnknownHostException e) { 
            e.printStackTrace(); 
        } catch (IOException e) { 
            e.printStackTrace(); 
        }

TCP客户端代码:

代码如下:

try { 
            Socket s = new Socket("localhost", 12345); 
            // outgoing stream redirect to socket 
            OutputStream out = s.getOutputStream(); 
            // 注意第二个参数据为true将会自动flush,否则需要需要手动操作out.flush() 
            PrintWriter output = new PrintWriter(out, true); 
            output.println("Hello IdeasAndroid!"); 
            BufferedReader input = new BufferedReader(newInputStreamReader(s 
                    .getInputStream())); 
            // read line(s) 
            String message = input.readLine(); 
            Log.d("Tcp Demo", "message From Server:" + message); 
            s.close(); 

        } catch (UnknownHostException e) { 
            e.printStackTrace(); 
        } catch (IOException e) { 
            e.printStackTrace(); 
        }

下面我们看看UDP:

UDP服务器端代码:

代码如下:

// UDP服务器监听的端口 
        Integer port = 12345; 
        // 接收的字节大小,客户端发送的数据不能超过这个大小 
        byte[] message = new byte[1024]; 
        try { 
            // 建立Socket连接 
            DatagramSocket datagramSocket = new DatagramSocket(port); 
            DatagramPacket datagramPacket = new DatagramPacket(message, 
                    message.length); 
            try { 
                while (true) { 
                    // 准备接收数据 
                    datagramSocket.receive(datagramPacket); 
                    Log.d("UDP Demo", datagramPacket.getAddress() 
                            .getHostAddress().toString() 
                            + ":" + new String(datagramPacket.getData())); 
                } 
            } catch (IOException e) { 
                e.printStackTrace(); 
            } 
        } catch (SocketException e) { 
            e.printStackTrace(); 
        }

UDP客户端代码:

代码如下:

public static void send(String message) { 
        message = (message == null ? "Hello IdeasAndroid!" : message); 
        int server_port = 12345; 
        DatagramSocket s = null; 
        try { 
            s = new DatagramSocket(); 
        } catch (SocketException e) { 
            e.printStackTrace(); 
        } 
        InetAddress local = null; 
        try { 
            // 换成服务器端IP 
            local = InetAddress.getByName("localhost"); 
        } catch (UnknownHostException e) { 
            e.printStackTrace(); 
        } 
        int msg_length = message.length(); 
        byte[] messagemessageByte = message.getBytes(); 
        DatagramPacket p = new DatagramPacket(messageByte, msg_length, local, 
                server_port); 
        try { 
            s.send(p); 
        } catch (IOException e) { 
            e.printStackTrace(); 
        } 
    }

代码中需要注意的地方已做了注释,希望本文对您有所帮助!


推荐阅读
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了VoLTE端到端业务详解|VoLTE用户注册流程相关的知识,希望对你有一定的参考价值。书籍来源:艾怀丽 ... [详细]
  • UDP千兆以太网FPGA_verilog实现(四、代码前期准备UDP和IP协议构建)
    UDP:userDatagramprotocol用户数据报协议无连接的传输层协议,提供面向事务的简单不可靠信息传送服务,IETFRFC76 ... [详细]
  • SQL Server 2008 到底需要使用哪些端口?
    SQLServer2008到底需要使用哪些端口?-下面就来介绍下SQLServer2008中使用的端口有哪些:  首先,最常用最常见的就是1433端口。这个是数据库引擎的端口,如果 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • 生成对抗式网络GAN及其衍生CGAN、DCGAN、WGAN、LSGAN、BEGAN介绍
    一、GAN原理介绍学习GAN的第一篇论文当然由是IanGoodfellow于2014年发表的GenerativeAdversarialNetworks(论文下载链接arxiv:[h ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • CentOS 7部署KVM虚拟化环境之一架构介绍
    本文介绍了CentOS 7部署KVM虚拟化环境的架构,详细解释了虚拟化技术的概念和原理,包括全虚拟化和半虚拟化。同时介绍了虚拟机的概念和虚拟化软件的作用。 ... [详细]
  • 概述H.323是由ITU制定的通信控制协议,用于在分组交换网中提供多媒体业务。呼叫控制是其中的重要组成部分,它可用来建立点到点的媒体会话和多点间媒体会议 ... [详细]
  • Ansem 最新雄文:软着陆后,加密市场下阶段趋势与核心叙事
    市场最糟糕的时候已经过去,以太坊合并前不太会看到新的低点;但仍需来自关注宏观市场的不确定风险。撰文:Ansem ... [详细]
  • 域名解析系统DNS
    文章目录前言一、域名系统概述二、因特网的域名结构三、域名服务器1.根域名服务器2.顶级域名服务器(TLD,top-leveldomain)3.权威(Authoritative)域名 ... [详细]
  • c# java socketn 字节流_C#Socket编程详解(一)TCP与UDP简介
    一、TCP与UDP(转载)1、TCP1.1定义TCP(TransmissionControlProtocol)传输控制协议。是一种可靠的、面向连接的协议(eg:打电话)、传输效率低 ... [详细]
  • python计算数据包校验和(python接口数据校验)
    本文目录一览:1、怎么用python算p值和t检验 ... [详细]
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
author-avatar
盼抽淡了烟的悲伤
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有