路飞学城Python-Day27(复习)
简单的socket通信
import socket
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
client.connect(('127.0.0.1', 8080))
msg = input('>>>').strip()
client.send(msg.encode('gbk'))
res = client.recv(1024)
print(res)
client.close()
客户端
import socket
sk = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sk.bind(('127.0.0.1', 8080))
sk.listen(5)
conn, addr = sk.accept()
res = conn.recv(1024)
conn.send(res.upper())
conn.close()
sk.close()
服务端
聊天版socket通信
import socket
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
client.connect(('127.0.0.1', 8080))
while True:
msg = input('发送信息>>>').strip()
client.send(msg.encode('gbk'))
re = client.recv(1024)
print('接收到的消息%s'%(re.decode('gbk')))
聊天版客户端
import socket
server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server.bind(('127.0.0.1', 8080))
server.listen(5)
while True:
conn,addr = server.accept()
while True:
try:
msg = conn.recv(1024)
print('接收到客户端的信息%s'%(msg.decode('gbk')))
re = input('请回复信息>>>').strip()
conn.send(re.encode('gbk'))
except ConnectionResetError:
pass
聊天版服务端
粘包版socket通信
import socket
import struct
import pickle
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
client.connect(('127.0.0.1', 8080))
while True:
msg = input('请输入发送的消息>>>').strip()
msg_dict = {
'msg':msg
}
msg_p = pickle.dumps(msg_dict)
client.send(struct.pack('i',len(msg_p)))
res = pickle.loads(client.recv(1024))
if res['confirm']:
client.send(msg.encode('gbk'))
else:
pass
粘包版客户端
import socket
import struct
import pickle
server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server.bind(('127.0.0.1', 8080))
server.listen(5)
while True:
conn, addr = server.accept()
while True:
res = conn.recv(4)
receive_bytes = struct.unpack('i',res)[0]
if receive_bytes<1024:
msg = {
'confirm': True,
}
msg_p = pickle.dumps(msg)
conn.send(msg_p)
res = conn.recv(1024)
print(res.decode('gbk'))
else:
msg = {
'confirm':False,
}
msg_p = pickle.dumps(msg)
conn.send(msg_p)
粘包版服务端
写一个异常
try:
int_number = int(input('请输入一个整数').strip())
print(int_number)
except Exception as e:
print(e)
写一个异常
自定义异常
class E(BaseException):
def __init__(self):
err = '发生异常了!'
BaseException.__init__(self,err)
raise E
自定义异常
windows系统版客户端和服务端
import socket
import pickle
import struct
import subprocess
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
client.connect(('127.0.0.1', 8080))
while True:
command = input('请输入命令>>>').strip()
msg_dict = {
'msg':command
}
msg = pickle.dumps(msg_dict)
client.send(struct.pack('i', len(msg)))
res = client.recv(1024)
if pickle.loads(res)['confirm']:
client.send(command.encode('gbk'))
# 解析长度
res_len = client.recv(4)
cmd_len = struct.unpack('i',res_len)[0]
# 接收结果
fin_res = client.recv(cmd_len).decode('gbk')
print(fin_res)
else:
print('超出字符限制,请重试!')
(系统命令版)客户端
import socket
import pickle
import struct
import subprocess
# a=subprocess.Popen('dir',shell=True,stdout=subprocess.PIPE)
# print(a.stdout.read().decode('gbk'))
server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server.bind(('127.0.0.1', 8080))
server.listen(5)
while True:
conn, addr = server.accept()
while True:
try:
res = conn.recv(4)
res_bytes = struct.unpack('i',res)[0]
if res_bytes<1024:
msg = {
'confirm':True,
}
conn.send(pickle.dumps(msg))
cmd = conn.recv(1024).decode('gbk')
cmd_res = subprocess.Popen(
cmd,
shell= True,
stdout= subprocess.PIPE,
stderr= subprocess.PIPE
)
res_cmd = cmd_res.stdout.read()
# 发送长度
conn.send(struct.pack('i',len(res_cmd)))
# 发送结果
conn.send(res_cmd)
else:
msg = {
'confirm': False,
}
conn.send(pickle.dumps(msg)) except Exception as e:
print(e)
break
(系统命令版)服务端
路飞学城Python-Day27(复习)的更多相关文章
- 路飞学城—Python爬虫实战密训班 第三章
路飞学城—Python爬虫实战密训班 第三章 一.scrapy-redis插件实现简单分布式爬虫 scrapy-redis插件用于将scrapy和redis结合实现简单分布式爬虫: - 定义调度器 - ...
- 路飞学城—Python爬虫实战密训班 第二章
路飞学城—Python爬虫实战密训班 第二章 一.Selenium基础 Selenium是一个第三方模块,可以完全模拟用户在浏览器上操作(相当于在浏览器上点点点). 1.安装 - pip instal ...
- 路飞学城Python爬虫课第一章笔记
前言 原创文章,转载引用务必注明链接.水平有限,如有疏漏,欢迎指正. 之前看阮一峰的博客文章,介绍到路飞学城爬虫课程限免,看了眼内容还不错,就兴冲冲报了名,99块钱满足以下条件会返还并送书送视频. 缴 ...
- 路飞学城-Python开发集训-第3章
学习心得: 通过这一章的作业,使我对正则表达式的使用直接提升了一个level,虽然作业完成的不怎么样,重复代码有点多,但是收获还是非常大的,有点找到写代码的感觉了,遗憾的是,这次作业交过,这次集训就结 ...
- 路飞学城-Python开发集训-第1章
学习体会: 在参加这次集训之前我自己学过一段时间的Python,看过老男孩的免费视频,自我感觉还行,老师写的代码基本上都能看懂,但是实际呢?....今天是集训第一次交作业的时间,突然发现看似简单升级需 ...
- 路飞学城-Python开发集训-第4章
学习心得: 学习笔记: 在python中一个py文件就是一个模块 模块好处: 1.提高可维护性 2.可重用 3.避免函数名和变量名冲突 模块分为三种: 1.内置标准模块(标准库),查看所有自带和第三方 ...
- 路飞学城-Python开发集训-第2章
学习心得: 这章对编码的讲解超级赞,现在对于编码终于有一点认知了,但还没有大彻大悟,还需要更加细心的琢磨一下Alex博客和视频,以前真的是被编码折磨死了,因为编码的问题而浪费的时间很多很多,现在终于感 ...
- 路飞学城-Python开发-第二章
''' 数据结构: menu = { '北京':{ '海淀':{ '五道口':{ 'soho':{}, '网易':{}, 'google':{} }, '中关村':{ '爱奇艺':{}, '汽车之家' ...
- 路飞学城-Python开发-第三章
# 数据结构: # goods = [ # {"name": "电脑", "price": 1999}, # {"name&quo ...
- 路飞学城-Python开发-第一章
# 基础需求: # 让用户输入用户名密码 # 认证成功后显示欢迎信息 # 输错三次后退出程序 username = 'pandaboy' password = ' def Login(username ...
随机推荐
- 【数据分析】算法+Echarts小练
''' 处理逻辑: 按number去处理 先遍历所有的number挨个去找有没有在列表里的,在列表里的拿出另外一个append 把number去除的列表 ''' li = [] with open(r ...
- MySQL py模块的链接Navicat可视化工具
数据库可视化工具Navicat 1 基本操作: 1 库 表 字段 记录(增删改查) 2 添加主建,添加自增. 3 添加外键,外键的链接 4 模型建表,模型添加外键.(逆向数据库到模型,运行SQL文件 ...
- hive 自定义函数(udf)
1.解压hive的压缩包 2.新建java项目,将hive压缩包里面lib文件夹的jar包导入新建的项目 3.编写java程序 package udfdemo; import org.apache.h ...
- 在windows环境中关于 pycharm配置 anaconda 虚拟环境
因为要在windows系统系统中练习tensorflow,所以需要配置一下环境(来回的开关机切换环境太麻烦了......) 首先安装anaconda3,我选择的版本是Anaconda3 5.1.0,对 ...
- ACdream 1229 Data Transmission
Data Transmission Special JudgeTime Limit: 12000/6000MS (Java/Others)Memory Limit: 128000/64000KB (J ...
- 双向链表的实现与操作(C语言实现)
双向链表也叫双链表,是链表的一种,它的每一个数据结点中都有两个指针,分别指向直接后继和直接前驱.所以,从双向链表中的随意一个结点開始,都能够非常方便地訪问它的前驱结点和后继结点. 单链表的局限 1.单 ...
- Unity里包裹Debug,且不影响Debug的重定向
Debug.Log, Debug.LogWarning, Debug.LogError在project中常常须要再包裹一层.做些定制.也方便开关Log.但有一个问题时.当用一个类将Debug包裹起来后 ...
- 怎样通过反编译工具与插件 查看java *.class 文件源代码
Java Decompiler[java 反编译]:开发了反编译工具.能够方便查看*.class 文件源代码.以下介绍几种查看源代码的方式:工具&插件 1.JD-GUI JD-GUI 是显示 ...
- XML系统学习
参考:W3School XML基本概念 1.XML是eXtensible Markup Language,使用DTD(Document Type Definition)来描述数据,主要是为传输和存储数 ...
- win7-32虚拟机安装
前置条件:安装好VMware-workstation 一.本人本机win7—32位 准备win7_32位镜像文件GSP1RMCULFRER_CN_DVD.iso 新建一个文件夹,将它保存在我们的新建文 ...