day-18网络编程

2018-11-28  本文已影响0人  L_4bc8

1.回顾

1.1.正则符号

a.匹配字符

.
\w
\s
\d 
\W
\S
\D
[字符集] \ [^字符集]

b.边界检测

\b
^
$

c.匹配次数

*
+
?
{N}, {M,N}, {,N}, {M,}
贪婪?

d.分之、分组

|
() - 分组,捕获,重复

e.转义符号

特殊符号前加\

1.2.re模块

fullmatch - 检测一个字符串是否ip/检测账号密码是否符号要求/检测输入的内容是否是手机号、邮箱 - 匹配对象
match - 检测字符串开头是否满足要求 - 匹配对象
sreach - 判断字符串中是否存在满足要求的子串 - 匹配对象
split - 字符串切割
sub - 字符串替换
findall - 获取子串
finditer - 获取所有的匹配结果(迭代器)

2.socket编程

socket又叫套接字,指的就是实现通信过程的两个端。等待请求的一端叫服务端套接字,发送请求的一端叫客户端套接字

python中提供了socket模块来支持socket编程

2.1.创建套接字对象

socket(family, type)
family - 设置ip类型 AF_INET(默认值) - ipv4 AF_INET6 - ipv6
type - 设置传输类型 SOCK_STREAM(默认值) - tcp SOCK_DGRAM - udp

  import socket
# 创建一个基于ipv4和TCP的套接字对象
server = socket.socket()

2.2.绑定ip地址和端口

bind((ip地址, 端口号))
ip地址 - 服务器对应的计算机的ip地址,字符串
端口号 - 用来区分计算机上不同服务; 是一个数字,范围是0~65535;
但是其中1024以下的是著名端口,用来表示一个特殊的服务,一般不要用;
同一时间一个端口只能对应一个服务

server.bind(('10.7.187.149', 8081))

2.3.开始监听

listen(最大监听数)
最大监听数 - 用来设置当前服务器一次可以处理多少个请求

server.listen(100)
print('开始监听')
``
## 2.4. 让服务一直处于启动状态

while True:

2.5.接收客户端发送的请求,返回建立的会话和客户端地址;

 注意,这段代码会阻塞线程(程序运行到这儿会停下来,直到有客户端给当前服务器发送请求为止)
    conversation, addr = server.accept()
    print('接收到请求:', addr)

2.6接收消息(客户端发送给服务器的消息)

recv(缓存大小) - 获取客户端给服务器发送的数据,返回值是二进制
缓存大小 - 决定一次可以接收的数据的最大字节数

这儿也会阻塞线程,直到客户端发送了消息才会接着往后执行

re_data = conversation.recv(1024)
    print('======')
    print(re_data.decode('utf-8'))
##2.7.发送数据(服务器给客户端发送数据)
    send(数据) - 将指定的数据发送给客户端
    数据 - 要求是二进制
    
    字符串(str)转二进制(bytes):
    a.bytes(字符串, 'utf-8')
    b.字符串.encode('utf-8')
    
    二进制转字符串
    a.str(二进制数据, 'utf-8')
    b.二进制.decode('utf-8')

  # message = 'HTTP/1.1 200 OK\r\n\r\n <html><<head><meta charset="utf-8" /><title>表格</title></head><body>你好!</body></html>'
    message = '你好!!!'
    # conversation.send(bytes(message, encoding='utf-8'))
    conversation.send(message.encode(encoding='utf-8'))

    # 8.关闭连接
    conversation.close()

3. 客户端套接字

import socket

# 1.创建套接字对象
client = socket.socket()

# 2.连接服务器
"""
connect((ip, 端口))
"""
client.connect(('172.21.203.2', 8088))

# 3.发送消息
message = input('>>')
client.send(message.encode('utf-8'))

# 4.接收消息
re_data = client.recv(1024)
print(re_data.decode('utf-8'))

4.服务器储存图片信息

import socket

# 1.创建套接字对象
server = socket.socket()

# 2.绑定ip和端口
server.bind(('10.7.187.149', 9093))

# 3.监听
server.listen(512)
print('开始监听!')

while True:
    # 4.接收请求
    conversation, addr = server.accept()
    print(addr)
    # ==========2.保持通话==============
    while True:
        # 接收消息
        data = conversation.recv(1024)
        print('客户端:', data.decode('utf-8'))

        # 发送消息
        message = input('服务器:')
        conversation.send(message.encode('utf-8'))

    # ===========1.发送图片=============
    # with open('luffy.png', 'br') as f:
    #     content = f.read()
    #     conversation.send(content)
    #
    # conversation.close()

5.客户端接收图片信息

"""__author__ = 余婷"""

import socket

client = socket.socket()
client.connect(('10.7.187.149', 9092))

# ========2.保持通话=============
while True:
    # 发送消息
    message = input('客户端:')
    client.send(message.encode('utf-8'))

    # 接收消息
    data = client.recv(1024)
    print('服务器:', data.decode('utf-8'))


# ========1.接收图片==========
# 不断接收数据,直到接收完为止
# 创建一个空的二进制数据
# data = bytes()
# while True:
#     re_data = client.recv(1024)
#     data += re_data
#     print('接收到数据!')
#     if not re_data:
#         break
#
# print('数据接收完了')
# with open('new.png', 'bw') as f:
#     f.write(data)

7.网络请求

python中去做http请求,需要使用一个第三方库: requests
get(url, 参数字典) - 返回响应

7.1.向服务器发送get请求

import requests
# a.手动拼接url
# url = 'https://www.apiopen.top/satinApi?type=1&page=1'
# response = requests.get(url)
# print(response)
# b.自动拼接url
url = 'https://www.apiopen.top/satinApi'
response = requests.get(url, {'type': 1, 'page': 1})
print(response)

7.2.获取响应头

header = response.headers
print(header)

7.3.获取响应体

a.获取二进制格式的响应体

content = response.content
print(type(content))

b.获取json格式响应体 - 自动将json数据转换成python

json = response.json()
print(type(json))

c.获取字符串格式的响应体

text = response.text
print(type(text))

##应用:下载网络图片

url = 'https://timgsa.baidu.com/timg?image&quality=80&size=b10000_10000&sec=1543395098&di=2a5bbaa5600097b050ba69a688672de9&src=http://p0.qhimgs4.com/t0112e7ebfdef7f923d.jpg'
response = requests.get(url)
image_data = response.content
with open('王也.jpg', 'wb') as f:
    f.write(image_data)

上一篇 下一篇

猜你喜欢

热点阅读