shell脚本中如何高效的encode一个字符串

shell脚本中如何高效的encode一个字符串

`

function urlencode() {

local length="${#1}"

for (( i = 0; i < length; i++ )); do

local c="${1:i:1}"

case $c in

[a-zA-Z0-9.~_-]) printf "$c" ;;

*) printf "$c" | xxd -p -c1 | while read x;do printf "%%%s" "$x";done

esac

done

}

`
目前是用这个函数encode的,效率特别低,100多k的文件都encode很久,请问如何encode快一些,可以在shell借助什么库吗?


回答:

$ alias urldecode='python -c "import sys, urllib as ul; \

print ul.unquote_plus(sys.argv[1])"'

$ alias urlencode='python -c "import sys, urllib as ul; \

print ul.quote_plus(sys.argv[1])"'

$ urlencode 'lalala啦啦啦'

lalala%E5%95%A6%E5%95%A6%E5%95%A6

$ urldecode 'alala%E5%95%A6%E5%95%A6%E5%95%A6'

alala啦啦啦

参考: https://www.cnblogs.com/Bob-w...


回答:

不知道你编码的具体用途。

若是 HTTP 请求,则不可能用在请求头,因你提到 100KB 的文件。那么猜测应该是请求体(body),这种情况可以用 curl 命令,如

curl --data-urlencode 'content@somefile.bin' http://localhost/

这会上传文件 somefile.bin,自动做 url 编码。

参考 man curl


回答:

@Yujiaao
你的写法应该是python2的写法

我这里是python3的写法

[jian@laptop ~]$ python

Python 3.6.7 (default, Mar 21 2019, 20:23:57)

[GCC 8.3.1 20190223 (Red Hat 8.3.1-2)] on linux

Type "help", "copyright", "credits" or "license" for more information.

>>>

[jian@laptop ~]$ alias urlencode='python -c "import sys, urllib.parse as ul; \

print (ul.quote(sys.argv[1]))"'

[jian@laptop ~]$ urlencode 'lalala啦啦啦'

lalala%E5%95%A6%E5%95%A6%E5%95%A6

[jian@laptop ~]$ alias urldecode='python -c "import sys, urllib.parse as ul; \

print (ul.unquote(sys.argv[1]))"'

[jian@laptop ~]$ urldecode 'alala%E5%95%A6%E5%95%A6%E5%95%A6'

alala啦啦啦

以上是 shell脚本中如何高效的encode一个字符串 的全部内容, 来源链接: utcz.com/a/162270.html

回到顶部