网络编程

1.基本概念

1.什么是客户端/服务器架构?

服务器就是一系列硬件或软件,为一个或多个客户端(服务的用户)提供所需的“服务”。它存在唯一目的就是等待客户端的请求,

并响应它们(提供服务),然后等待更多请求。

一个提供服务,一个请求服务得到相应的过程。

2.套接字:通信端点

套接字,就是对网络中不同主机上的应用进程之间进行双向通信的端点的抽象。

一个套接字就是网络上进程通信的一端,提供了应用层进程利用网络协议交换数据的机制。

从所处的地位来讲,套接字上联应用进程,下联网络协议栈,是应用程序通过网络协议进行通

信的接口,是应用程序与网络协议栈进行交互的接口。

  • python只支持AF_UNIX、AF_NETLINK、AF_TIPC 和 AF_INET ,重点使用基于网络的AF_INET

  • 套接字地址:主机-端口对(有效端口范围为0~65535)

3.套接字类型

  • 流式套接字(SOCK_STREAM):用于提供面向连接、可靠的数据传输服务。

  • 数据报套接字(SOCK_DGRAM):提供了一种无连接的服务。该服务并不能保证数据传输的可靠性,数据有可能在传输过程中丢失或出现数据重复,且无法保证顺序地接收到数据。

Python中的网络编程

首先介绍一下socket()模块函数

要创建套接字,必须使用socket.socket()函数,它一般的语法如下

socket(socket_family, socket_type, protocol=0)

socket_family如下(部分):

  • socket.AF_UNIX:用于同一台机器上的进程通信(既本机通信)
  • socket.AF_INET:用于服务器与服务器之间的网络通信
  • socket.AF_INET6:基于IPV6方式的服务器与服务器之间的网络通信

socket_type如下:

  • socket.SOCK_STREAM:基于TCP的流式socket通信
  • socket.SOCK_DGRAM:基于UDP的数据报式socket通信

套接字的内置方法

创建服务和客户端

  • 创建TCP服务
ss = socket()   # 创建服务器套接字
ss.bind() # 套接字与地址绑定
ss.listen() # 监听
cs = ss.accept() # 接收客户端连接
cs.recv()/cs.send() # 对话(接收/发送)
cs.close() # 关闭客户端套接字(可选)
ss.close() # 关闭服务器套接字(可选)
  • 创建TCP客户端
cs = socket()       #  创建客户端套接字
cs.connect() # 尝试连接服务器
cs.send()/cs.recv() # 对话(发送 / 接收)
cs.close() # 关闭客户端套接字

代码示例

# TCP服务
import socket
import threading IP = ""
PORT = 80 def main():
server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server.bind((IP, PORT))
server.listen(5)
print(f"[*] Listening on {IP}:{PORT}") while True:
client, address = server.accept()
print(f"[*] Accepted connection from {address[0]}:{address[1]}")
client_header = threading.Thread(target=handle_client, args=(client, ), daemon=True)
client_header.start() def handle_client(client_server):
with client_server as sock:
request = sock.recv(1024)
print(f'[*] Received: {request.decode("utf-8")}')
send = "服务器端"
sock.send(send.encode("utf-8")) if __name__ == '__main__':
main()
# TCP 客户端
import socket target_host = "127.0.0.1"
target_port = 80 client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
try:
client.connect((target_host, target_port)) send = "客户端"
client.send(send.encode("utf-8"))
response = client.recv(4096)
print(response.decode())
except:
print("连接失败!")
finally:
client.close()

可以根据自己的想法进行扩展,例如持续连接进行交互,根据自己的要求进行断开连接,此时可以在客户端加个while True:

和一个判断语句,等等

Python socket记录的更多相关文章

  1. Python Socket 编程——聊天室示例程序

    上一篇 我们学习了简单的 Python TCP Socket 编程,通过分别写服务端和客户端的代码了解基本的 Python Socket 编程模型.本文再通过一个例子来加强一下对 Socket 编程的 ...

  2. python/socket编程之粘包

    python/socket编程之粘包 粘包 只有TCP有粘包现象,UDP永远不会粘包. 首先需要掌握一个socket收发消息的原理 发送端可以是1k,1k的发送数据而接受端的应用程序可以2k,2k的提 ...

  3. Python Socket 编程——聊天室演示样例程序

    上一篇 我们学习了简单的 Python TCP Socket 编程,通过分别写服务端和client的代码了解主要的 Python Socket 编程模型.本文再通过一个样例来加强一下对 Socket ...

  4. Python Socket 基础多用户编程

    简介   写下这篇小记的原因是想记录一下自己学习Python Socket编程的心路历程.之前在中专的时间学过一些基础的Socket编程,知道了一些比较基础的内容比如基础的socket.bind()类 ...

  5. Python Socket 网络编程

    Socket 是进程间通信的一种方式,它与其他进程间通信的一个主要不同是:它能实现不同主机间的进程间通信,我们网络上各种各样的服务大多都是基于 Socket 来完成通信的,例如我们每天浏览网页.QQ ...

  6. Python学习记录day6

    title: Python学习记录day6 tags: python author: Chinge Yang date: 2016-12-03 --- Python学习记录day6 @(学习)[pyt ...

  7. Python学习记录day5

    title: Python学习记录day5 tags: python author: Chinge Yang date: 2016-11-26 --- 1.多层装饰器 多层装饰器的原理是,装饰器装饰函 ...

  8. python socket发送魔法包网络唤醒开机.py

    python socket发送魔法包网络唤醒开机.py 现在的电脑应该都普遍支持有线网络的WOL了,支持无线网络唤醒的电脑,可能比较少. """ python socke ...

  9. Python socket编程之二:【struct.pack】&【struct.unpack】

    import struct """通过 socket 的 send 和 recv 只能传输 str 格式的数据""" "" ...

  10. Python Socket,How to Create Socket Server? - 网络编程实例

    文章出自:Python socket – network programming tutorial by Silver Moon 原创译文,如有版权问题请联系删除. Network programin ...

随机推荐

  1. Java并发夺命50问

    本文已经收录到Github仓库,该仓库包含计算机基础.Java基础.多线程.JVM.数据库.Redis.Spring.Mybatis.SpringMVC.SpringBoot.分布式.微服务.设计模式 ...

  2. Python ArcPy批量掩膜、重采样大量遥感影像

      本文介绍基于Python中ArcPy模块,对大量栅格遥感影像文件进行批量掩膜与批量重采样的操作.   首先,我们来明确一下本文的具体需求.现有一个存储有大量.tif格式遥感影像的文件夹:且其中除了 ...

  3. list Api

    类型 名称 void add(String item)将指定的项目添加到滚动列表的末尾. void add(String item, int index)将指定的项目添加到由索引指示的位置的滚动列表中 ...

  4. python 启动外部程序四种方法

    在Python中,可以方便地使用os模块来运行其他脚本或者程序,这样就可以在脚本中直接使用其他脚本或程序提供的功能,而不必再次编写实现该功能的代码.为了更好地控制运行的进程,可以使用win32proc ...

  5. Thread面试题

    面试题目录https://www.cnblogs.com/Kaelthas/p/15005844.html 1.一个Thread对象代表一个线程,同一个线程能否多次启动? 不能,在Thread类中变量 ...

  6. Nacos Prometheus Grafana

    目录 运维篇:springboot与微服务组件nacos Linux服务器部署springboot项目 Springboot启动服务指定参数 Linux & Win 监控运行中的服务 Prom ...

  7. C# 反射 判断类型是否是列表

    1 /// <summary> 2 /// 判断类型是否为可操作的列表类型 3 /// </summary> 4 /// <param name="type&q ...

  8. 飞桨Paddle动转静@to_static技术设计

    一.整体概要 在深度学习模型构建上,飞桨框架支持动态图编程和静态图编程两种方式,其代码编写和执行方式均存在差异: 动态图编程: 采用 Python 的编程风格,解析式地执行每一行网络代码,并同时返回计 ...

  9. 2020-11-30:java中,卡表和记忆集的区别?

    福哥答案2020-12-04:[答案来自此链接:](http://bbs.xiangxueketang.cn/question/530)这两个都是G1收集器中的概念记忆集,RemeberSet,用来记 ...

  10. 2021-01-21:java中,HashMap的读流程是什么?

    福哥答案2020-01-21: jdk1.7读流程:1.key是否为空值null,如果为空,直接遍历table[0]链表,寻找key==null键.调用的是getForNullKey()方法.如下:1 ...