一、eval语法
先介绍一下eval的语法:eval(expression, globals=None, locals=None)
它有三个参数,其中 expression 是一个字符串类型的表达式或代码对象,用于做运算;globals 与 locals 是可选参数,默认值是 None。
globals 用于指定运行时的全局命名空间,类型是字典,缺省时使用的是当前模块的内置命名空间。locals 指定运行时的局部命名空间,类型是字典,缺省时使用 globals 的值。两者都缺省时,则遵循 eval 函数执行时的作用域。值得注意的是,这两者不代表真正的命名空间,只在运算时起作用,运算后则销毁。
二、问题场景
由于业务需要,对eval进行了hook,hook方法大概如下:
import builtins
import os
def eval_hook(func):
print("eval: ", func)
def wrapper(*args, **kwargs):
# 逻辑处理
return func(*args, **kwargs)
return wrapper
builtins.eval = eval_hook(builtins.eval)
在脚本中进行调用时会发现;