今日内容概要
- hashlib加密模块
- subprocess模块
- logging模块
- 软件开发主要流程
hashlib加密模块
1.什么是加密?
将明文数据处理成密文数据,让人无法看懂
2.为什么要加密?
保证数据的安全防止被人看懂盗用
3.如何判断数据是否是加密数据?
加密的密文都是由一串没有规律的字符串(数字,字母,符号)组成
4.密文的长短有什么讲究?
密文越长表示使用的加密算法(数据的处理过程)越复杂
5.常见的加密算法有哪些?
md5、base64、hmac、sha系列
6.加密算法的基本操作
import hashlib
# 1.选择加密的算法
md5 = hashlib.md5()
# 2.传入明文数据
md5.update(b'hello')
# 3.获取加密密文
res = md5.hexdigest()
print(res)
输出结果:
5d41402abc4b2a76b9719d911017c592
加密补充说明
1.加密算法不变,内容如果相同的话,那么结果肯定相同
# md5.update(b'hello~world') # 一次性的传数据可以
# 21342e79ace7d355b6ce1bb728ef84be
md5.update(b'hello') # 分多次传也可以
md5.update(b'~world')
# 21342e79ace7d355b6ce1bb728ef84be
res =md5.hexdigest()
print(res)
2.加密之后的的结果是无法反解密的
只能丛明文到密文正向推导,无法从密文到明文的反向推导,常见的解密过程其实就是有的程序员因为太闲了提前记录下一些简单的明文的密文,提前猜测的一些结果。
例如:
123 密文
321 密文
111 密文
3.加盐处理
如果数据量很大,可以分块多次调用update(),最后计算的结果是一样的:
在明文里面添加一些额外的干扰项
1.选择加密算法
md5 = hashlib.md5()
2.传入明文数据
md5.update('为项目文件设置的干扰项'.encode('utf8'))
md5.update(b'hello ppython') # 一次性传可以
3.获取加密密文
res = md5.hexdigest()
print(res) # e53024684c9be1dd3f6114ecc8bbdddc
4.动态加盐
干扰项是随机变化的
比较常用的有:当前时间、用户的用户名的一部分。。。
5.加密实战操作
1.用户密码加密
2.文件安全性校验
3.文件内容加密
4.大文件内容加密
截取部分内容加密即可
任何允许用户登录的网站都会存储用户登录的用户名和口令。如何存储用户名和口令呢?方法是存到数据库表中:
ame | password
--------+----------
michael | 123456
bob | abc999
alice | alice2008
subprocess模块
python执行shell脚本,通常会使用so模块中的几个方法,如system、spawn*、popen等。
subprocess标准库的引入就是为了取代这些老的模块方法。subprocess使用时,父进程创建子进程去执行一个外部程序,并提供了标准输入输出和管道(pipe)的实现方法。
该模块适用于配置文件的格式与windows ini文件类似,可以包含一个或多个节(section),每个节可以有多个参数(键=值)。
subprocess.Popen()
模拟操作系统终端,执行命令并获取执行结果
import subprocess
res =subprocess.Popen(
'asdas', # 操作系统要执行的命令
shell= True,# 固定配置
stdin = subprocess.PIPE, # 输入命令
stdout = subprocess.PIPE # 输出结果
)
print('正确结果',res.stdout.read().decode('gbk')) # 获取操作系统执行命令之后的正确结果
print('错误结果',res.stderr) # 获取操作系统执行命令之后的错误结果
# 正确结果
# 错误结果 None
# 'asdas' �����ڲ����ⲿ���Ҳ���ǿ����еij���
# ���������ļ���
logging日志模块
1.如何理解日志模块
简单的理解为就是记录行为的一种操作员(就像古时候记录历史的史官)
2.日志的级别 (日志模块不必掌握多深,会用即可)
有五种,重要程度从上往下,越往下越重要
import logging
logging.debug('debug message') 调试错误
logging.info('info messge') # 信息
logging.warning('warning messge') #警告,
logging.error('error messge') #错误
logging.critical('critical messge') #严重的,危机的
file_handler = logging.FileHandler(filename='x1.log', mode='a', encoding='utf8',)
logging.basicConfig(
format='%(asctime)s - %(name)s - %(levelname)s -%(module)s: %(message)s',
datefmt='%Y-%m-%d %H:%M:%S %p',
handlers=[file_handler,],
level=logging.ERROR
)
logging.error('你好呀')
日志的组成
1.产生日志,过滤日志,日志格式,输出日志
小提示:过滤日志基本不怎么使用,因为在日志产生阶段就可以控制想要的日志内容
logging参数配置
logging.basicConfig()函数中可通过具体参数来更改logging模块默认行为,可用参数有:
filename:用指定的文件名创建FiledHandler,这样日志会被存储在指定的文件中。
filemode:文件打开方式,在指定了filename时使用这个参数,默认值为“a”还可指定为“w”。
format:指定handler使用的日志显示格式。
datefmt:指定日期时间格式。
level:设置rootlogger(后边会讲解具体概念)的日志级别
stream:用指定的stream创建StreamHandler。可以指定输出到sys.stderr,sys.stdout或者文件(f=open(‘test.log’,’w’)),默认为sys.stderr。若同时列出了filename和stream两个参数,则stream参数会被忽略。
format参数中可能用到的格式化串:
%(name)s Logger的名字
%(levelno)s 数字形式的日志级别
%(levelname)s 文本形式的日志级别
%(pathname)s 调用日志输出函数的模块的完整路径名,可能没有
%(filename)s 调用日志输出函数的模块的文件名
%(module)s 调用日志输出函数的模块名
%(funcName)s 调用日志输出函数的函数名
%(lineno)d 调用日志输出函数的语句所在的代码行
%(created)f 当前时间,用UNIX标准的表示时间的浮 点数表示
%(relativeCreated)d 输出日志信息时的,自Logger创建以 来的毫秒数
%(asctime)s 字符串形式的当前时间。默认格式是 “2003-07-08 16:49:45,896”。逗号后面的是毫秒
%(thread)d 线程ID。可能没有
%(threadName)s 线程名。可能没有
%(process)d 进程ID。可能没有
%(message)s用户输出的消息
复制代码
import logging
# 1.日志的产生(准备原材料)
logger对象logger = logging.getLogger('购物车记录')
# 2.日志的过滤(剔除不良品) filter对象>>>:可以忽略 不用使用
# 3.日志的产出(成品) handler对象
hd1 = logging.FileHandler('a1.log', encoding='utf-8') # 输出到文件中
hd2 = logging.FileHandler('a2.log', encoding='utf-8') # 输出到文件中
hd3 = logging.StreamHandler() # 输出到终端
# 4.日志的格式(包装) format对象
fm1 = logging.Formatter(
fmt='%(asctime)s - %(name)s - %(levelname)s -%(module)s: %(message)s',
datefmt='%Y-%m-%d %H:%M:%S %p',)fm2 = logging.Formatter( fmt='%(asctime)s - %(name)s: %(message)s', datefmt='%Y-%m-%d',)
# 5.给logger对象绑定handler对象
logger.addHandler(hd1)
logger.addHandler(hd2)
logger.addHandler(hd3)
# 6.给handler绑定formmate对象
hd1.setFormatter(fm1)
hd2.setFormatter(fm2)
hd3.setFormatter(fm1)
# 7.设置日志等级logger.setLevel(10) # debug
# 8.记录日志logger.debug('写了半天 好累啊 好热啊')
日志配置字典
import logging
import logging.config
# 定义日志输出格式 开始
standard_format = '[%(asctime)s][%(threadName)s:%(thread)d][task_id:%(name)s][%(filename)s:%(lineno)d]' \
'[%(levelname)s][%(message)s]' # 其中name为getlogger指定的名字
simple_format = '[%(levelname)s][%(asctime)s][%(filename)s:%(lineno)d]%(message)s'
# 自定义文件路径
logfile_path = 'a3.log'
LOGGING_DIC = {
'version': 1,
'disable_existing_loggers': False,
'formatters': {
'standard': {
'format': standard_format
},
'simple': {
'format': simple_format
},
},
'filters': {}, # 过滤日志
'handlers': {
# 打印到终端的日志
'console': {
'level': 'DEBUG',
'class': 'logging.StreamHandler', # 打印到屏幕
'formatter': 'simple'
},
# 打印到文件的日志,收集info及以上的日志
'default': {
'level': 'DEBUG',
'class': 'logging.handlers.RotatingFileHandler', # 保存到文件
'formatter': 'standard',
'filename': logfile_path, # 日志文件
'maxBytes': 1024 * 1024 * 5, # 日志大小 5M
'backupCount': 5,
'encoding': 'utf-8', # 日志文件的编码,再也不用担心中文log乱码了
},
},
'loggers': {
# logging.getLogger(__name__)拿到的logger配置 动态获取日志名称
'': {
'handlers': ['default', 'console'], # 这里把上面定义的两个handler都加上,即log数据既写入文件又打印到屏幕
'level': 'DEBUG',
'propagate': True, # 向上(更高level的logger)传递
}, # 当键不存在的情况下 (key设为空字符串)默认都会使用该k:v配置
# '购物车记录': {
# 'handlers': ['default','console'], # 这里把上面定义的两个handler都加上,即log数据既写入文件又打印到屏幕
# 'level': 'WARNING',
# 'propagate': True, # 向上(更高level的logger)传递
# }, # 当键不存在的情况下 (key设为空字符串)默认都会使用该k:v配置
},
}
logging.config.dictConfig(LOGGING_DIC) # 自动加载字典中的配置
# logger1 = logging.getLogger('购物车记录')
# logger1.warning('尊敬的VIP客户 晚上好 您又来啦')
# logger1 = logging.getLogger('注册记录')
# logger1.debug('jason注册成功')
logger1 = logging.getLogger('登录记录')
logger1.debug('Andy登录成功')
标签:hashlib,logging,python,模块,密文,加密,日志,md5
From: https://www.cnblogs.com/qiguanfusu/p/16833350.html