当我使用 bash 获取网页但仅当我在另一个函数中调用我的函数时,我收到 400 Bad Request 响应标头?
get_download_page() {
[ $# -eq 1 ] || die "get_location: 1 argument expected, recieved $#"
page="$(get_page $1)/download"
echo "http://www.curse.com$(curl --silent -I $page | awk 'NR==4 { print; exit }' | cut -d\ -f2)"
}
get_page() {
[ $# -eq 1 ] || die "get_page: 1 argument expected, recieved $#"
echo "www.curse.com/addons/wow/$1"
}
get_file() {
[ $# -eq 1 ] || die "get_file: 1 argument expected, recieved $#"
echo $(curl -s $1 | sed -rn 's/.*data-href="([^"]+)".*/\1/p')
}
fetch_addon() {
[ $# -eq 1 ] || die "fetch_addon: 1 argument expected, recieved $#"
download=$(get_download_page $1)
file=$(get_file $download)
echo $file
}
IE
打电话给fetch_addon "bagnon"
我一个错误的请求标头。
但如果我这样做:get_file "http://www.curse.com/addons/wow/bagnon/704176"
http://addons.curse.cursecdn.com/files/704/176/Bagnon_5.3.zip
这是我所期望的,即使get_download_page "bagnon"
返回我传递给的相同链接get_file
?
如图所示:
get_download_page "bagnon"
echo "http://www.curse.com/addons/wow/bagnon/704176"
输出:
http://www.curse.com/addons/wow/bagnon/704176
http://www.curse.com/addons/wow/bagnon/704176
经过进一步调查,这两个字符串似乎并不完全相等。当我做
echo $(cmp -bl <(echo "$download") <(echo "http://www.curse.com/addons/wow/bagnon/704176"))
我得到这个输出:
46 15 ^M 12 ^J
即生成的下载链接最后一个字符是^M,手动找到的下载链接最后一个字符是^J