网络编程socket-SocketServer-FTP
16章 网络编程
?应该是讲网络之间如何编程来进行通信的章节
16.1.1 客户端/服务器架构
?客户端请求访问,服务器端监听请求,处理请求,进行相应的模式
16.1.2 客户端/服务器编程
?服务器端:创建通讯端点,以用来监听。并将自身位置确定,既URL
客户端:创建通讯端点,建立到服务器的连接
16.2 套接字:通讯断点
?是一种通讯必需的网络数据结构,就像电话接口,它是一种数据接口
套接字地址:套接字要有主机地址和端口(0-65535)
套接字类型:
面向连接:通信前要建立一条连接:实现的协议时TCP
无连接:实现的协议时UDP
它们这些套接字都是使用IP协议来在网络中寻找主机。
16.3 使用python来实现网络编程通信
16.3.1 socket()模块
?socket.socket()函数可以创建套接字
分别建立TCP/IP,UDP/IP的套接字
tcpSock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 第一个是家族协议,它们都是网络的。第二个是面向类型
udpSock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
16.3.2 套接字方法
?创建套接字后,要用它具有的方法来进行通信
16.3.3 创建一个TCP服务器
思路:创建套接字---绑定套接字到一个本地地址---监听连接---无限循环接听TCP客户端请求(接收到后会返回客户端套接字)---接受TCP数据---发送TCP数据---关闭子套接字---关闭服务器套接字
from socket import *
from time import ctime
HOST = '' # 表示可以绑定任何有效地址
PORT = 2157
BUFSIZ = 1024 # 关键字,大小为1k
ADR= (HOST, PORT)
tcpSerSock = socket(AF_INET, SOCK_STREAM) # 创建基于网络的、TCP服务器套接字
tcpSerSock.bind(ADR)
tcpSerSock.listen(5) # 只允许5个连接同时
while True: # 无限循环接听
print 'waiting for connecttion....'
tcpCliSock, addr = tcpSerSock.accept() # 接收,并将客户端套接字、客户端地址保存
print '...conneted from:', addr
while True:
data = tcpCliSock.recv(BUFSIZ) # 读取缓冲区的数据
if not data:
break
tcpCliSock.send('{0} {1}' .format(ctime(), data)) #发送给客户端信息
tcpCliSock.close()
tcpSerSock.close()
16.3.4 创建TCP客户端
思路:创建客户端套接字---进行连接---发送数据(发送为空就退出)---从缓冲区接收数据(接收失败就退出)---关闭客户端套接字
from socket import *
HOST = 'localhost'
PORT = 21567
BUFSIZ = 1024
ADDR = (HOST, PORT)
tcpCliSock = socket(AF_INET, SOCK_STREAM)
tcpCliSock.connect(ADDR)
while True:
data = raw_input('>')
if not data:
break
tcpCliSock.send(data)
data = tcpCliSock.recv(BUFSIZ)
if not data:
break
print data
tcpCliSock.close()
16.3.6 创建一个UDP服务器
思路:创建套接字---绑定套接字到一个本地地址--接收数据---发送数据
from socket import *
from time import ctime
HOST = '' # 表示可以绑定任何有效地址
PORT = 2157
BUFSIZ = 1024 # 关键字,大小为1k
ADR= (HOST, PORT)
udpSerSock = socket(AF_INET, SOCK_DGRAM)
udpSerSock.bind(ADR)
while True:
print 'waiting for message...'
data, addr = udpSerSock.recvfrom(BUFSIZ)
udpSerSock.sendto('{0} {1}' .format(ctime(), data), addr)
print '...received from and returned to:', addr
udpSerSock.close()
16.3.7 创建一个UDp客户端
思路:创建客户端套接字---发送数据---接收数据
from socket import *
from time import ctime
HOST = 'localhost' # 表示可以绑定任何有效地址
PORT = 2157
BUFSIZ = 1024 # 关键字,大小为1k
ADDR= (HOST, PORT)
udpCliSock = socket(AF_INET, SOCK_DGRAM)
while True:
data = raw_input('>')
if not data:
break
udpCliSock.sendto(data, ADDR)
data, ADDR = udpCliSock.recvfrom(BUFSIZ)
if not data:
break
print data
udpCliSock.close()
16.4 SocketServer 模块
?是标准库中用于简化实现网络客户端与服务器所需的大量样版代码,将很多需要的代码封装好
164.1 创建一个基于SocketServer 的TCP服务器
思路:先继承StreamRequestHandler创建请求处理类,重写handle函数---调用TCPServer使用参数“请求处理类”生成TCP服务器---服务器无限循环
from SocketServer import (TCPServer as TCP, StreamRequestHandler as SRH)
from time import ctime
HOST = ''
PORT = 21567
ADDR = (HOST, PORT)
class MyRequestHandler(SRH): # 定义继承StreamRequestHandler的请求类,重写handle函数(默认是pass)
def handle(self):
print '...connected from:', self.client_address
self.wfile.write('{0} {1}' .format(ctime(), self.rfile.readline())) # 分别读,写
tcpServ = TCP(ADDR, MyRequestHandler) # 调用TCPServer要求参数addr和请求处理类
print 'waiting for connection...'
tcpServ.serve_forever() # 这个服务器进入无限循环
16.4.2 创建一个基于SocketServer的TCP客户端
思路:创建客户端套接字---发送数据---接收数据---关闭套接字
from socket import *
HOST = 'localhost'
PORT = 21567
BUFSIZ = 1024
ADDR = (HOST, PORT)
while True:
tcpCliSock = socket(AF_INET, SOCK_STREAM) # 与之前的区别在这里,SocketServer的请求处理器的默认行为是接受连接,得到请求,就关闭连接,所以要每次都要创建一个套接字
tcpCliSock.connect(ADDR)
data = raw_input('>')
if not data:
break
tcpCliSock.send('%s\r\n' % data)
data = tcpCliSock.recv(BUFSIZ)
if not data:
break
print data.strip()
tcpCliSock.close()
16.5 Twisted 框架
?是一个完全时间驱动的网络框架,允许使用和开发完全异步的网络应用程序和协议
17 网络客户端编程
?基于TCP/UDP等低级别的协议,开发出来特定用途的协议,包括FTP/SCP,NNTP,SMTP
现在我们基于这些协议学习开发客户端(相对与服务器)
17.2 文件传输
17.2.2 文件传输协议FTP
流程:客户端连接远程的FTP服务器---客户端输入用户名和密码(或者匿名)---客户端做各种文件传输和信息查询操作---客户端登出远程FTP服务器,通讯结束
17.2.6 实例
import ftplib
import os
import socket
HOST = 'ftp.mozilla.org'
DIRN = 'pub/webtools'
FILE = 'bugzilla-LATEST.tar.gz'
def main():
try:
f = ftplib.FTP(HOST)
except (socket.error, socket.gaierror), e:
print 'ERROR: cannot reach "%s"' % HOST
return
print '***Connected to host "%s"' % HOST
try:
f.login()
except ftplib.error_perm:
print 'ERROR: cannot login anonymously'
f.quit()
return
print '*** Login in as "anonymous'
try:
f.cwd(DIRN)
except ftplib.error_perm:
print 'ERROR: cannot CD to "%s"' % DIRN
f.quit()
return
print '*** Changed to "%s" folder' % DIRN
try:
f.retrbinary('RETR %s' % FILE, open(FILE, 'wb').write)
except ftplib.error_perm:
print 'ERROR: cannot read file "%s" to CWD' % FILE
f.quit()
return
if __name__ == '__main__':
main()
网络编程socket-SocketServer-FTP的更多相关文章
- python网络编程socket /socketserver
提起网络编程,不同于web编程,它主要是C/S架构,也就是服务器.客户端结构的.对于初学者而言,最需要理解的不是网络的概念,而是python对于网络编程都提供了些什么模块和功能.不同于计算机发展的初级 ...
- Python网络编程socket
网络编程之socket 看到本篇文章的题目是不是很疑惑,what is this?,不要着急,但是记住一说网络编程,你就想socket,socket是实现网络编程的工具,那么什么是socket,什么是 ...
- 网络编程 并发socketserver
网络编程 并发socketserver ipv4.ipv6 ip协议:规定网络地址的协议 B/S架构 C/S架构 bs是cs的一种 B/S是浏览器和服务端架构 C/S是客户端和服务端架构 osi七层协 ...
- 网络编程socket基本API详解(转)
网络编程socket基本API详解 socket socket是在应用层和传输层之间的一个抽象层,它把TCP/IP层复杂的操作抽象为几个简单的接口供应用层调用已实现进程在网络中通信. socket ...
- Android 网络编程 Socket
1.服务端开发 创建一个Java程序 public class MyServer { // 定义保存所有的Socket,与客户端建立连接得到一个Socket public static List< ...
- 网络编程Socket之TCP之close/shutdown具体解释(续)
接着上一篇网络编程Socket之TCP之close/shutdown具体解释 如今我们看看对于不同情况的close的返回情况和可能遇到的一些问题: 1.默认操作的close 说明:我们已经知道writ ...
- 铁乐学Python_Day33_网络编程Socket模块1
铁乐学Python_Day33_网络编程Socket模块1 部份内容摘自授课老师的博客http://www.cnblogs.com/Eva-J/ 理解socket Socket是应用层与TCP/IP协 ...
- java网络编程socket\server\TCP笔记(转)
java网络编程socket\server\TCP笔记(转) 2012-12-14 08:30:04| 分类: Socket | 标签:java |举报|字号 订阅 1 TCP的开销 a ...
- linux网络编程-socket(37)
在编程的时候需要加上对应pthread开头的头文件,gcc编译的时候需要加了-lpthread选项 第三个参数是线程的入口参数,函数的参数是void*,返回值是void*,第四个参数传递给线程函数的参 ...
- python网络编程-socket编程
一.服务端和客户端 BS架构 (腾讯通软件:server+client) CS架构 (web网站) C/S架构与socket的关系: 我们学习socket就是为了完成C/S架构的开发 二.OSI七层 ...
随机推荐
- Django2.2使用mysql数据库pymysql版本不匹配问题的解决过程与总结
前置条件 django版本:2.2.1 python版本:3.6.6 mysql版本:mysql-community8.0.15 问题 在搭建django项目,配置mysql数据库时遇到无法迁移数据库 ...
- 精通SpringBoot---整合RabbitMQ消息队列
今天来和朋友们一起学习下,SpringBoot怎么整合RabbitMQ.目前消息组件大致有三种:.activemq, rabbitmq, kafka.这三者各有优缺点,RabbitMQ相比之下是处于其 ...
- 菜鸟学Linux - Linux文件属性
在Linux中,文件的属性是一个很重要的概念,用户或者用户组对一个文件所拥有的权限,都可以从文件的属性得知. 我们可以通过ls -al命令,列出某个文件夹下面的所有文件(包括以.开头的隐藏文件).下面 ...
- 1010: [HNOI2008]玩具装箱toy(斜率优化)
1010: [HNOI2008]玩具装箱toy Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 12280 Solved: 5277[Submit][S ...
- Java装箱和拆箱
https://www.cnblogs.com/dolphin0520/p/3780005.html http://mxdxm.iteye.com/blog/2028196 装箱过程是通过调用包装器的 ...
- Python+Selenium练习篇之13-获取当前页面的URL
本文介绍如何通过webdriver方法获取当前测试页面的URL.获取当前URL有什么用处呢,一般URL可以帮助我们判断跳转的页面是否正确,或者URL中部分字段可以作为我们自动化测试脚本期待结果的一部分 ...
- Python基础-week02 Python的常用数据类型
一.模块初识 import导入Py自带模块例如os,sys等及其自己编写的Py文件,导入到其他文件中,默认查找当前目录.如果不在同一目录,会报错,将该自定义py文件模块放到site-packages目 ...
- TopK-微博今日热门话题
大纲 TopK on single node TopK on multiple nodes Realtime topK with low QPS Realtime topK with high QPS ...
- python的重重之器(生成器、迭代器、装饰器)
一.装饰器 1.定义:本质是函数,装饰其他函数就是为其他函数添加附件功能. 2.原则: a.不能修改被装饰的函数的源代码: b.不能修改被装饰的函数的调用方式: 实例: #!/usr/bin/env ...
- Java中转发与重定向的区别
转发与重定向的区别 转发是服务器行为,重定向是客户端行为 1.转发在服务器端完成的:重定向是在客户端完成的2.转发的速度快:重定向速度慢3.转发的是同一次请求:重定向是两次不同请求4.转发不会 ...