有没有办法将 unicode 编码为 base64 的人类可读变体(在 python 中)



我想对来自Web界面的用户输入值进行编码,以便我可以以安全的方式将数据传递到我的系统中。换句话说,我想去掉我认为不好的字符,例如引号和括号等。

我可以使用base64,它可以正常工作。但是,我希望能够读取字符串,如果它们最初是较低层人类可读格式的字母数字。

因此,'Nice string'将被编码为'Nice string''N@sty!!``string!!))'将被编码为类似 "N=E2sty=B3=B3=XY=XYstring=B3=B3=B1=B1" .我只是编造的,但你明白了。

是否存在这样的编码格式,特别是它存在于 python 中。

怎么样:

urllib.quote("'N@sty!!`` string,!!))'",safe=" ,.").replace('%','=')
'=27N=40sty=21=21=60=60 string,=21=21=29=29=27'
您可以使用

urllib.quote

>>> urllib.quote("Nice String");
'Nice%20String'
>>> urllib.quote("N@sty!!``string!!))");
'N%40sty%21%21%60%60string%21%21%29%29'

我认为Punycode可以满足您的需求。

import encodings.punycode
encoded = encodings.punycode.punycode_encode(inputstr)

相关内容

  • 没有找到相关文章

最新更新