因为该方法采用ascii与正则匹配字母和数字,所以无法匹配中文等其他字符
所以需要修改源码。找到Lib\site-packages\werkzeug\utils的secure_filename方法
初始代码:
_filename_ascii_strip_re = re.compile(r"[^A-Za-z0-9_.-]")#原始正则
if isinstance(filename, text_type):
from unicodedata import normalize
filename = normalize("NFKD", filename).encode("ascii", "ignore")
if not PY2:
filename = filename.decode("ascii")
for sep in os.path.sep, os.path.altsep:
if sep:
filename = filename.replace(sep, " ")
filename = str(_filename_ascii_strip_re.sub("", "_".join(filename.split()))).strip(
"._"
)
改后的代码:
if isinstance(filename, text_type):
from unicodedata import normalize
filename = normalize("NFKD", filename).encode("utf-8", "ignore")
if not PY2:
filename = filename.decode("utf-8")
for sep in os.path.sep, os.path.altsep:
if sep:
filename = filename.replace(sep, " ")
_filename_ascii_add_strip_re = re.compile(r'[^A-Za-z0-9_\u4E00-\u9FBF.-]')#新的正则
filename = str(_filename_ascii_add_strip_re.sub("", "_".join(filename.split()))).strip(
"._"
)