今日所学

一.ftp上传简单实例

二.socketsever的固定用法

三.验证合法性连接

1.ftp上传实例

这个题目是我们现在网络编程比较基础一点的题目

下面我们只写简单上传的代码

上传服务端的代码

import socket
import struct
import json
sever=socket.socket()
ip_port=('127.0.0.1',8008)
sever.bind(ip_port)
sever.listen()
conn,addr=sever.accept()
#先接受4个字节,为文件的信息的长度
struct_len_info=conn.recv(4) # 拿到字典的长度,(拿到的结果为元组,从元组中把数据拿出来)
data_len=struct.unpack('i',struct_len_info)[0] # 然后根据拿到的长度,接收字典的字节类型
data_dict_bytes=conn.recv(data_len) # 将字节转换为json字符串类型
data_json=data_dict_bytes.decode('utf-8') # 将json字符串转换为字典
data_dict=json.loads(data_json) sum=0
#算出文件的路径
file_path='相对路径'+'\\'+data_dict['file_name']
with open(file_path,mode='wb') as f:
while sum<data_dict['file_size']: from_client_msg=conn.recv(1024) sum+=len(from_client_msg) f.write(from_client_msg)  

上传客户端代码

import socket
import os
import struct
import json
client=socket.socket()
cleint.connect(('127.0.0.1',8008))
#读取文件的大小(读出来的内容是文件的字节类型)
file_size=os.path.getsize(r'相对路径')
# 在发送真实的文件之前,先将文件的信息包装成字典发送给服务端(文件名字,文件大小,文件路径)
file_info={
'file_name':'XXX.XXX',
'file_size' : file_size,
'file_LuJing': '文件的路径'
}
#将字典序列化成json字符串
file_info_str=json.dumps(file_info)
#将json字符串编码成字节
file_info_byte=file_info_str.encode('utf-8')
#求出字典的字节长度
info_len=len(file_info_byte)
# 打包
info_struct=struct.pack('i',info_len)
# 将打包好的信息和长度发送给服务端
client.send(info_struct+file_info_byte)
with open('你要发送的文件.xxx',mode='rb') as f:
#如果你累加的长度小于文件的长度,让他继续执行
while sum<file_size:
#每次读取的大小最大为1024
every_read=f.read(1024)
sum+=len(every_read)
#将读取到的数据发送给服务端
client.send(every_read)  

注 : 上传和下载只是角色互换而已,上传为客户端向服务端中保存数据,而下载是客户端从服务端的内容中下载相应的文件.

2.socketsever的固定用法

话不多说,上代码

先上传服务端的代码

import socketsever
class 类名(socketsever.BaseRequestHandler):
# 注:这里的handle方法名是固定的,是不允许变的
def handle(self):
while 1:
# self.request相当于conn
from_client_msg=self.request.recv(1024)
print(from_client_msg.decode('utf-8'))
msg=input('服务端说:)
self.request.send(msg.encode('utf-8')) if __name__='__main__':
ip_port=('127.0.0.1',8008)
sever=socketsever.ThreadingTCPSever(ip_port,类名)
sever.serve_forever()
以下是客户端的代码
import socket
client=socket.socket()
client.connect(('127.0.0.1',8008))
while 1:
msg=input('客户端说>>>')
if msg=='byebye':
break
client.send(msg.encode('utf-8'))
from_sever_msg=client.recv(1024)
print(from_sever_msg.decode('utf-8')) client.close()
3. 验证合法性连接的服务端
服务端:
from socket import *
import hmac,os
#秘钥
secret_key=b'Jedan has a big key!'
def conn_auth(conn): print('开始验证新链接的合法性')
msg=os.urandom(32)#生成一个32字节的随机字符串
conn.sendall(msg)
h=hmac.new(secret_key,msg)
digest=h.digest()
respone=conn.recv(len(digest))
return hmac.compare_digest(respone,digest) def data_handler(conn,bufsize=1024):
if not conn_auth(conn):
print('该链接不合法,关闭')
conn.close()
return
print('链接合法,开始通信')
while True:
data=conn.recv(bufsize)
if not data:break
conn.sendall(data.upper()) def server_handler(ip_port,bufsize,backlog=5):
'''
只处理链接
:param ip_port:
:return:
'''
tcp_socket_server=socket(AF_INET,SOCK_STREAM)
tcp_socket_server.bind(ip_port)
tcp_socket_server.listen(backlog)
while True:
conn,addr=tcp_socket_server.accept()
print('新连接[%s:%s]' %(addr[0],addr[1]))
data_handler(conn,bufsize) if __name__ == '__main__':
ip_port=('127.0.0.1',9999)
# 自己定义接收大小
bufsize=1024
server_handler(ip_port,bufsize)

 客户端:

from socket import *
import hmac,os secret_key=b'Jedan has a big key!'
def conn_auth(conn):
'''
验证客户端到服务器的链接
:param conn:
:return:
'''
msg=conn.recv(32)
h=hmac.new(secret_key,msg)
digest=h.digest()
conn.sendall(digest) def client_handler(ip_port,bufsize=1024):
tcp_socket_client=socket(AF_INET,SOCK_STREAM)
tcp_socket_client.connect(ip_port) conn_auth(tcp_socket_client) while True:
data=input('>>: ').strip()
if not data:continue
if data == 'quit':break tcp_socket_client.sendall(data.encode('utf-8'))
respone=tcp_socket_client.recv(bufsize)
print(respone.decode('utf-8'))
tcp_socket_client.close() if __name__ == '__main__':
ip_port=('127.0.0.1',9999)
bufsize=1024
client_handler(ip_port,bufsize)

day29 socketsever ftp功能简单讲解的更多相关文章

  1. Python socketserver ftp功能简单讲解

    socketserver模块实现并发 为什么要讲socketserver?我们之前写的tcp协议的socket是不是一次只能和一个客户端通信,如果用socketserver可以实现和多个客户端通信.它 ...

  2. python之socketserver ftp功能简单讲解

    TCP协议中的socket一次只能和一个客户端通信,然而socketserver可以实现和多个客户端通信. 它是在socket的基础上进行了一层封装,底层还是调用的socket # 服务端 impor ...

  3. python网络编程--socketserver 和 ftp功能简单说明

    1. socketserver 我们之前写的tcp协议的socket是不是一次只能和一个客户端通信,如果用socketserver可以实现和多个客户端通信.它是在socket的基础上进行了一层封装,也 ...

  4. FTP的搭建与虚拟目录作用<之简单讲解>

    操作系统:win7 VS2010编写WebService与在IIS的发布<之简单讲解>中我已经说了IIS安装与使用,不明白的可以跳过去看. 1.添加FTP站点 2. 3. 4. 5. zq ...

  5. Shiro 核心功能案例讲解 基于SpringBoot 有源码

    Shiro 核心功能案例讲解 基于SpringBoot 有源码 从实战中学习Shiro的用法.本章使用SpringBoot快速搭建项目.整合SiteMesh框架布局页面.整合Shiro框架实现用身份认 ...

  6. Android事件总线分发库EventBus3.0的简单讲解与实践

    Android事件总线分发库EventBus的简单讲解与实践 导语,EventBus大家应该不陌生,EventBus是一款针对Android优化的发布/订阅事件总线.主要功能是替代Intent,Han ...

  7. 关于SI4432的问题简单讲解

    对于SX1278 和SI4432的对比性,下面为大家展示对比参数: 由此可以看出的SI4432虽然跟SX1278有部分地方不同,但是整体来说还是差别不大,各有各的长处和短处,性价比上个人还是觉得SI4 ...

  8. 常用函数式接口与Stream API简单讲解

    常用函数式接口与Stream API简单讲解 Stream简直不要太好使啊!!! 常用函数式接口 Supplier<T>,主要方法:T get(),这是一个生产者,可以提供一个T对象. C ...

  9. SpringBoot切面Aop的demo简单讲解

    前言 本篇文章主要介绍的是SpringBoot切面Aop的demo简单讲解. SpringBoot Aop 说明:如果想直接获取工程那么可以直接跳到底部,通过链接下载工程代码. 切面(Aop) 一.概 ...

随机推荐

  1. Java中 Tomcat 是干什么的?

    Tomcat是web容器.它的作用稍后给你解释. 你在做web项目时,多数需要http协议,也就是基于请求和响应,比如你在百度输入一行内容搜索, 那么百度服务器如何处理这个请求呢,他需要创建servl ...

  2. 用原生js来处理跨域的数据(jsonp)

    说明总结: 1.ajax和jsonp其实本质上是不同的东西.ajax的核心是通过XmlHttpRequest获取非本页内容,而jsonp的核心则是动态添加<script>标签来调用服务器提 ...

  3. Mongodb脚本记录

    mongoexport -h -d stat_terminalbase -c stat_terminalbase -f terminal_mac,detect_time,site_id,device_ ...

  4. 几种RAID介绍(总结)

    概念 RAID是Redundent Array of Inexpensive Disks的缩写,简称为“磁盘阵列”.后来RAID中的字母I被改作了Independent,RAID就成了“独立冗余磁盘阵 ...

  5. Very Good Article on How Git Commands Work

    http://stackoverflow.com/questions/30038999/differences-between-commit-commit-and-push-commit-and-sy ...

  6. IDEA分享项目到GitHub出现Could not read from remote repository

    如果VCS->Import into Version Control->Share Project on GitHub出现如下错误:: 重点在最后一行Could not read from ...

  7. 在项目中使用react

    1. 运行 ’cnpm i react react-dom -S' 安装包 react:专门用于创建组件和虚拟DOM,同时组件的生命周期都在这个包中 react-dom:专门进行DOM操作,主要应用场 ...

  8. git 更新代码到本地

    正规流程 git status(查看本地分支文件信息,确保更新时不产生冲突) git checkout – [file name] (若文件有修改,可以还原到最初状态; 若文件需要更新到服务器上,应该 ...

  9. 深拷贝的原生js实现

    面试时被问到怎么实现深拷贝,想都没想就用var obj2=JSON.parse(JSON.stringify(obj1))来实现.但面试官却要我用循环写出来,那就只能用递归了.可惜当时一下子忘了判断是 ...

  10. position属性的总结

    static 默认.位置设置为 static 的元素,它始终会处于页面流给予的位置(static 元素会忽略任何 top.bottom.left 或 right 声明). relative 位置被设置 ...