简单的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(复习)的更多相关文章

  1. 路飞学城—Python爬虫实战密训班 第三章

    路飞学城—Python爬虫实战密训班 第三章 一.scrapy-redis插件实现简单分布式爬虫 scrapy-redis插件用于将scrapy和redis结合实现简单分布式爬虫: - 定义调度器 - ...

  2. 路飞学城—Python爬虫实战密训班 第二章

    路飞学城—Python爬虫实战密训班 第二章 一.Selenium基础 Selenium是一个第三方模块,可以完全模拟用户在浏览器上操作(相当于在浏览器上点点点). 1.安装 - pip instal ...

  3. 路飞学城Python爬虫课第一章笔记

    前言 原创文章,转载引用务必注明链接.水平有限,如有疏漏,欢迎指正. 之前看阮一峰的博客文章,介绍到路飞学城爬虫课程限免,看了眼内容还不错,就兴冲冲报了名,99块钱满足以下条件会返还并送书送视频. 缴 ...

  4. 路飞学城-Python开发集训-第3章

    学习心得: 通过这一章的作业,使我对正则表达式的使用直接提升了一个level,虽然作业完成的不怎么样,重复代码有点多,但是收获还是非常大的,有点找到写代码的感觉了,遗憾的是,这次作业交过,这次集训就结 ...

  5. 路飞学城-Python开发集训-第1章

    学习体会: 在参加这次集训之前我自己学过一段时间的Python,看过老男孩的免费视频,自我感觉还行,老师写的代码基本上都能看懂,但是实际呢?....今天是集训第一次交作业的时间,突然发现看似简单升级需 ...

  6. 路飞学城-Python开发集训-第4章

    学习心得: 学习笔记: 在python中一个py文件就是一个模块 模块好处: 1.提高可维护性 2.可重用 3.避免函数名和变量名冲突 模块分为三种: 1.内置标准模块(标准库),查看所有自带和第三方 ...

  7. 路飞学城-Python开发集训-第2章

    学习心得: 这章对编码的讲解超级赞,现在对于编码终于有一点认知了,但还没有大彻大悟,还需要更加细心的琢磨一下Alex博客和视频,以前真的是被编码折磨死了,因为编码的问题而浪费的时间很多很多,现在终于感 ...

  8. 路飞学城-Python开发-第二章

    ''' 数据结构: menu = { '北京':{ '海淀':{ '五道口':{ 'soho':{}, '网易':{}, 'google':{} }, '中关村':{ '爱奇艺':{}, '汽车之家' ...

  9. 路飞学城-Python开发-第三章

    # 数据结构: # goods = [ # {"name": "电脑", "price": 1999}, # {"name&quo ...

  10. 路飞学城-Python开发-第一章

    # 基础需求: # 让用户输入用户名密码 # 认证成功后显示欢迎信息 # 输错三次后退出程序 username = 'pandaboy' password = ' def Login(username ...

随机推荐

  1. 仅前端cookie之记住密码

    参考文章给忘了...,我就在他基础上修改了一些,但至于安全性,我没弄md5,所以安全系数应该为0 <!DOCTYPE html> <html lang="en"& ...

  2. [2] day 02

    1. df.memory_usage()将返回每列占用多少 要包含索引,请传递index=True所以要获得整体内存消耗: 2. numpy.iinfo 3. shift函数 https://blog ...

  3. springboot配置容器

    servlet容器配置 Spring Boot快速的原因除了自动配置外,另一个就是将web常用的容器也集成进来并做自动配置,让使用它的人能更快速的搭建web项目,快速的实现自己的业务目的.什么是容器? ...

  4. Impala ODBC 安装笔记

    Impala在线文档介绍了 Impala ODBC接口安装和配置 http://www.cloudera.com/content/cloudera-content/cloudera-docs/CDH5 ...

  5. DesignPattern_Java:Factory Method Pattern

    工厂方法模式 Factory Method :(虚拟构造函数模式 Virtual Constructor,多态性工厂模式 Ploymorphic Facoty) Define an interface ...

  6. hdu 4997 Biconnected

    这题主要是计算连通子图的个数(c)和不连通子图的个数(dc)还有连通度为1的子图的个数(c1)和连通度为2以上的子图的个数(c2)之间的转化关系 主要思路大概例如以下: 用状态压缩的方法算出状态为x的 ...

  7. Manarcher 求 字符串 的最长回文子串 【记录】

    声明:这里仅仅写出了实现过程.想学习Manacher的能够看下这里给出的实现过程,算法涉及的一些原理推荐个博客. 给个链接 感觉讲的非常细 引子:给定一个字符串s,让你求出最长的回文子串的长度. 算法 ...

  8. Oracle RMAN备份中catalog和nocatalog区别

    nocatalog方式:用control file作为catalog,每一次备份都要往控制文件里面写好多备份信息,控制文件里面会有越来越多的备份信息,即RMAN的备份信息写在本地控制文件里面. cat ...

  9. iis 部署

    配置错误1: 由于权限不足而无法读取配置文件 建立一个新用户,分配所有权限 http://blog.csdn.net/jaychouliyu/article/details/7237143 配置错误2 ...

  10. python中黏包现象

    #黏包:发送端发送数据,接收端不知道应如何去接收造成的一种数据混乱现象. #关于分包和黏包: #黏包:发送端发送两个字符串"hello"和"word",接收方却 ...