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

Java基础高级2网络编程

1.协议的概念:通信双方事先约定好的通信规则2七层网络通信协议;应用成,表示层,会话层,传输层,

1.协议的概念:通信双方事先约定好的通信规则

2七层网络通信协议;应用成,表示层,会话层,传输层,网络层,数据链路层

3.TCP/IP协议:点对点通信,三层握手,安全有保证

4。UDP协议;广播协议,不保证数据安全但很高效

5.重要APl:InetAddress类,URl类,ServerSocked类,DatagramSocket类

6.网络编程主要有两部分:一是获取管理socket连接,二是获取使用输入输出流传输数据

1.网络模型介绍

OSI参考模型                   TCP/IP参考模型

应用层                              应用层

表示层                       

会话层

传输层                               传输层

网络层                               Internet层

数据链路层           

物理层                                网络接口层

TCP/IP协议组

HTTP FTP SMIP DNS RPC SNM

TCP                       UDP

RARP  IP              IGMP ICMP

以太网   令牌环             帧中  ATM

 

网络通讯要素:IP地址,端口号,传输协议

 2.网络通讯要素1-IP地址

 ip计算机唯一标识

端口号每台计算机应用程序的隔离

传输协议:通讯的规则

IP地址;网络中设备的标识

ip不方便记忆,使用主机名

本地回环地址;127.0.0.1 主机名localhost

2的10次方,小于255

IP也是一个类java.net下的InetAddress

里面没有构造函数,不能通过new来创建对象

3.网络通讯要素2-端口

端口号;用于标识进程的逻辑地址

有效端口0~65535,其中0~1024被系统使用或保留端口

某一个数据传给某一个进程,

能上网不能聊QQ,通过防火墙软件,把QQ相应数据传输端口被禁用了,就不能 发送和接收信息了

端口号是进程的唯一标识,如果QQ和飞秋是同一个端口,可以同时接收到一个信息

4.网络通讯要素3-传输协议

 通讯的规则

常见协议TCP.UDP

传输层:TCP 和UDP

UDP

不需要建立连接,将数据及源和目的封装到数据包中,不需要源和目的进行连接

每个数据包的大小限制在64kb

因无连接,是不可靠协议:咱们发送的数据不知道对方是否接受到

不需要建立连接,效率相对快

TCP

建立连接,形成传输数据的通道

在连接中进行大数据量的传输,没有限制,基于通道,任意发送

通过三次握手完成确认连接,是可靠协议。连接已经建立,通话可靠,确认通道连接正常

必须建立连接,效率会降低

 5. Socket(套接字)

Socket就是为网络服务提供的一种机制

通信的两端都有Socket

网络通讯其实就是Socket通信

数据在两个Socket件传输,数据传输IO流

网络编程步骤(Socket编程)

客户端

建立网络连接(指定iP地址和端口号),建立Socket服务,基于Socket服务器进行数据传输

交换数据(请求响应模型)

关闭连接,释放资源

服务器端

监听端口,当客户端发送数据时,有端口进行接收

获得连接(被动),等待客户端连接

交换数据,基于客户端请求,创建Socket服务

关闭连接

6. UDP发送端开发

发送端

1.建立UDP的Socket服务

DatagramSocket socket=new DatagramSocket();

2.封装数据包

byte[] data="开始UDP之旅".getByte();

DatagramPacket packet=new DatagramPacket(buf,buf.length,InetAddress.getLocalHost(),10000);

3.通过socket的send()发送数据

socket.send(packet);

4.关闭资源

socket.close();

 7. UDP接收端开发

接收端

1.建立udp的socket服务器,必须指定端口

DatagramSocket socket=new DatagramSocket(10000);

2. 定义数据包用于接收数据

byte[] data=new byte[1024];

DatagramPacket packet=socket.receive(buf,buf.length)

3.通过socket的receive()方法,把数据接收到packet包中

socket.receive(packet);

4.通过packet的相应方法获取数据

packet.getData(); getAddress();...

String content=new String(packet.getData(),0.packet.length)

5.关闭资源

socket.close();

 8. UDP聊天程序开发

 UDP发送端

// 1. 创建udp的Socket服务,可指定端口,可不指定,开通一个任意的执行端口
  DatagramSocket socket = new DatagramSocket();// 不需要指定端口,因为只需要一个端口把数据发送出去就行
  // 2.提供相应的发送信息,封装数据包,自己构造包,某个ip和端口上(字节数组,ip,端口)
  // 2.1动态发送数据,可以通过一个服务多次发送,多次接收
  Scanner scanner = new Scanner(System.in);// 键盘录入是system.in
  while (scanner.hasNext()) {// 判断是否录入结束
   byte[] data = scanner.nextLine().getBytes();// 字节数组
   DatagramPacket packet = new DatagramPacket(data, data.length,
     InetAddress.getLocalHost(), 888);
   // 3.调用Socket服务的发送方法send,进行信息的发送
   socket.send(packet);
  }

UDP接收端

// 1.创建socket服务,必须指定端口和发送端相同的端口,发送主机相同的端口
  DatagramSocket socket = new DatagramSocket(888);
  // 2.构建datagramPacket ,用于接收数据
  byte[] data = new byte[1024];// 缓冲区
  DatagramPacket packet = new DatagramPacket(data, data.length);// 只需要有数据就行
  // 3.通过socket的receive方法,将数据封装到packet中
  while (true) {
   socket.receive(packet);// 该方法是阻塞方法// 把包以参数,10000端口监听到的信息,封装给包
   // 4.通过packet提供的相应方法,获取客户端发送的相应信息
   // InetAddress ip = packet.getAddress();
   // System.out.println(ip.getHostAddress());
   String content = new String(packet.getData(), 0, packet.getLength());// 返回字节数组
   System.out.println(content);
  }

首先运行接收端,然后运行接收端

9. TCP客户端开发

 客户端

1. 建立TCP客户端socketfuw

Socket socket=new Socket(192.168.1.161,10001);

2.通过socket的getOutputStream()获得流对象

OutputStream out=socket.getOutputStream();

3.通过流对象的操作方法传输数据

byte[] data="开始春游".getByte();

out.write(data);

4.关闭资源

socket.close();

 提前建立连接,在客户端和服务器端创建socket服务

tcp和udp编程的不同

1. 使用的封装API不一样

2.IP和端口号,udp是写到包里的,不用写在socket服务中

                   tcp是写到socket服务中,和服务器端建立连接

3. udp使用的是包,tcp使用的是流

输出是write,输入read

10 TCP服务器端开发

服务端

1. 建立TCP服务端socket服务

ServerSocket ss=new ServerSocket(10001);

2.通过ss的accept()获得客户端对象

Socket socket=ss.accept();

3.通过socket获取读取流,读取客户端发送的数据

InputStream in=socket.getInputStream();

4.通过流对象操作数据

byte[] buf=new byte[1024];

int len=in.read(buf);

5.关闭资源

socket.close();

ss.close();

 11。TCP服务端和客户端的相互通讯

服务端回写信息

// 还可以回写信息,客户端和服务器端相互通信
  OutputStream out = socket.getOutputStream();
  // byte[] data = "可以".getBytes();
  out.write("收到收到".getBytes());

客户端接收信息

// 接收服务器端数据
  InputStream in = socket.getInputStream();
  byte[] buf = new byte[1024];
  int len = in.read(buf);
  System.out.println(new String(buf, 0, len));

12.智能聊天机器人客户端开发

 

转:https://www.cnblogs.com/shiyeyeyeye/p/5287498.html



推荐阅读
  • 在Linux系统中,网络配置是至关重要的任务之一。本文详细解析了Firewalld和Netfilter机制,并探讨了iptables的应用。通过使用`ip addr show`命令来查看网卡IP地址(需要安装`iproute`包),当网卡未分配IP地址或处于关闭状态时,可以通过`ip link set`命令进行配置和激活。此外,文章还介绍了如何利用Firewalld和iptables实现网络流量控制和安全策略管理,为系统管理员提供了实用的操作指南。 ... [详细]
  • IOS Run loop详解
    为什么80%的码农都做不了架构师?转自http:blog.csdn.netztp800201articledetails9240913感谢作者分享Objecti ... [详细]
  • Java Socket 关键参数详解与优化建议
    Java Socket 的 API 虽然被广泛使用,但其关键参数的用途却鲜为人知。本文详细解析了 Java Socket 中的重要参数,如 backlog 参数,它用于控制服务器等待连接请求的队列长度。此外,还探讨了其他参数如 SO_TIMEOUT、SO_REUSEADDR 等的配置方法及其对性能的影响,并提供了优化建议,帮助开发者提升网络通信的稳定性和效率。 ... [详细]
  • REST与RPC:选择哪种API架构风格?
    在探讨REST与RPC这两种API架构风格的选择时,本文首先介绍了RPC(远程过程调用)的概念。RPC允许客户端通过网络调用远程服务器上的函数或方法,从而实现分布式系统的功能调用。相比之下,REST(Representational State Transfer)则基于资源的交互模型,通过HTTP协议进行数据传输和操作。本文将详细分析两种架构风格的特点、适用场景及其优缺点,帮助开发者根据具体需求做出合适的选择。 ... [详细]
  • Nacos 0.3 数据持久化详解与实践
    本文详细介绍了如何将 Nacos 0.3 的数据持久化到 MySQL 数据库,并提供了具体的步骤和注意事项。 ... [详细]
  • 一、Tomcat安装后本身提供了一个server,端口配置默认是8080,对应目录为:..\Tomcat8.0\webapps二、Tomcat8.0配置多个端口,其实也就是给T ... [详细]
  • C#实现文件的压缩与解压
    2019独角兽企业重金招聘Python工程师标准一、准备工作1、下载ICSharpCode.SharpZipLib.dll文件2、项目中引用这个dll二、文件压缩与解压共用类 ... [详细]
  • 本文详细介绍了在 Ubuntu 系统上搭建 Hadoop 集群时遇到的 SSH 密钥认证问题及其解决方案。通过本文,读者可以了解如何在多台虚拟机之间实现无密码 SSH 登录,从而顺利启动 Hadoop 集群。 ... [详细]
  • php更新数据库字段的函数是,php更新数据库字段的函数是 ... [详细]
  • 基于Net Core 3.0与Web API的前后端分离开发:Vue.js在前端的应用
    本文介绍了如何使用Net Core 3.0和Web API进行前后端分离开发,并重点探讨了Vue.js在前端的应用。后端采用MySQL数据库和EF Core框架进行数据操作,开发环境为Windows 10和Visual Studio 2019,MySQL服务器版本为8.0.16。文章详细描述了API项目的创建过程、启动步骤以及必要的插件安装,为开发者提供了一套完整的开发指南。 ... [详细]
  • 小王详解:内部网络中最易理解的NAT原理剖析,挑战你的认知极限
    小王详解:内部网络中最易理解的NAT原理剖析,挑战你的认知极限 ... [详细]
  • 在JavaWeb项目架构中,NFS(网络文件系统)的实现与优化是关键环节。NFS允许不同主机系统通过局域网共享文件和目录,提高资源利用率和数据访问效率。本文详细探讨了NFS在JavaWeb项目中的应用,包括配置、性能优化及常见问题的解决方案,旨在为开发者提供实用的技术参考。 ... [详细]
  • TCP三次握手过程详解与图示解析
    本文详细解析了TCP三次握手的过程,并通过图示清晰展示了各个状态的变化。同时,文章还介绍了四次挥手的图解,解释了在TIME_WAIT状态中,客户端最后一次发送的ACK包的作用和重要性。 ... [详细]
  • 通过采用用户数据报协议(UDP),本研究设计并实现了一种高效的文件传输方法。在发送端,系统利用Java编程语言中的相关类库,如`File`和`FileInputStream`,实现了文件的读取与分段处理,确保了数据的快速传输。该方法不仅提高了传输效率,还降低了网络拥塞的风险,适用于大规模文件传输场景。 ... [详细]
  • 深入解析OSI七层架构与TCP/IP协议体系
    本文详细探讨了OSI七层模型(Open System Interconnection,开放系统互连)及其与TCP/IP协议体系的关系。OSI模型将网络通信过程划分为七个层次,每个层次负责不同的功能,从物理层到应用层逐步实现数据传输和处理。通过对比分析,本文揭示了OSI模型与TCP/IP协议在结构和功能上的异同,为理解现代网络通信提供了全面的视角。 ... [详细]
author-avatar
手机用户2702932962_848
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有