Python 中的网络编程一、socket模块套接字:套接字最初是为同一主机上的应用程序所创建,使得主机上运行的一个程序(又名一个 进程)与另一个运行的程序进行通信。这就是所谓的进程间通信(Inter Process Communication,IPC)。有两种类型的套接字:基于文件的和面向网络的。总的来说,Python 只支持 AF_UNIX、AF_NETLINK、AF_TIPC 和 AF_IN
想尝试写一个web框架,不是因为Django, Flask, Sanic, tornado等web框架不香, 而是尝试造一个轮子会对框架的认识更深,为了认识更深自然不应该依赖第三方库(仅使用内置库)。大多数写web框架的文章专注于应用层的实现,比如在wsgi接口的基础上实现web框架,这样当然是没有问题的,就是少了更底层一点的东西,比如不知道request到底怎么来的,但是我也理解如此做法,因为解
转载 2024-07-18 07:19:54
28阅读
学习自廖雪峰的python教程,代码也是参照着他的教程敲的。这个例子是一个TCP客户端python编程的例子,(1)首先建立一个TCP的socket(2)然后调用socket的方法与服务器进行连接(3)连接之后给服务器发送一条HTTP请求(4)接收服务器返回的HTTP响应(包括包头和HTML数据)(5)关闭连接,把接收到的数据打印或另存# -*- coding: utf-8 -*- 声明编码格
转载 2023-06-21 15:34:47
170阅读
# 实现 Java TCP 包教程 ## 1. 简介 在开始教学之前,我们首先了解一下什么是 TCPTCP(Transmission Control Protocol,传输控制协议)是一种面向连接的、可靠的、基于字节流的传输层协议。Java 提供了一套 TCP 相关的类库,方便我们进行网络编程。 本教程将指导你如何使用 Java 实现一个简单的 TCP 通信过程。 ## 2. 教学步骤
原创 2023-08-07 03:00:39
65阅读
TCP的黏问题主要分为以下三种情况: 第一种情况:如上图中的第一根bar所示,服务端一共读到两个数据,每个数据都是完成的,并没有发生粘的问题,这种情况比较好处理,服务器只需要简单的从网络缓冲区去读就好了,每次服务端读取到的消息都是完成的,并不会出现数据不正确的情况。第二种情况:服务端仅收到一个数据,这个数据包包含客户端发出的两条消息的完整信息,这个时候基于第一种情况的逻辑实现的服务端就蒙
转载 2023-11-25 12:58:47
48阅读
网络编程网络协议如同人与人之间相互交流是需要遵循一定的规则(如语言)一样,计算机之间能够进行相互通信是因为它们都共同遵守一定的规则,即网络协议。OSI参考模型和TCP/IP模型在不同的层次中有许多不同的网络协议,如图所示:网络协议之间的关系图如下:   IP协议(Internet protocol)IP协议的作用在于把各种数据包准备无误的传递给对方,其中两个重要的条件是IP地址和MAC地址。由于I
前言:         根据我的第七篇文章编写了NIO的Socket服务端代码后,接受UDP的数据正常,但是接收的TCP数据却出现了粘分包/拆/半包问题,查阅网上资料知道已经有开源的Netty提供了多种支持TCP/拆的解码器,用来满足用户的不同诉求。         可是我已经根据Java原生的NIO写
转载 2024-05-16 06:25:22
0阅读
网络由下往上分为   物理层、数据链路层、网络层、传输层、会话层、表示层和应用层。   通过初步的了解,我知道IP协议对应于网络层,TCP协议对应于传输层,而HTTP协议对应于应用层,   三者从本质上来说没有可比性,   socket则是对TCP/IP协议的封装和应用(程序员层面上)。   也可以说,TPC/IP协议是传输层协议,主要解决数据如何在网络中传输,   而HTTP是
转载 2024-07-26 21:03:31
33阅读
目录网络编程基础1. IP 地址和端口2. InetAddress 类3. UDP 和 TCP 网络编程基础Java 语言提供了非常强大的网络类,屏蔽了底层的复杂细节,使程序员可以很容易地编写处网络程序;1. IP 地址和端口虽然通过计算机网络可以使多台计算机实现连接,但是位于同一个网络中的计算机在进行连接和通信时必须遵守一定的规则,这就好比在道路中行驶的汽车一定要遵守交通规则一样。在计算机网络
转载 2024-06-01 13:11:01
22阅读
文章目录1. 简介2. NIO 和 BIO 的比较3. NIO 三大核心原理示意图4. `缓冲区(Buffer)`4.1 Buffer 类及其子类4.2 常用Buffer子类4.3 Buffer四大属性4.4 Buffer类相关方法4.4.1 最常用的自然是ByteBuffer 类(二进制数据)4.5 Buffer缓冲区代码演示5. `通道(Channel)`5.1 应用实例1-本地文件写数据5
转载 2023-07-15 13:23:08
89阅读
一,NIO入门    NIO 是new io的缩写,说实话,nio api比较难用,所用大家需要采用网络通信的时候,普通首先想到的是netty,不直接使用NIO,但是你不了解NIO,说实话,你也理解不了netty       好多人不理解socket 是干啥的,只知道socket是Java 用来通信的。应用层协议(HTTP 协议)如何发送
转载 2023-06-29 09:30:20
96阅读
一些概念: 通信信道(communication channel):将字节序列从一个主机传输到另一个主机的一种手段,可能是有线电缆,如以太网(Ethernet),也可能是无线的,如WiFi,或是其他方式的连接。 信息(information)是指由程序创建和解释的字节序列。在计算机网络环境中,这些字节序列称为分组报文(packet)。 协议(prot
转载 2023-12-25 12:19:01
39阅读
目录一、Socket类和ServerSocket类1. Socket类 2. ServerSocket类二、 使用TCP的 Socket编程实现登录功能1. 实现单用户登录2. 实现多客户端用户登录3. InetAddress类一、Socket类和ServerSocket类   TCP具有很好的安全性能        &nbsp
转载 2024-05-29 11:23:30
38阅读
什么是粘? 在进行 Java NIO 学习时,可能会发现:如果客户端连续不断的向服务端发送数据时,服务端接收的数据会出现两个数据粘在一起的情况。TCP 是基于字节流的,虽然应用层和 TCP 传输层之间的数据交互是大小不等的数据块,但是 TCP 把这些数据块仅仅看成一连串无结构的字节流,没有边界;从 TCP 的帧结构也可以看出,在 TCP 的首部没有表示数据长度的字段。 基于上面两点,在使用
转载 2023-11-14 22:04:03
96阅读
只可能出现在流传输中UDP是不会出现粘,因为他是基于报文的,也就是说UDP发送端调用几次write,接收端必须调用相同次数的read读完,他每次最多只能读取一个报文,报文与报文是不会合并的,如果缓冲区小于报文长度,则多出来的部分会被丢掉。TCP不同了,TCP是基于流传输的,他会合并消息,并且以不确定方式合并,这样就需要我们去粘处理了。TCP造成粘主要原因:    1、
转载 2023-07-15 13:22:43
188阅读
使用tcp协议在任何时候都不会丢,因为:       tcp/ip模型中,ip层负责发送但不保证正确接收,而tcp层在ip层上,保证每个正确接收。         在应用程序中,如果用socket的send发送一段数据,只要函数返回ok,对方肯定正确接收
转载 2024-02-20 22:25:00
53阅读
保证顺序性,每一个都有一个 ID。在建立连接的时候,会商定起始的 ID 是什么,然后按照 ID 一个个发送。假设A发给B的数据流由一个500 000字节的文件组成,MSS为1000字节。数据流的首字节ID为0,那么TCP会将这个文件分为500个报文段,每一个报文段的首部序号字段中分别为0、1000、2000... 如果第二个报文段先于第一个到B,也就是的顺序出错。TCP RFC中并没
转载 2024-01-04 06:02:45
94阅读
# Java发送TCP的实现流程 ## 流程图 ```mermaid flowchart TD A(创建Socket对象) --> B(创建输出流) B --> C(发送数据) C --> D(关闭输出流) ``` ## 详细步骤和代码 1. 首先需要创建一个Socket对象,用来建立与服务器的TCP连接。 ```java Socket socket = new
原创 2023-09-18 03:46:48
115阅读
# Java TCP问题解析及解决方案 ## 引言 在网络通信中,TCP协议是一种可靠的传输协议,它能够保证数据的可靠性和顺序性。但是,由于TCP是面向流的传输协议,数据是以流的形式传输的,因此在发送端和接收端之间存在着数据传输的粘连问题,也就是我们通常所说的TCP问题。 本文将详细介绍什么是TCP问题,分析其发生的原因,并提供一种解决方案。 ## 什么是TCP问题 TC
原创 2023-08-06 21:58:59
55阅读
# Java TCP 心跳实现指南 在网络编程中,心跳(Heartbeat Packet)是一种常用的方式,用于检测连接的活性和有效性。特别是在TCP协议中,心跳能够帮助检测因网络问题或其他原因导致的连接中断。本文将指导你如何在Java中实现一个简单的TCP心跳包机制。 ## 心跳流程概述 在实现TCP心跳之前,让我们先理清整个流程。以下是实现心跳所需的步骤: | 步骤 | 描
原创 9月前
71阅读
  • 1
  • 2
  • 3
  • 4
  • 5