一、服务器程序要求永远运行,一般用死循环来处理

1.服务器改造版本V03(主程序

原封不动,这里只修改了运行的程序)

if __name__ == "__main__":

    while True:

        try:

            print("Start Server")

            serverFunc()

            print("End Server")

        except Exception as e:

            print(e)

​

        time.sleep(1)

二、TCP编程

1.面向链接的传输,即每次传输之前需要先建立一个实例

2.客户端和服务端两个程序需要编写

3.Server端的编写流程

(1)建立socket负责具体通信,这个socket其实只负责接受对方的请求

(2)绑定端口和地址

(3)监听接入的访问socket

(4)接受访问的socket,可以理解接受访问即建立了一个通讯的链接通路

(5)接受对方的发送内容,利用接收到的socket接受内容

(6)如果有必要,给对方发送反馈信息

(7)关闭链接通路

4.Client端流程

(1)建立通信socket

(2)链接对方,请求跟对方建立通路

(3)发送内容到对方服务器

(4)接受对方的反馈

(5)关闭链接通路

5.举例


import socket

​

def tcp_srv():

    sock = socket.socket(socket.AF_INET,socket.SOCK_STREAM)#其哪一个参数为ipv4,后一个参数为TCP固定参数

    addr = ("127.0.0.1",8998)#ip地址和端口号

​

    sock.bind(addr)#绑定addr

    sock.listen()#监听接入的访问socket

​

    while True:

        #接受访问的socket,可以理解为接受访问即建立一个通讯的链接通路,accept返回的元组第一个元素赋给skt,第二个元素赋给addr

        skt,addr = sock.accept()#第一个元素是socket,第一个元素就是发送方的地址

        #接受对方的发送内容,利用接受到的socket接受内容

        msg = skt.recv(500)#500代表接收使用的buffersize,理解为接受内容的大小

        msg = msg.decode()#接受到的是bytes格式内容,想得到str格式的,需要进行解码

        #下面三行代表反馈的信息

        rst = "Received msg:{0} from {1}".format(msg,addr)

        print(rst)

        skt.send(rst.encode())

        #关闭socket

        skt.close()

​

if __name__ == "__main__":

    print("Startint tcp server.......")

    tcp_srv()

print("Ending tcp server.........")
import socket

​

def tcp_clt():

    sock = socket.socket(socket.AF_INET,socket.SOCK_STREAM)

    addr = ("127.0.0.1",8998)

    sock.connect(addr)#链接addr这个地址,建立tcp这个通道

    msg = "I am a good man"

    sock.send(msg.encode())

    rst = sock.recv(500)#接受对方的反馈

    print(rst.decode())

    sock.close()

​

if __name__ == "__main__":

    tcp_clt()

解释:先运行了服务器端的程序一次,然后运行了客户端程序四次,可以看到服务器端(端口8998)接收到了四次客户端发来的消息,并且每一次发来消息的端口都不一样,按照升序53256-53259.

三、FTP编程

FTP(FileTransferProtocal)文件传输协议

​用途:定制一些特殊的上传下载文件的服务

​用户分类:登录FTP服务器必须有一个账号

(1)Real账户​:注册账户

(2)​Guest账户:可能临时对某一类人的行为进行授权

(3)Anoymous​账户:匿名账户,允许任何人​

四、源码

D33_3_LoopOfServer.py

D33_4_TCPSever.py

D33_5_TCPClient.py

https://github.com/ruigege66/Python_learning/blob/master/D33_3_LoopOfServer.py

https://github.com/ruigege66/Python_learning/blob/master/D33_4_TCPSever.py

https://github.com/ruigege66/Python_learning/blob/master/D33_5_TCPClient.py

2.CSDN:https://blog.csdn.net/weixin_44630050(心悦君兮君不知-睿)

3.博客园:https://www.cnblogs.com/ruigege0000/

4.欢迎关注微信公众号:傅里叶变换,个人公众号,仅用于学习交流,后台回复”礼包“,获取大数据学习资料

Python连载53-UDP、TCP、FTP编程实例的更多相关文章

  1. Python Socket Programming UDP/TCP

    基于UDP/TCP的套接字编程demo UDP 客户端/服务器 一个简单的基于UDP协议的客户端和服务器应用的进程通信. 逻辑: 客户端会给服务器发送小写的英文字母,服务器接受后,把它转化成大写再返回 ...

  2. Python—网络通信编程之tcp通信编程

    服务端代码 import socket # 1.创建流式套接字实例 # server = socket.socket() server = socket.socket(socket.AF_INET, ...

  3. python的socket的tcp协议编程

    服务端代码如下: # _*_ coding:utf-8 _*_import socketimport datetimeHOST='0.0.0.0'PORT=3434 s=socket.socket(s ...

  4. Python复习笔记(六)网络编程(udp/tcp)

    一.网络-udp(用户数据报协议) 用户数据报协议 类似写信,不安全,数据有可能丢 1.1 ip地址 注意: IP地址127.0.0.1 ~ 127.255.255.255 用于回路测试 私有ip地址 ...

  5. python udp编程实例

    与python tcp编程控制见 http://blog.csdn.net/aspnet_lyc/article/details/39854569 c++ udp/tcp 编程见 http://blo ...

  6. Python Socket,How to Create Socket Cilent? - 网络编程实例

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

  7. 三十天学不会TCP,UDP/IP网络编程-UDP,从简单的开始

    如果对和程序员有关的计算机网络知识,和对计算机网络方面的编程有兴趣,欢迎去gitbook(https://www.gitbook.com/@rogerzhu/)star我的这一系列文章,虽然说现在这种 ...

  8. centos Linux系统日常管理2 tcpdump,tshark,selinux,strings命令, iptables ,crontab,TCP,UDP,ICMP,FTP网络知识 第十五节课

    centos  Linux系统日常管理2  tcpdump,tshark,selinux,strings命令, iptables ,crontab,TCP,UDP,ICMP,FTP网络知识 第十五节课 ...

  9. SOCKET, TCP/UDP, HTTP, FTP 浅析

    SOCKET, TCP/UDP, HTTP, FTP (一)TCP/UDP,SOCKET,HTTP,FTP简析   TCP/IP是个协议组,可分为三个层次:网络层.传输层和应用层: 网络层:IP协议. ...

随机推荐

  1. Oracle - crfclust.bdb文件太大

    今天在检查oracle rac集群时,突然才发现服务器的根目录下面占用了很多空间,照道理不应该出现这种情况,初步猜想可能是哪个日志或跟踪文件太大导致.切换到跟目录,使用du -sh *来一层一层查看到 ...

  2. TP随机从数据库中获取一条数据

    orderRaw('rand()'): /** * 随机获取一条商品信息 * @param [type] $condition * @param [type] $field * @param [typ ...

  3. apache storm基本原理及使用总结

    什么是Apache Storm Apache Storm是一个分布式实时大数据处理系统.Storm设计用于在容错和水平可扩展方法中处理大量数据.它是一个流数据框架,具有最高的摄取率.虽然Storm是无 ...

  4. 由随机数rand5实现随机数rand7

    rand5表示生成随机数1,2,3,4,5 rand7表示生成随机数1,2,3,4,5,6,7 要通过rand5构造rand7现在可能没有什么思路,我们先试着用rand7生成rand5 rand7生成 ...

  5. 《Web Development with Go》Mangodb插入map,slice,Embedded Documents

    这几个好理解, 更好的实现,再说. package main import ( "fmt" "log" "time" "gopkg ...

  6. Springboot整合Mybatis实现级联一对多CRUD操作

    在关系型数据库中,随处可见表之间的连接,对级联的表进行增删改查也是程序员必备的基础技能.关于Spring Boot整合Mybatis在之前已经详细写过,不熟悉的可以回顾Spring Boot整合Myb ...

  7. queue队列基础讲解

    前言 似乎这种对蒟蒻最重要的概念都搜不到,对巨佬来说也根本不必要提及. 导致我也不懂. Queue 意义 queue,队列,一种数据结构. 队列是一种操作受限制的线性表: 特点: 1.元素先进先出. ...

  8. Django之web框架原理

    Web框架原理 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web框架了. 先写一个 原始的web框架 imp ...

  9. SpringCloud的入门学习之深入理解Eureka注册中心

    1.Eureka 注册中心三种角色. 答:a.Eureka Server,注册中心,通过 Register.Get.Renew 等接口提供服务的注册和发现. b.Application Service ...

  10. 练手爬虫用urllib模块获取

    练手爬虫用urllib模块获取 有个人看一段python2的代码有很多错误 import re import urllib def getHtml(url): page = urllib.urlope ...