mirror of
https://github.com/juewuy/ShellCrash.git
synced 2026-03-11 07:51:45 +00:00
77 lines
2.9 KiB
Bash
77 lines
2.9 KiB
Bash
. "$CRASHDIR"/libs/set_proxy.sh
|
||
|
||
webget(){
|
||
if pidof CrashCore >/dev/null; then
|
||
setproxy #设置临时代理,【$1】代表下载目录,【$2】代表在线地址
|
||
url=$(printf '%s\n' "$2" |
|
||
sed -e 's#https://.*jsdelivr.net/gh/juewuy/ShellCrash[@|/]#https://raw.githubusercontent.com/juewuy/ShellCrash/#' \
|
||
-e 's#https://gh.jwsc.eu.org/#https://raw.githubusercontent.com/juewuy/ShellCrash/#')
|
||
else
|
||
url=$(printf '%s\n' "$2" |
|
||
sed 's#https://raw.githubusercontent.com/juewuy/ShellCrash/#https://testingcf.jsdelivr.net/gh/juewuy/ShellCrash@#')
|
||
fi
|
||
# ===============================================
|
||
|
||
#参数【$1】代表下载目录,【$2】代表在线地址
|
||
#参数【$3】代表输出显示,【$4】不启用重定向
|
||
#参数【$5】代表验证证书,【$6】使用自定义UA
|
||
[ -n "$6" ] && agent="--user-agent $6"
|
||
if wget --help 2>&1 | grep -q 'show-progress' >/dev/null 2>&1; then
|
||
[ "$3" = "echooff" ] && progress='-q' || progress='-q --show-progress'
|
||
[ "$4" = "rediroff" ] && redirect='--max-redirect=0' || redirect=''
|
||
if [ "$5" = "skipceroff" ] || [ "$skip_cert" = OFF ];then
|
||
certificate=''
|
||
else
|
||
certificate='--no-check-certificate'
|
||
fi
|
||
wget -Y on $agent $progress $redirect $certificate --timeout=3 -O "$1" "$url" && return 0 #成功则退出否则重试
|
||
wget -Y off $agent $progress $redirect $certificate --timeout=5 -O "$1" "$2"
|
||
return $?
|
||
elif curl --version >/dev/null 2>&1; then
|
||
if [ "$3" = "echooff" ];then
|
||
progress='-s'
|
||
elif echo "$url" | grep -q 'jsdelivr.net';then
|
||
. "$CRASHDIR"/libs/web_get_curlbar.sh && curl_fsize
|
||
else
|
||
progress='-#'
|
||
fi
|
||
[ "$4" = "rediroff" ] && redirect='' || redirect='-L'
|
||
if [ "$5" = "skipceroff" ] || [ "$skip_cert" = OFF ];then
|
||
certificate=''
|
||
else
|
||
certificate='-k'
|
||
fi
|
||
# curl 特殊版本兼容
|
||
auth_arg=""
|
||
if curl --version | grep -q '^curl 8.' && ckcmd base64; then
|
||
auth_b64=$(printf '%s' "$authentication" | base64)
|
||
[ -n "$auth_b64" ] && auth_arg="--proxy-header Proxy-Authorization:Basic $auth_b64"
|
||
fi
|
||
if [ -n "$fsize_raw" ] && [ "$fsize_raw" -gt 204800 ]; then
|
||
result=$(execute_curl "$1" "$url" "$fsize_raw" "$agent $auth_arg $redirect $certificate")
|
||
else
|
||
result=$(curl $agent $auth_arg -w '%{http_code}' --connect-timeout 3 $progress $redirect $certificate -o "$1" "$url")
|
||
fi
|
||
|
||
[ "$result" = "200" ] && return 0 #成功则退出否则重试
|
||
export https_proxy=""
|
||
export http_proxy=""
|
||
|
||
if [ -n "$fsize_raw" ] && [ "$fsize_raw" -gt 204800 ]; then
|
||
result=$(execute_curl "$1" "$2" "$fsize_raw" "$agent $redirect $certificate")
|
||
else
|
||
result=$(curl $agent -w '%{http_code}' --connect-timeout 5 $progress $redirect $certificate -o "$1" "$2")
|
||
fi
|
||
[ "$result" = "200" ]
|
||
return $?
|
||
elif ckcmd wget;then
|
||
[ "$3" = "echooff" ] && progress='-q'
|
||
wget -Y on $progress -O "$1" "$url" && return 0 #成功则退出否则重试
|
||
wget -Y off $progress -O "$1" "$2"
|
||
return $?
|
||
else
|
||
echo "No Curl or Wget!!!"
|
||
return 1
|
||
fi
|
||
}
|