#!/bin/bash red='\e[91m' green='\e[92m' yellow='\e[93m' magenta='\e[95m' cyan='\e[96m' none='\e[0m' # Root [[ $(id -u) != 0 ]] && echo -e " 哎呀……请使用 ${red}root ${none}用户运行 ${yellow}~(^_^) ${none}" && exit 1 cmd="apt-get" sys_bit=$(uname -m) if [[ $sys_bit == "i386" || $sys_bit == "i686" ]]; then v2ray_bit="32" elif [[ $sys_bit == "x86_64" ]]; then v2ray_bit="64" else echo -e " 哈哈……这个 ${red}辣鸡脚本${none} 不支持你的系统。 ${yellow}(-_-) ${none}" && exit 1 fi # 笨笨的检测方法 if [[ -f /usr/bin/apt-get ]] || [[ -f /usr/bin/yum && -f /bin/systemctl ]]; then if [[ -f /usr/bin/yum ]]; then cmd="yum" fi if [[ -f /bin/systemctl ]]; then systemd=true fi else echo -e " 哈哈……这个 ${red}辣鸡脚本${none} 不支持你的系统。 ${yellow}(-_-) ${none}" && exit 1 fi uuid=$(cat /proc/sys/kernel/random/uuid) old_id="23332333-2333-2333-2333-233boy233boy" v2ray_server_config="/etc/v2ray/config.json" v2ray_client_config="/etc/v2ray/233blog_v2ray_config.json" backup="/etc/v2ray/233blog_v2ray_backup.conf" transport=( TCP TCP_HTTP WebSocket "WebSocket + TLS" mKCP mKCP_utp mKCP_srtp mKCP_wechat-video TCP_dynamicPort TCP_HTTP_dynamicPort WebSocket_dynamicPort mKCP_dynamicPort mKCP_utp_dynamicPort mKCP_srtp_dynamicPort mKCP_wechat-video_dynamicPort HTTP/2 Socks5 ) ciphers=( aes-128-cfb aes-256-cfb chacha20 chacha20-ietf aes-128-gcm aes-256-gcm chacha20-ietf-poly1305 ) v2ray_config() { # clear echo while :; do echo -e "请选择 "$yellow"V2Ray"$none" 传输协议 [${magenta}1-${#transport[*]}$none]" echo for ((i = 1; i <= ${#transport[*]}; i++)); do Stream="${transport[$i - 1]}" if [[ "$i" -le 9 ]]; then # echo echo -e "$yellow $i. $none${Stream}" else # echo echo -e "$yellow $i. $none${Stream}" fi done echo echo "备注1: 含有 [dynamicPort] 的即启用动态端口.." echo "备注2: [utp | srtp | wechat-video] 分别为 伪装成 [BT下载 | 视频通话 | 微信视频通话]" echo read -p "$(echo -e "(默认协议: ${cyan}TCP$none)"):" v2ray_transport_opt [ -z "$v2ray_transport_opt" ] && v2ray_transport_opt=1 case $v2ray_transport_opt in [1-9] | 1[0-7]) echo echo echo -e "$yellow V2Ray 传输协议 = $cyan${transport[$v2ray_transport_opt - 1]}$none" echo "----------------------------------------------------------------" echo break ;; *) error ;; esac done v2ray_port_config } v2ray_port_config() { case $v2ray_transport_opt in [1-3] | [5-9] | 1[0-5] | 17) local random=$(shuf -i20001-65535 -n1) while :; do echo -e "请输入 "$yellow"V2Ray"$none" 端口 ["$magenta"1-65535"$none"]" read -p "$(echo -e "(默认端口: ${cyan}${random}$none):")" v2ray_port [ -z "$v2ray_port" ] && v2ray_port=$random case $v2ray_port in [1-9] | [1-9][0-9] | [1-9][0-9][0-9] | [1-9][0-9][0-9][0-9] | [1-5][0-9][0-9][0-9][0-9] | 6[0-4][0-9][0-9][0-9] | 65[0-4][0-9][0-9] | 655[0-3][0-5]) echo echo echo -e "$yellow V2Ray 端口 = $cyan$v2ray_port$none" echo "----------------------------------------------------------------" echo break ;; *) error ;; esac done if [[ $v2ray_transport_opt -ge 9 && $v2ray_transport_opt -le 15 ]]; then v2ray_dynamic_port_start elif [[ $v2ray_transport_opt == 17 ]]; then socks_user_config socks_pass_config fi ;; *) tls_config ;; esac } v2ray_dynamic_port_start() { while :; do echo -e "请输入 "$yellow"V2Ray 动态端口开始 "$none"范围 ["$magenta"1-65535"$none"]" read -p "$(echo -e "(默认开始端口: ${cyan}10000$none):")" v2ray_dynamic_port_start_input [ -z $v2ray_dynamic_port_start_input ] && v2ray_dynamic_port_start_input=10000 case $v2ray_dynamic_port_start_input in $v2ray_port) echo echo " 不能和 V2Ray 端口一毛一样...." error ;; [1-9] | [1-9][0-9] | [1-9][0-9][0-9] | [1-9][0-9][0-9][0-9] | [1-5][0-9][0-9][0-9][0-9] | 6[0-4][0-9][0-9][0-9] | 65[0-4][0-9][0-9] | 655[0-3][0-5]) echo echo echo -e "$yellow V2Ray 动态端口开始 = $cyan$v2ray_dynamic_port_start_input$none" echo "----------------------------------------------------------------" echo break ;; *) error ;; esac done if [[ $v2ray_dynamic_port_start_input -lt $v2ray_port ]]; then lt_v2ray_port=true fi v2ray_dynamic_port_end } v2ray_dynamic_port_end() { while :; do echo -e "请输入 "$yellow"V2Ray 动态端口结束 "$none"范围 ["$magenta"1-65535"$none"]" read -p "$(echo -e "(默认结束端口: ${cyan}20000$none):")" v2ray_dynamic_port_end_input [ -z $v2ray_dynamic_port_end_input ] && v2ray_dynamic_port_end_input=20000 case $v2ray_dynamic_port_end_input in [1-9] | [1-9][0-9] | [1-9][0-9][0-9] | [1-9][0-9][0-9][0-9] | [1-5][0-9][0-9][0-9][0-9] | 6[0-4][0-9][0-9][0-9] | 65[0-4][0-9][0-9] | 655[0-3][0-5]) if [[ $v2ray_dynamic_port_end_input -le $v2ray_dynamic_port_start_input ]]; then echo echo " 不能小于或等于 V2Ray 动态端口开始范围" error elif [ $lt_v2ray_port ] && [[ ${v2ray_dynamic_port_end_input} -ge $v2ray_port ]]; then echo echo " V2Ray 动态端口结束范围 不能包括 V2Ray 端口..." error else echo echo echo -e "$yellow V2Ray 动态端口结束 = $cyan$v2ray_dynamic_port_end_input$none" echo "----------------------------------------------------------------" echo break fi ;; *) error ;; esac done } socks_user_config() { while :; do read -p "$(echo -e "请输入$yellow用户名$none...(默认用户名: ${cyan}233blog$none)"): " username [ -z "$username" ] && username="233blog" case $username in *[/$]* | *\&*) echo echo -e " 由于这个脚本太辣鸡了..所以用户名不能包含$red / $none或$red $ $none或$red & $none这三个符号.... " echo error ;; *) echo echo echo -e "$yellow 用户名 = $cyan$username$none" echo "----------------------------------------------------------------" echo break ;; esac done } socks_pass_config() { while :; do read -p "$(echo -e "请输入$yellow密码$none...(默认密码: ${cyan}233blog.com$none)"): " userpass [ -z "$userpass" ] && userpass="233blog.com" case $userpass in *[/$]* | *\&*) echo echo -e " 由于这个脚本太辣鸡了..所以密码不能包含$red / $none或$red $ $none或$red & $none这三个符号.... " echo error ;; *) echo echo echo -e "$yellow 密码 = $cyan$userpass$none" echo "----------------------------------------------------------------" echo break ;; esac done } tls_config() { echo local random=$(shuf -i20001-65535 -n1) while :; do echo -e "请输入 "$yellow"V2Ray"$none" 端口 ["$magenta"1-65535"$none"],不能选择 "$magenta"80"$none" 或 "$magenta"443"$none" 端口" read -p "$(echo -e "(默认端口: ${cyan}${random}$none):")" v2ray_port [ -z "$v2ray_port" ] && v2ray_port=$random case $v2ray_port in 80) echo echo " ...都说了不能选择 80 端口了咯....." error ;; 443) echo echo " ..都说了不能选择 433 端口了咯....." error ;; [1-9] | [1-9][0-9] | [1-9][0-9][0-9] | [1-9][0-9][0-9][0-9] | [1-5][0-9][0-9][0-9][0-9] | 6[0-4][0-9][0-9][0-9] | 65[0-4][0-9][0-9] | 655[0-3][0-5]) echo echo echo -e "$yellow V2Ray 端口 = $cyan$v2ray_port$none" echo "----------------------------------------------------------------" echo break ;; *) error ;; esac done while :; do echo echo -e "请输入一个 $magenta正确的域名$none,一定一定一定要正确,不!能!出!错!" read -p "(例如:233blog.com): " domain [ -z "$domain" ] && error && continue echo echo echo -e "$yellow 你的域名 = $cyan$domain$none" echo "----------------------------------------------------------------" break done get_ip echo echo echo -e "$yellow 请将 $magenta$domain$none $yellow解析到: $cyan$ip$none" echo echo -e "$yellow 请将 $magenta$domain$none $yellow解析到: $cyan$ip$none" echo echo -e "$yellow 请将 $magenta$domain$none $yellow解析到: $cyan$ip$none" echo "----------------------------------------------------------------" echo while :; do read -p "$(echo -e "(是否已经正确解析: [${magenta}Y$none]):") " record if [[ -z "$record" ]]; then error else if [[ "$record" == [Yy] ]]; then echo echo echo -e "$yellow 域名解析 = ${cyan}我确定已经有解析了$none" echo "----------------------------------------------------------------" echo break else error fi fi done if [[ $v2ray_transport_opt -ne 16 ]]; then auto_tls_config else caddy=true install_caddy_info="打开" fi if [[ $caddy ]]; then path_config_ask fi } auto_tls_config() { echo -e " 安装 Caddy 来实现 自动配置 TLS 如果你已经安装 Nginx 或 Caddy $yellow并且..自己能搞定配置 TLS$none 那么就不需要 打开自动配置 TLS " echo "----------------------------------------------------------------" echo while :; do read -p "$(echo -e "(是否自动配置 TLS: [${magenta}Y/N$none]):") " auto_install_caddy if [[ -z "$auto_install_caddy" ]]; then error else if [[ "$auto_install_caddy" == [Yy] ]]; then caddy=true install_caddy_info="打开" echo echo echo -e "$yellow 自动配置 TLS = $cyan$install_caddy_info$none" echo "----------------------------------------------------------------" echo break elif [[ "$auto_install_caddy" == [Nn] ]]; then install_caddy_info="关闭" echo echo echo -e "$yellow 自动配置 TLS = $cyan$install_caddy_info$none" echo "----------------------------------------------------------------" echo break else error fi fi done } path_config_ask() { echo while :; do echo -e "是否开启 网站伪装 和 路径分流 [${magenta}Y/N$none]" read -p "$(echo -e "(默认: [${cyan}N$none]):")" is_path [[ -z $is_path ]] && is_path="n" case $is_path in Y | y) path_config break ;; N | n) echo echo echo -e "$yellow 网站伪装 和 路径分流 = $cyan不想配置$none" echo "----------------------------------------------------------------" echo break ;; *) error ;; esac done } path_config() { echo while :; do echo -e "请输入想要 ${magenta}用来分流的路径$none , 例如 /233blog , 那么只需要输入 233blog 即可" read -p "$(echo -e "(默认: [${cyan}233blog$none]):")" path [[ -z $path ]] && path="233blog" case $path in *[/$]*) echo echo -e " 由于这个脚本太辣鸡了..所以分流的路径不能包含$red / $none或$red $ $none这两个符号.... " echo error ;; *) echo echo echo -e "$yellow 分流的路径 = ${cyan}/${path}$none" echo "----------------------------------------------------------------" echo break ;; esac done proxy_site_config } proxy_site_config() { echo while :; do echo -e "请输入 ${magenta}一个正确的$none ${cyan}网址$none 用来作为 ${cyan}网站的伪装$none , 例如 https://liyafly.com" echo -e "举例...你当前的域名是 $green$domain$none , 伪装的网址的是 https://liyafly.com" echo -e "然后打开你的域名时候...显示出来的内容就是来自 https://liyafly.com 的内容" echo -e "其实就是一个反代...明白就好..." echo -e "如果不能伪装成功...可以使用 v2ray config 修改伪装的网址" read -p "$(echo -e "(默认: [${cyan}https://liyafly.com$none]):")" proxy_site [[ -z $proxy_site ]] && proxy_site="https://liyafly.com" case $proxy_site in *[#$]*) echo echo -e " 由于这个脚本太辣鸡了..所以伪装的网址不能包含$red # $none或$red $ $none这两个符号.... " echo error ;; *) echo echo echo -e "$yellow 伪装的网址 = ${cyan}${proxy_site}$none" echo "----------------------------------------------------------------" echo break ;; esac done } blocked_hosts() { echo while :; do echo -e "是否开启广告拦截 [${magenta}Y/N$none]" read -p "$(echo -e "(默认 [${cyan}N$none]):")" blocked_ad [[ -z $blocked_ad ]] && blocked_ad="n" case $blocked_ad in Y | y) blocked_ad_info="开启" is_blocked_ad=true echo echo echo -e "$yellow 广告拦截 = $cyan开启$none" echo "----------------------------------------------------------------" echo break ;; N | n) blocked_ad_info="关闭" echo echo echo -e "$yellow 广告拦截 = $cyan关闭$none" echo "----------------------------------------------------------------" echo break ;; *) error ;; esac done } shadowsocks_config() { echo while :; do echo -e "是否配置 ${yellow}Shadowsocks${none} [${magenta}Y/N$none]" read -p "$(echo -e "(默认 [${cyan}N$none]):") " install_shadowsocks [[ -z "$install_shadowsocks" ]] && install_shadowsocks="n" if [[ "$install_shadowsocks" == [Yy] ]]; then echo shadowsocks=true shadowsocks_port_config break elif [[ "$install_shadowsocks" == [Nn] ]]; then break else error fi done } shadowsocks_port_config() { local random=$(shuf -i20001-65535 -n1) while :; do echo -e "请输入 "$yellow"Shadowsocks"$none" 端口 ["$magenta"1-65535"$none"],不能和 "$yellow"V2Ray"$none" 端口相同" read -p "$(echo -e "(默认端口: ${cyan}${random}$none):") " ssport [ -z "$ssport" ] && ssport=$random case $ssport in $v2ray_port) echo echo " 不能和 V2Ray 端口一毛一样...." error ;; [1-9] | [1-9][0-9] | [1-9][0-9][0-9] | [1-9][0-9][0-9][0-9] | [1-5][0-9][0-9][0-9][0-9] | 6[0-4][0-9][0-9][0-9] | 65[0-4][0-9][0-9] | 655[0-3][0-5]) if [[ $v2ray_transport_opt == "4" || $v2ray_transport_opt == "16" ]]; then local tls=ture fi if [[ $tls && $ssport == "80" ]] || [[ $tls && $ssport == "443" ]]; then echo echo -e "由于你已选择了 "$green"WebSocket + TLS $none或$green HTTP/2"$none" 传输协议." echo echo -e "所以不能选择 "$magenta"80"$none" 或 "$magenta"443"$none" 端口" error elif [[ $v2ray_dynamic_port_start_input == $ssport || $v2ray_dynamic_port_end_input == $ssport ]]; then local multi_port="${v2ray_dynamic_port_start_input} - ${v2ray_dynamic_port_end_input}" echo echo " 抱歉,此端口和 V2Ray 动态端口 冲突,当前 V2Ray 动态端口范围为:$multi_port" error elif [[ $v2ray_dynamic_port_start_input -lt $ssport && $ssport -le $v2ray_dynamic_port_end_input ]]; then local multi_port="${v2ray_dynamic_port_start_input} - ${v2ray_dynamic_port_end_input}" echo echo " 抱歉,此端口和 V2Ray 动态端口 冲突,当前 V2Ray 动态端口范围为:$multi_port" error else echo echo echo -e "$yellow Shadowsocks 端口 = $cyan$ssport$none" echo "----------------------------------------------------------------" echo break fi ;; *) error ;; esac done shadowsocks_password_config } shadowsocks_password_config() { while :; do echo -e "请输入 "$yellow"Shadowsocks"$none" 密码" read -p "$(echo -e "(默认密码: ${cyan}233blog.com$none)"): " sspass [ -z "$sspass" ] && sspass="233blog.com" case $sspass in *[/$]*) echo echo -e " 由于这个脚本太辣鸡了..所以密码不能包含$red / $none或$red $ $none这两个符号.... " echo error ;; *) echo echo echo -e "$yellow Shadowsocks 密码 = $cyan$sspass$none" echo "----------------------------------------------------------------" echo break ;; esac done shadowsocks_ciphers_config } shadowsocks_ciphers_config() { while :; do echo -e "请选择 "$yellow"Shadowsocks"$none" 加密协议 [${magenta}1-${#ciphers[*]}$none]" for ((i = 1; i <= ${#ciphers[*]}; i++)); do ciphers_show="${ciphers[$i - 1]}" echo echo -e "$yellow $i. $none${ciphers_show}" done echo read -p "$(echo -e "(默认加密协议: ${cyan}${ciphers[6]}$none)"):" ssciphers_opt [ -z "$ssciphers_opt" ] && ssciphers_opt=7 case $ssciphers_opt in [1-7]) ssciphers=${ciphers[$ssciphers_opt - 1]} echo echo echo -e "$yellow Shadowsocks 加密协议 = $cyan${ssciphers}$none" echo "----------------------------------------------------------------" echo break ;; *) error ;; esac done pause } install_info() { clear echo echo " ....准备安装了咯..看看有毛有配置正确了..." echo echo "---------- 安装信息 -------------" echo echo -e "$yellow V2Ray 传输协议 = $cyan${transport[$v2ray_transport_opt - 1]}$none" if [[ $v2ray_transport_opt == "4" || $v2ray_transport_opt == 16 ]]; then echo echo -e "$yellow V2Ray 端口 = $cyan$v2ray_port$none" echo echo -e "$yellow 你的域名 = $cyan$domain$none" echo echo -e "$yellow 域名解析 = ${cyan}我确定已经有解析了$none" echo echo -e "$yellow 自动配置 TLS = $cyan$install_caddy_info$none" if [[ $is_blocked_ad ]]; then echo echo -e "$yellow 广告拦截 = $cyan$blocked_ad_info$none" fi if [[ $path ]]; then echo echo -e "$yellow 路径分流 = ${cyan}/${path}$none" fi elif [[ $v2ray_transport_opt -ge 9 && $v2ray_transport_opt -le 15 ]]; then echo echo -e "$yellow V2Ray 端口 = $cyan$v2ray_port$none" echo echo -e "$yellow V2Ray 动态端口范围 = $cyan${v2ray_dynamic_port_start_input} - ${v2ray_dynamic_port_end_input}$none" if [[ $is_blocked_ad ]]; then echo echo -e "$yellow 广告拦截 = $cyan$blocked_ad_info$none" fi elif [[ $v2ray_transport_opt == 17 ]]; then echo echo -e "$yellow V2Ray 端口 = $cyan$v2ray_port$none" echo echo -e "$yellow 用户名 = $cyan$username$none" echo echo -e "$yellow 密码 = $cyan$userpass$none" if [[ $is_blocked_ad ]]; then echo echo -e "$yellow 广告拦截 = $cyan$blocked_ad_info$none" fi else echo echo -e "$yellow V2Ray 端口 = $cyan$v2ray_port$none" if [[ $is_blocked_ad ]]; then echo echo -e "$yellow 广告拦截 = $cyan$blocked_ad_info$none" fi fi if [ $shadowsocks ]; then echo echo -e "$yellow Shadowsocks 端口 = $cyan$ssport$none" echo echo -e "$yellow Shadowsocks 密码 = $cyan$sspass$none" echo echo -e "$yellow Shadowsocks 加密协议 = $cyan${ssciphers}$none" else echo echo -e "$yellow 是否配置 Shadowsocks = ${cyan}未配置${none}" fi echo echo "---------- END -------------" echo pause echo } domain_check() { # if [[ $cmd == "yum" ]]; then # yum install bind-utils -y # else # $cmd install dnsutils -y # fi # test_domain=$(dig $domain +short) test_domain=$(ping $domain -c 1 | grep -oE -m1 "([0-9]{1,3}\.){3}[0-9]{1,3}") if [[ $test_domain != $ip ]]; then echo echo -e "$red 检测域名解析错误....$none" echo echo -e " 你的域名: $yellow$domain$none 未解析到: $cyan$ip$none" echo echo -e " 你的域名当前解析到: $cyan$test_domain$none" echo echo "备注...如果你的域名是使用 Cloudflare 解析的话..在 Status 那里点一下那图标..让它变灰" echo exit 1 fi } install_caddy() { local caddy_tmp="/tmp/install_caddy/" local caddy_tmp_file="/tmp/install_caddy/caddy.tar.gz" if [[ $sys_bit == "i386" || $sys_bit == "i686" ]]; then local caddy_download_link="https://caddyserver.com/download/linux/386?license=personal" elif [[ $sys_bit == "x86_64" ]]; then local caddy_download_link="https://caddyserver.com/download/linux/amd64?license=personal" else echo -e "$red 自动安装 Caddy 失败!不支持你的系统。$none" && exit 1 fi mkdir -p $caddy_tmp if ! wget --no-check-certificate -O "$caddy_tmp_file" $caddy_download_link; then echo -e "$red 下载 Caddy 失败!$none" && exit 1 fi tar zxf $caddy_tmp_file -C $caddy_tmp cp -f ${caddy_tmp}caddy /usr/local/bin/ if [[ ! -f /usr/local/bin/caddy ]]; then echo -e "$red 安装 Caddy 出错!" && exit 1 fi setcap CAP_NET_BIND_SERVICE=+eip /usr/local/bin/caddy if [[ $systemd ]]; then cp -f ${caddy_tmp}init/linux-systemd/caddy.service /lib/systemd/system/ # sed -i "s/www-data/root/g" /lib/systemd/system/caddy.service systemctl enable caddy else cp -f ${caddy_tmp}init/linux-sysvinit/caddy /etc/init.d/caddy # sed -i "s/www-data/root/g" /etc/init.d/caddy chmod +x /etc/init.d/caddy update-rc.d -f caddy defaults fi mkdir -p /etc/ssl/caddy if [ -z "$(grep www-data /etc/passwd)" ]; then useradd -M -s /usr/sbin/nologin www-data fi chown -R www-data.www-data /etc/ssl/caddy mkdir -p /etc/caddy/ rm -rf $caddy_tmp caddy_config } caddy_config() { local email=$(shuf -i1-10000000000 -n1) case $v2ray_transport_opt in 4) if [[ $path ]]; then cat >/etc/caddy/Caddyfile <<-EOF $domain { tls ${email}@gmail.com gzip timeouts none proxy / $proxy_site { without /${path} } proxy /${path} 127.0.0.1:${v2ray_port} { without /${path} websocket } } EOF else cat >/etc/caddy/Caddyfile <<-EOF $domain { tls ${email}@gmail.com timeouts none proxy / 127.0.0.1:${v2ray_port} { websocket } } EOF fi ;; 16) if [[ $path ]]; then cat >/etc/caddy/Caddyfile <<-EOF $domain { tls ${email}@gmail.com gzip timeouts none proxy / $proxy_site { without /${path} } proxy /${path} https://127.0.0.1:${v2ray_port} { header_upstream Host {host} header_upstream X-Forwarded-Proto {scheme} insecure_skip_verify } } EOF else cat >/etc/caddy/Caddyfile <<-EOF $domain { tls ${email}@gmail.com timeouts none proxy / https://127.0.0.1:${v2ray_port} { header_upstream Host {host} header_upstream X-Forwarded-Proto {scheme} insecure_skip_verify } } EOF fi ;; esac # systemctl restart caddy do_service restart caddy } install_v2ray() { $cmd update -y # if [[ $cmd == "apt-get" ]]; then # $cmd install -y lrzsz git zip unzip curl wget qrencode dnsutils # else # $cmd install -y lrzsz git zip unzip curl wget qrencode bind-utils iptables-services # fi if [[ $cmd == "apt-get" ]]; then $cmd install -y lrzsz git zip unzip curl wget qrencode libcap2-bin else $cmd install -y lrzsz git zip unzip curl wget qrencode libcap iptables-services fi ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime [ -d /etc/v2ray ] && rm -rf /etc/v2ray if [[ $local_install ]]; then if [[ ! -d $(pwd)/config ]]; then echo echo -e "$red 哎呀呀...安装失败了咯...$none" echo echo -e " 请确保你有完整的上传 233blog.com V2Ray 一键安装脚本 & 管理脚本到当前 ${green}$(pwd) $none目录下" echo exit 1 fi mkdir -p /etc/v2ray/233boy/v2ray cp -rf $(pwd)/* /etc/v2ray/233boy/v2ray else git clone https://github.com/233boy/v2ray /etc/v2ray/233boy/v2ray fi [ -d /tmp/v2ray ] && rm -rf /tmp/v2ray mkdir -p /tmp/v2ray v2ray_tmp_file="/tmp/v2ray/v2ray.zip" v2ray_ver="$(curl -s https://api.github.com/repos/v2ray/v2ray-core/releases/latest | grep 'tag_name' | cut -d\" -f4)" v2ray_download_link="https://github.com/v2ray/v2ray-core/releases/download/$v2ray_ver/v2ray-linux-${v2ray_bit}.zip" if ! wget --no-check-certificate -O "$v2ray_tmp_file" $v2ray_download_link; then echo -e " $red 下载 V2Ray 失败啦..可能是你的小鸡鸡的网络太辣鸡了...重新安装也许能解决$none " && exit 1 fi unzip $v2ray_tmp_file -d "/tmp/v2ray/" mkdir -p /usr/bin/v2ray cp -f "/tmp/v2ray/v2ray-${v2ray_ver}-linux-${v2ray_bit}/v2ray" "/usr/bin/v2ray/v2ray" chmod +x "/usr/bin/v2ray/v2ray" cp -f "/tmp/v2ray/v2ray-${v2ray_ver}-linux-${v2ray_bit}/v2ctl" "/usr/bin/v2ray/v2ctl" chmod +x "/usr/bin/v2ray/v2ctl" if [[ $systemd ]]; then cp -f "/tmp/v2ray/v2ray-${v2ray_ver}-linux-${v2ray_bit}/systemd/v2ray.service" "/lib/systemd/system/" systemctl enable v2ray else apt-get install -y daemon cp "/tmp/v2ray/v2ray-${v2ray_ver}-linux-${v2ray_bit}/systemv/v2ray" "/etc/init.d/v2ray" chmod +x "/etc/init.d/v2ray" update-rc.d -f v2ray defaults fi mkdir -p /var/log/v2ray mkdir -p /etc/v2ray rm -rf /tmp/v2ray if [ $shadowsocks ]; then if [[ $is_blocked_ad ]]; then case $v2ray_transport_opt in 1) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/tcp_ss.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/tcp.json" ;; 2) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/http_ss.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/http.json" ;; 3) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/ws_ss.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/ws.json" ;; 4) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/ws_ss.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/ws_tls.json" ;; 5 | 6 | 7 | 8) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/kcp_ss.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/kcp.json" ;; 9) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/tcp_ss_dynamic.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/tcp.json" ;; 10) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/http_ss_dynamic.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/http.json" ;; 11) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/ws_ss_dynamic.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/ws.json" ;; 12 | 13 | 14 | 15) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/kcp_ss_dynamic.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/kcp.json" ;; 16) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/h2_ss.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/h2.json" ;; 17) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/socks_ss.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/socks.json" ;; esac else case $v2ray_transport_opt in 1) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/tcp_ss.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/tcp.json" ;; 2) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/http_ss.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/http.json" ;; 3) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/ws_ss.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/ws.json" ;; 4) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/ws_ss.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/ws_tls.json" ;; 5 | 6 | 7 | 8) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/kcp_ss.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/kcp.json" ;; 9) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/tcp_ss_dynamic.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/tcp.json" ;; 10) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/http_ss_dynamic.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/http.json" ;; 11) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/ws_ss_dynamic.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/ws.json" ;; 12 | 13 | 14 | 15) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/kcp_ss_dynamic.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/kcp.json" ;; 16) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/h2_ss.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/h2.json" ;; 17) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/socks_ss.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/socks.json" ;; esac fi else if [[ $is_blocked_ad ]]; then case $v2ray_transport_opt in 1) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/tcp.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/tcp.json" ;; 2) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/http.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/http.json" ;; 3) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/ws.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/ws.json" ;; 4) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/ws.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/ws_tls.json" ;; 5 | 6 | 7 | 8) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/kcp.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/kcp.json" ;; 9) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/sblocked_hosts/erver/tcp_dynamic.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/tcp.json" ;; 10) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/http_dynamic.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/http.json" ;; 11) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/ws_dynamic.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/ws.json" ;; 12 | 13 | 14 | 15) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/kcp_dynamic.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/kcp.json" ;; 16) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/h2.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/h2.json" ;; 17) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/blocked_hosts/server/socks.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/socks.json" ;; esac else case $v2ray_transport_opt in 1) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/tcp.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/tcp.json" ;; 2) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/http.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/http.json" ;; 3) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/ws.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/ws.json" ;; 4) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/ws.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/ws_tls.json" ;; 5 | 6 | 7 | 8) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/kcp.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/kcp.json" ;; 9) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/tcp_dynamic.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/tcp.json" ;; 10) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/http_dynamic.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/http.json" ;; 11) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/ws_dynamic.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/ws.json" ;; 12 | 13 | 14 | 15) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/kcp_dynamic.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/kcp.json" ;; 16) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/h2.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/h2.json" ;; 17) v2ray_server_config_file="/etc/v2ray/233boy/v2ray/config/server/socks.json" v2ray_client_config_file="/etc/v2ray/233boy/v2ray/config/client/socks.json" ;; esac fi fi } open_port() { if [[ $1 != "multiport" ]]; then iptables -I INPUT -m state --state NEW -m tcp -p tcp --dport $1 -j ACCEPT iptables -I INPUT -m state --state NEW -m udp -p udp --dport $1 -j ACCEPT ip6tables -I INPUT -m state --state NEW -m tcp -p tcp --dport $1 -j ACCEPT ip6tables -I INPUT -m state --state NEW -m udp -p udp --dport $1 -j ACCEPT # firewall-cmd --permanent --zone=public --add-port=$1/tcp # firewall-cmd --permanent --zone=public --add-port=$1/udp # firewall-cmd --reload else local multiport="${v2ray_dynamic_port_start_input}:${v2ray_dynamic_port_end_input}" iptables -I INPUT -p tcp --match multiport --dports $multiport -j ACCEPT iptables -I INPUT -p udp --match multiport --dports $multiport -j ACCEPT ip6tables -I INPUT -p tcp --match multiport --dports $multiport -j ACCEPT ip6tables -I INPUT -p udp --match multiport --dports $multiport -j ACCEPT # local multi_port="${v2ray_dynamic_port_start_input}-${v2ray_dynamic_port_end_input}" # firewall-cmd --permanent --zone=public --add-port=$multi_port/tcp # firewall-cmd --permanent --zone=public --add-port=$multi_port/udp # firewall-cmd --reload fi if [[ $cmd == "apt-get" ]]; then iptables-save >/etc/iptables.rules.v4 ip6tables-save >/etc/iptables.rules.v6 else service iptables save >/dev/null 2>&1 service ip6tables save >/dev/null 2>&1 fi } del_port() { if [[ $1 != "multiport" ]]; then # if [[ $cmd == "apt-get" ]]; then iptables -D INPUT -m state --state NEW -m tcp -p tcp --dport $1 -j ACCEPT iptables -D INPUT -m state --state NEW -m udp -p udp --dport $1 -j ACCEPT ip6tables -D INPUT -m state --state NEW -m tcp -p tcp --dport $1 -j ACCEPT ip6tables -D INPUT -m state --state NEW -m udp -p udp --dport $1 -j ACCEPT # else # firewall-cmd --permanent --zone=public --remove-port=$1/tcp # firewall-cmd --permanent --zone=public --remove-port=$1/udp # fi else # if [[ $cmd == "apt-get" ]]; then if [[ $v2ray_transport ]]; then local ports="${v2ray_dynamicPort_start}:${v2ray_dynamicPort_end}" else local port_start=$(sed -n '23p' $backup) local port_end=$(sed -n '25p' $backup) local ports="${port_start}:${port_end}" fi iptables -D INPUT -p tcp --match multiport --dports $ports -j ACCEPT iptables -D INPUT -p udp --match multiport --dports $ports -j ACCEPT ip6tables -D INPUT -p tcp --match multiport --dports $ports -j ACCEPT ip6tables -D INPUT -p udp --match multiport --dports $ports -j ACCEPT # else # local port_start=$(sed -n '23p' $backup) # local port_end=$(sed -n '25p' $backup) # local ports="${port_start}-${port_end}" # firewall-cmd --permanent --zone=public --remove-port=$ports/tcp # firewall-cmd --permanent --zone=public --remove-port=$ports/udp # fi fi if [[ $cmd == "apt-get" ]]; then iptables-save >/etc/iptables.rules.v4 ip6tables-save >/etc/iptables.rules.v6 else service iptables save >/dev/null 2>&1 service ip6tables save >/dev/null 2>&1 fi } config() { cp -f $v2ray_server_config_file $v2ray_server_config cp -f $v2ray_client_config_file $v2ray_client_config cp -f /etc/v2ray/233boy/v2ray/config/backup.conf $backup cp -f /etc/v2ray/233boy/v2ray/v2ray.sh /usr/local/bin/v2ray chmod +x /usr/local/bin/v2ray local multi_port="${v2ray_dynamic_port_start_input}-${v2ray_dynamic_port_end_input}" if [ $shadowsocks ]; then case $v2ray_transport_opt in 1) sed -i "28s/6666/$ssport/; 30s/chacha20-ietf/$ssciphers/; 31s/233blog.com/$sspass/" $v2ray_server_config ;; 2) sed -i "64s/6666/$ssport/; 66s/chacha20-ietf/$ssciphers/; 67s/233blog.com/$sspass/" $v2ray_server_config ;; 3 | 4) sed -i "31s/6666/$ssport/; 33s/chacha20-ietf/$ssciphers/; 34s/233blog.com/$sspass/" $v2ray_server_config ;; 5 | 6 | 7 | 8) sed -i "43s/6666/$ssport/; 45s/chacha20-ietf/$ssciphers/; 46s/233blog.com/$sspass/" $v2ray_server_config ;; 9) sed -i "31s/6666/$ssport/; 33s/chacha20-ietf/$ssciphers/; 34s/233blog.com/$sspass/; 42s/10000-20000/$multi_port/" $v2ray_server_config ;; 10) sed -i "67s/6666/$ssport/; 69s/chacha20-ietf/$ssciphers/; 70s/233blog.com/$sspass/; 78s/10000-20000/$multi_port/" $v2ray_server_config ;; 1[1-5]) sed -i "34s/6666/$ssport/; 36s/chacha20-ietf/$ssciphers/; 37s/233blog.com/$sspass/; 45s/10000-20000/$multi_port/" $v2ray_server_config ;; 16) sed -i "46s/6666/$ssport/; 48s/chacha20-ietf/$ssciphers/; 49s/233blog.com/$sspass/" $v2ray_server_config ;; 17) sed -i "30s/6666/$ssport/; 32s/chacha20-ietf/$ssciphers/; 33s/233blog.com/$sspass/" $v2ray_server_config ;; esac case $v2ray_transport_opt in 6) sed -i "31s/none/utp/" $v2ray_server_config sed -i "44s/none/utp/" $v2ray_client_config ;; 7) sed -i "31s/none/srtp/" $v2ray_server_config sed -i "44s/none/srtp/" $v2ray_client_config ;; 8) sed -i "31s/none/wechat-video/" $v2ray_server_config sed -i "44s/none/wechat-video/" $v2ray_client_config ;; 13) sed -i "74s/none/utp/" $v2ray_server_config sed -i "44s/none/utp/" $v2ray_client_config ;; 14) sed -i "74s/none/srtp/" $v2ray_server_config sed -i "44s/none/srtp/" $v2ray_client_config ;; 15) sed -i "74s/none/wechat-video/" $v2ray_server_config sed -i "44s/none/wechat-video/" $v2ray_client_config ;; esac else case $v2ray_transport_opt in 9) sed -i "31s/10000-20000/$multi_port/" $v2ray_server_config ;; 10) sed -i "67s/10000-20000/$multi_port/" $v2ray_server_config ;; 1[1-5]) sed -i "34s/10000-20000/$multi_port/" $v2ray_server_config ;; esac case $v2ray_transport_opt in 6) sed -i "31s/none/utp/" $v2ray_server_config sed -i "44s/none/utp/" $v2ray_client_config ;; 7) sed -i "31s/none/srtp/" $v2ray_server_config sed -i "44s/none/srtp/" $v2ray_client_config ;; 8) sed -i "31s/none/wechat-video/" $v2ray_server_config sed -i "44s/none/wechat-video/" $v2ray_client_config ;; 13) sed -i "63s/none/utp/" $v2ray_server_config sed -i "44s/none/utp/" $v2ray_client_config ;; 14) sed -i "63s/none/srtp/" $v2ray_server_config sed -i "44s/none/srtp/" $v2ray_client_config ;; 15) sed -i "63s/none/wechat-video/" $v2ray_server_config sed -i "44s/none/wechat-video/" $v2ray_client_config ;; esac fi if [[ $v2ray_transport_opt == 17 ]]; then sed -i "8s/2333/$v2ray_port/; 14s/233blog/$username/; 15s/233blog.com/$userpass/" $v2ray_server_config else sed -i "8s/2333/$v2ray_port/; 14s/$old_id/$uuid/" $v2ray_server_config fi if [[ $v2ray_transport_opt -eq 16 ]]; then sed -i "24s/233blog.com/$domain/" $v2ray_server_config if [[ $path ]]; then sed -i "26s/233blog/$path/" $v2ray_server_config else sed -i "26s/233blog//" $v2ray_server_config fi fi if [[ $v2ray_transport_opt -eq 4 || $v2ray_transport_opt -eq 16 ]]; then sed -i "s/233blog.com/$domain/; 22s/2333/443/; 25s/$old_id/$uuid/" $v2ray_client_config if [[ $path ]]; then sed -i "40s/233blog/$path/" $v2ray_client_config else sed -i "40s/233blog//" $v2ray_client_config fi elif [[ $v2ray_transport_opt == 17 ]]; then sed -i "21s/233blog.com/$ip/; 22s/2333/$v2ray_port/; 25s/233blog/$username/; 26s/233blog.com/$userpass/" $v2ray_client_config else sed -i "s/233blog.com/$ip/; 22s/2333/$v2ray_port/; 25s/$old_id/$uuid/" $v2ray_client_config fi # zip -q -r -j --password "233blog.com" /etc/v2ray/233blog_v2ray.zip $v2ray_client_config if [[ $cmd == "apt-get" ]]; then cat >/etc/network/if-pre-up.d/iptables <<-EOF #!/bin/sh /sbin/iptables-restore < /etc/iptables.rules.v4 /sbin/ip6tables-restore < /etc/iptables.rules.v6 EOF chmod +x /etc/network/if-pre-up.d/iptables else [ $(pgrep "firewall") ] && systemctl stop firewalld systemctl mask firewalld systemctl disable firewalld systemctl enable iptables systemctl enable ip6tables systemctl start iptables systemctl start ip6tables fi [ $shadowsocks ] && open_port $ssport if [[ $v2ray_transport_opt == "4" || $v2ray_transport_opt == 16 ]]; then open_port "80" open_port "443" open_port $v2ray_port elif [[ $v2ray_transport_opt -ge 9 && $v2ray_transport_opt -le 15 ]]; then open_port $v2ray_port open_port "multiport" else open_port $v2ray_port fi # systemctl restart v2ray do_service restart v2ray backup_config } backup_config() { sed -i "18s/=1/=$v2ray_transport_opt/; 21s/=2333/=$v2ray_port/; 24s/=$old_id/=$uuid/" $backup if [[ $v2ray_transport_opt -ge 9 && $v2ray_transport_opt -le 15 ]]; then sed -i "30s/=10000/=$v2ray_dynamic_port_start_input/; 33s/=20000/=$v2ray_dynamic_port_end_input/" $backup fi if [ $shadowsocks ]; then sed -i "42s/=/=true/; 45s/=6666/=$ssport/; 48s/=233blog.com/=$sspass/; 51s/=chacha20-ietf/=$ssciphers/" $backup fi [[ $v2ray_transport_opt == "4" || $v2ray_transport_opt == 16 ]] && sed -i "36s/=233blog.com/=$domain/" $backup [ $caddy ] && sed -i "39s/=/=true/" $backup [ $is_blocked_ad ] && sed -i "54s/=/=true/" $backup if [[ $path ]]; then sed -i "57s/=/=true/; 60s/=233blog/=$path/" $backup sed -i "63s#=https://liyafly.com#=$proxy_site#" $backup fi if [[ $v2ray_transport_opt == 17 ]]; then sed -i "66s/=233blog/=$username/; 69s/=233blog.com/=$userpass/" $backup fi } try_enable_bbr() { if [[ $(uname -r | cut -b 1) -eq 4 ]]; then case $(uname -r | cut -b 3-4) in 9. | [1-9][0-9]) sed -i '/net.ipv4.tcp_congestion_control/d' /etc/sysctl.conf sed -i '/net.core.default_qdisc/d' /etc/sysctl.conf echo "net.ipv4.tcp_congestion_control = bbr" >>/etc/sysctl.conf echo "net.core.default_qdisc = fq" >>/etc/sysctl.conf sysctl -p >/dev/null 2>&1 ;; esac fi } get_ip() { ip=$(curl -s ipinfo.io/ip) } error() { echo -e "\n$red 输入错误!$none\n" } pause() { read -rsp "$(echo -e "按$green Enter 回车键 $none继续....或按$red Ctrl + C $none取消.")" -d $'\n' echo } do_service() { if [[ $systemd ]]; then systemctl $1 $2 else service $2 $1 fi } show_config_info() { local header="none" if [[ $path ]]; then local _path="/$path" else local _path="/" fi case $v2ray_transport_opt in 1 | 9) local net="tcp" # local network="tcp" # local obfs="none" ;; 2 | 10) local net="tcp" # local network="tcp" local header="http" local host="www.baidu.com" # local obfs="http" ;; 3 | 4 | 11) local net="ws" # local network="ws" # local obfs="websocket" ;; 5 | 12) local net="kcp" # local network="kcp" ;; 6 | 13) local net="kcp" # local network="kcp" local header="utp" ;; 7 | 14) local net="kcp" # local network="kcp" local header="srtp" ;; 8 | 15) local net="kcp" # local network="kcp" local header="wechat-video" ;; 16) local net="h2" # local network="h2" ;; esac if [[ $v2ray_transport_opt == "4" || $v2ray_transport_opt == 16 ]]; then cat >/etc/v2ray/vmess_qr.json <<-EOF { "v": "2", "ps": "233blog_v2ray_${domain}", "add": "${domain}", "port": "443", "id": "${uuid}", "aid": "233", "net": "${net}", "type": "none", "host": "${domain}", "path": "$_path", "tls": "tls" } EOF elif [[ $v2ray_transport_opt != 17 ]]; then cat >/etc/v2ray/vmess_qr.json <<-EOF { "v": "2", "ps": "233blog_v2ray_${ip}", "add": "${ip}", "port": "${v2ray_port}", "id": "${uuid}", "aid": "233", "net": "${net}", "type": "${header}", "host": "${host}", "path": "", "tls": "" } EOF fi clear echo echo "---------- V2Ray 安装完成 -------------" echo echo -e " $yellow输入 ${cyan}v2ray${none} $yellow即可管理 V2Ray${none}" echo echo -e " ${yellow}V2Ray 客户端使用教程: https://233blog.com/post/20/$none" echo if [[ $v2ray_transport_opt == "4" && ! $caddy ]]; then echo -e " $red警告!$none$yellow请自行配置 TLS...教程: https://233blog.com/post/19/$none" echo fi echo "---------- V2Ray 配置信息 -------------" if [[ $v2ray_transport_opt == "4" || $v2ray_transport_opt == 16 ]]; then echo echo -e "$yellow 地址 (Address) = $cyan${domain}$none" echo echo -e "$yellow 端口 (Port) = ${cyan}443${none}" echo echo -e "$yellow 用户ID (User ID / UUID) = $cyan${uuid}$none" echo echo -e "$yellow 额外ID (Alter Id) = ${cyan}233${none}" echo echo -e "$yellow 传输协议 (Network) = ${cyan}${net}$none" echo echo -e "$yellow 伪装类型 (header type) = ${cyan}${header}$none" echo echo -e "$yellow 伪装域名 (host) = ${cyan}${domain}$none" echo echo -e "$yellow 路径 (path) = ${cyan}${_path}$none" echo echo -e "$yellow TLS (Enable TLS) = ${cyan}打开$none" echo elif [[ $v2ray_transport_opt == 17 ]]; then echo echo -e "$yellow 主机 (Hostname) = $cyan${ip}$none" echo echo -e "$yellow 端口 (Port) = $cyan$v2ray_port$none" echo echo -e "$yellow 用户名 (Username) = $cyan${username}$none" echo echo -e "$yellow 密码 (Password) = $cyan${userpass}$none" echo echo -e "$yellow Telegram 代理配置链接 = ${cyan}tg://socks?server=${ip}&port=${v2ray_port}&user=${username}&pass=${userpass}$none" echo echo " 这是 Socks5 协议相关的配置啦.... 不用在乎一些 V2Ray 客户端 怎么没有这些东东配置的" echo else echo echo -e "$yellow 地址 (Address) = $cyan${ip}$none" echo echo -e "$yellow 端口 (Port) = $cyan$v2ray_port$none" echo echo -e "$yellow 用户ID (User ID / UUID) = $cyan${uuid}$none" echo echo -e "$yellow 额外ID (Alter Id) = ${cyan}233${none}" echo echo -e "$yellow 传输协议 (Network) = ${cyan}${net}$none" echo echo -e "$yellow 伪装类型 (header type) = ${cyan}${header}$none" echo fi if [[ $v2ray_transport_opt -ge 9 && $v2ray_transport_opt -le 15 ]] && [[ $is_blocked_ad ]]; then echo " 备注: 动态端口已启用...广告拦截已开启..." echo elif [[ $v2ray_transport_opt -ge 9 && $v2ray_transport_opt -le 15 ]]; then echo " 备注: 动态端口已启用..." echo elif [[ $is_blocked_ad ]]; then echo " 备注: 广告拦截已开启.." echo fi if [ $shadowsocks ]; then local ss="ss://$(echo -n "${ssciphers}:${sspass}@${ip}:${ssport}" | base64)#233blog_ss_${ip}" echo echo "---------- Shadowsocks 配置信息 -------------" echo echo -e "$yellow 服务器地址 = $cyan${ip}$none" echo echo -e "$yellow 服务器端口 = $cyan$ssport$none" echo echo -e "$yellow 密码 = $cyan$sspass$none" echo echo -e "$yellow 加密协议 = $cyan${ssciphers}$none" echo echo -e "$yellow SS 链接 = ${cyan}$ss$none" echo echo -e " 备注:$red Shadowsocks Win 4.0.6 $none客户端可能无法识别该 SS 链接" echo if [[ $v2ray_transport_opt == 17 ]]; then echo -e " 温馨提示: 使用${cyan} v2ray ssqr ${none}即可生成 Shadowsocks 配置信息二维码" echo fi fi } create_qr_link_ask() { if [[ $shadowsocks && $v2ray_transport_opt != 17 ]]; then echo while :; do echo -e "是否需要生成$yellow V2Ray 和 Shadowsocks $none配置信息二维码链接 [${magenta}Y/N$none]" read -p "$(echo -e "默认 [${magenta}N$none]:")" y_n [ -z $y_n ] && y_n="n" if [[ $y_n == [Yy] ]]; then get_qr_link 1 break elif [[ $y_n == [Nn] ]]; then rm -rf /etc/v2ray/vmess_qr.json # rm -rf /etc/v2ray/shadowray_qr.txt break else error fi done elif [[ $v2ray_transport_opt != 17 ]]; then echo while :; do echo -e "是否需要生成$yellow V2Ray 配置信息 $none二维码链接 [${magenta}Y/N$none]" read -p "$(echo -e "默认 [${magenta}N$none]:")" y_n [ -z $y_n ] && y_n="n" if [[ $y_n == [Yy] ]]; then get_qr_link break elif [[ $y_n == [Nn] ]]; then rm -rf /etc/v2ray/vmess_qr.json # rm -rf /etc/v2ray/shadowray_qr.txt break else error fi done fi } get_qr_link() { echo echo -e "$green 正在生成链接.... 稍等片刻即可....$none" echo if [[ $1 ]]; then local random1=$(echo $RANDOM-$RANDOM-$RANDOM | base64) local random2=$(echo $RANDOM-$RANDOM-$RANDOM | base64) local vmess="vmess://$(cat /etc/v2ray/vmess_qr.json | base64)" echo $vmess >/etc/v2ray/vmess.txt cat /etc/v2ray/vmess.txt | qrencode -s 50 -o /tmp/233blog_v2ray.png local link1=$(curl -s --upload-file /tmp/233blog_v2ray.png "https://transfer.sh/${random1}_233blog_v2ray.png") local ss="ss://$(echo -n "${ssciphers}:${sspass}@${ip}:${ssport}" | base64)#233blog_ss_${ip}" echo "${ss}" >/tmp/233blog_shadowsocks.txt cat /tmp/233blog_shadowsocks.txt | qrencode -s 50 -o /tmp/233blog_shadowsocks.png local link2=$(curl -s --upload-file /tmp/233blog_shadowsocks.png "https://transfer.sh/${random2}_233blog_shadowsocks.png") if [[ $link1 && $link2 ]]; then echo echo "---------- V2Ray 二维码链接 -------------" echo echo -e "$yellow 适用于 V2RayNG v0.4.1+ / Kitsunebi = $cyan${link1}$none" echo echo echo echo "---------- Shadowsocks 二维码链接 -------------" echo echo -e "$yellow 链接 = $cyan${link2}$none" echo echo -e " 温馨提示...$red Shadowsocks Win 4.0.6 $none客户端可能无法识别该二维码" echo echo echo "----------------------------------------------------------------" echo echo "备注...链接将在 14 天后失效" echo echo "提醒...请不要把链接分享出去...除非你有特别的理由...." echo else echo echo -e "$red 哎呀呀呀...出错咯...$none" echo echo -e " 请尝试使用${cyan} v2ray qr ${none}生成 V2Ray 配置信息二维码" echo echo -e " 请尝试使用${cyan} v2ray ssqr ${none}生成 Shadowsocks 配置信息二维码" echo fi rm -rf /tmp/233blog_shadowsocks.png rm -rf /tmp/233blog_shadowsocks.txt else local random1=$(echo $RANDOM-$RANDOM-$RANDOM | base64) local vmess="vmess://$(cat /etc/v2ray/vmess_qr.json | base64)" echo $vmess >/etc/v2ray/vmess.txt cat /etc/v2ray/vmess.txt | qrencode -s 50 -o /tmp/233blog_v2ray.png local link1=$(curl -s --upload-file /tmp/233blog_v2ray.png "https://transfer.sh/${random1}_233blog_v2ray.png") if [[ $link1 ]]; then echo echo "---------- V2Ray 二维码链接 -------------" echo echo -e "$yellow 适用于 V2RayNG v0.4.1+ / Kitsunebi = $cyan${link1}$none" echo echo echo echo "----------------------------------------------------------------" echo echo "备注...链接将在 14 天后失效" echo echo "提醒...请不要把链接分享出去...除非你有特别的理由...." echo else echo echo -e "$red 哎呀呀呀...出错咯...请重试$none" echo echo -e " 请尝试使用${cyan} v2ray qr ${none}生成 V2Ray 配置信息二维码" echo fi fi rm -rf /tmp/233blog_v2ray.png rm -rf /etc/v2ray/vmess_qr.json rm -rf /etc/v2ray/vmess.txt } install() { if [[ -f /usr/bin/v2ray/v2ray && -f /etc/v2ray/config.json ]] && [[ -f $backup && -d /etc/v2ray/233boy/v2ray ]]; then echo echo " 大佬...你已经安装 V2Ray 啦...无需重新安装" echo echo -e " $yellow输入 ${cyan}v2ray${none} $yellow即可管理 V2Ray${none}" echo exit 1 elif [[ -f /usr/bin/v2ray/v2ray && -f /etc/v2ray/config.json ]] && [[ -f /etc/v2ray/233blog_v2ray_backup.txt && -d /etc/v2ray/233boy/v2ray ]]; then echo echo " 大佬... 如果你需要继续安装.. 请先卸载旧版本" echo echo -e " $yellow输入 ${cyan}v2ray uninstall${none} $yellow即可卸载${none}" echo exit 1 fi v2ray_config blocked_hosts shadowsocks_config install_info try_enable_bbr [ $caddy ] && domain_check install_v2ray if [[ $caddy || $v2ray_port == "80" ]]; then if [[ $cmd == "yum" ]]; then [[ $(pgrep "httpd") ]] && systemctl stop httpd [[ $(command -v httpd) ]] && yum remove httpd -y else [[ $(pgrep "apache2") ]] && service apache2 stop [[ $(command -v apache2) ]] && apt-get remove apache2* -y fi fi [ $caddy ] && install_caddy get_ip config show_config_info create_qr_link_ask } uninstall() { if [[ -f /usr/bin/v2ray/v2ray && -f /etc/v2ray/config.json ]] && [[ -f $backup && -d /etc/v2ray/233boy/v2ray ]]; then . $backup while :; do echo read -p "$(echo -e "是否卸载 ${yellow}V2Ray$none [${magenta}Y/N$none]:")" uninstall_v2ray_ask if [[ -z $uninstall_v2ray_ask ]]; then error else case $uninstall_v2ray_ask in Y | y) is_uninstall_v2ray=true echo echo -e "$yellow 卸载 V2Ray = ${cyan}是${none}" echo break ;; N | n) echo echo -e "$red 卸载已取消...$none" echo break ;; *) error ;; esac fi done if [[ $caddy_status ]] && [[ -f /usr/local/bin/caddy && -f /etc/caddy/Caddyfile ]]; then while :; do echo read -p "$(echo -e "是否卸载 ${yellow}Caddy$none [${magenta}Y/N$none]:")" uninstall_caddy_ask if [[ -z $uninstall_caddy_ask ]]; then error else case $uninstall_caddy_ask in Y | y) is_uninstall_caddy=true echo echo -e "$yellow 卸载 Caddy = ${cyan}是${none}" echo break ;; N | n) echo echo -e "$yellow 卸载 Caddy = ${cyan}否${none}" echo break ;; *) error ;; esac fi done fi if [[ $is_uninstall_v2ray && $is_uninstall_caddy ]]; then pause echo if [[ $shadowsocks_status ]]; then del_port $ssport fi if [[ $v2ray_transport == "4" || $v2ray_transport == 16 ]]; then del_port "80" del_port "443" del_port $v2ray_port elif [[ $v2ray_transport -ge 9 && $v2ray_transport -le 15 ]]; then del_port $v2ray_port del_port "multiport" else del_port $v2ray_port fi [ $cmd == "apt-get" ] && rm -rf /etc/network/if-pre-up.d/iptables v2ray_pid=$(ps ux | grep "/usr/bin/v2ray/v2ray" | grep -v grep | awk '{print $2}') # [ $v2ray_pid ] && systemctl stop v2ray [ $v2ray_pid ] && do_service stop v2ray rm -rf /usr/bin/v2ray rm -rf /usr/local/bin/v2ray rm -rf /etc/v2ray rm -rf /var/log/v2ray caddy_pid=$(pgrep "caddy") # [ $caddy_pid ] && systemctl stop caddy [ $caddy_pid ] && do_service stop caddy rm -rf /usr/local/bin/caddy rm -rf /etc/caddy rm -rf /etc/ssl/caddy if [[ $systemd ]]; then systemctl disable v2ray >/dev/null 2>&1 rm -rf /lib/systemd/system/v2ray.service systemctl disable caddy >/dev/null 2>&1 rm -rf /lib/systemd/system/caddy.service else update-rc.d -f caddy remove >/dev/null 2>&1 update-rc.d -f v2ray remove >/dev/null 2>&1 rm -rf /etc/init.d/caddy rm -rf /etc/init.d/v2ray fi # clear echo echo -e "$green V2Ray 卸载完成啦 ....$none" echo echo "如果你觉得这个脚本有哪些地方不够好的话...请告诉我" echo echo "反馈问题: https://github.com/233boy/v2ray/issus" echo elif [[ $is_uninstall_v2ray ]]; then pause echo if [[ $shadowsocks_status ]]; then del_port $ssport fi if [[ $v2ray_transport == "4" || $v2ray_transport == 16 ]]; then del_port "80" del_port "443" del_port $v2ray_port elif [[ $v2ray_transport -ge 9 && $v2ray_transport -le 15 ]]; then del_port $v2ray_port del_port "multiport" else del_port $v2ray_port fi [ $cmd == "apt-get" ] && rm -rf /etc/network/if-pre-up.d/iptables v2ray_pid=$(ps ux | grep "/usr/bin/v2ray/v2ray" | grep -v grep | awk '{print $2}') # [ $v2ray_pid ] && systemctl stop v2ray [ $v2ray_pid ] && do_service stop v2ray rm -rf /usr/bin/v2ray rm -rf /usr/local/bin/v2ray rm -rf /etc/v2ray rm -rf /var/log/v2ray if [[ $systemd ]]; then systemctl disable v2ray >/dev/null 2>&1 rm -rf /lib/systemd/system/v2ray.service else update-rc.d -f v2ray remove >/dev/null 2>&1 rm -rf /etc/init.d/v2ray fi # clear echo echo -e "$green V2Ray 卸载完成啦 ....$none" echo echo "如果你觉得这个脚本有哪些地方不够好的话...请告诉我" echo echo "反馈问题: https://github.com/233boy/v2ray/issus" echo fi elif [[ -f /usr/bin/v2ray/v2ray && -f /etc/v2ray/config.json ]] && [[ -f /etc/v2ray/233blog_v2ray_backup.txt && -d /etc/v2ray/233boy/v2ray ]]; then backup="/etc/v2ray/233blog_v2ray_backup.txt" while :; do echo read -p "$(echo -e "是否卸载 ${yellow}V2Ray$none [${magenta}Y/N$none]:")" uninstall_v2ray_ask if [[ -z $uninstall_v2ray_ask ]]; then error else case $uninstall_v2ray_ask in Y | y) is_uninstall_v2ray=true echo echo -e "$yellow 卸载 V2Ray = ${cyan}是${none}" echo break ;; N | n) echo echo -e "$red 卸载已取消...$none" echo break ;; *) error ;; esac fi done if [[ $(sed -n '29p' $backup) == "true" ]]; then caddy_installed=true fi if [[ $caddy_installed ]] && [[ -f /usr/local/bin/caddy && -f /etc/caddy/Caddyfile ]]; then while :; do echo read -p "$(echo -e "是否卸载 ${yellow}Caddy$none [${magenta}Y/N$none]:")" uninstall_caddy_ask if [[ -z $uninstall_caddy_ask ]]; then error else case $uninstall_caddy_ask in Y | y) is_uninstall_caddy=true echo echo -e "$yellow 卸载 Caddy = ${cyan}是${none}" echo break ;; N | n) echo echo -e "$yellow 卸载 Caddy = ${cyan}否${none}" echo break ;; *) error ;; esac fi done fi if [[ $is_uninstall_v2ray && $is_uninstall_caddy ]]; then pause echo shadowsocks=$(sed -n '31p' $backup) if [[ $shadowsocks == "true" ]]; then ssport=$(sed -n '33p' $backup) del_port $ssport fi v2ray_transport_opt=$(sed -n '17p' $backup) v2ray_port=$(sed -n '19p' $backup) if [[ $v2ray_transport_opt == "4" ]]; then del_port "80" del_port "443" del_port $v2ray_port elif [[ $v2ray_transport_opt -ge 9 ]]; then del_port $v2ray_port del_port "multiport" else del_port $v2ray_port fi [ $cmd == "apt-get" ] && rm -rf /etc/network/if-pre-up.d/iptables v2ray_pid=$(ps ux | grep "/usr/bin/v2ray/v2ray" | grep -v grep | awk '{print $2}') # [ $v2ray_pid ] && systemctl stop v2ray [ $v2ray_pid ] && do_service stop v2ray rm -rf /usr/bin/v2ray rm -rf /usr/local/bin/v2ray rm -rf /etc/v2ray rm -rf /var/log/v2ray caddy_pid=$(pgrep "caddy") # [ $caddy_pid ] && systemctl stop caddy [ $caddy_pid ] && do_service stop caddy rm -rf /usr/local/bin/caddy rm -rf /etc/caddy rm -rf /etc/ssl/caddy if [[ $systemd ]]; then systemctl disable v2ray >/dev/null 2>&1 rm -rf /lib/systemd/system/v2ray.service systemctl disable caddy >/dev/null 2>&1 rm -rf /lib/systemd/system/caddy.service else update-rc.d -f caddy remove >/dev/null 2>&1 update-rc.d -f v2ray remove >/dev/null 2>&1 rm -rf /etc/init.d/caddy rm -rf /etc/init.d/v2ray fi # clear echo echo -e "$green V2Ray 卸载完成啦 ....$none" echo echo "如果你觉得这个脚本有哪些地方不够好的话...请告诉我" echo echo "反馈问题: https://github.com/233boy/v2ray/issus" echo elif [[ $is_uninstall_v2ray ]]; then pause echo shadowsocks=$(sed -n '31p' $backup) if [[ $shadowsocks == "true" ]]; then ssport=$(sed -n '33p' $backup) del_port $ssport fi v2ray_transport_opt=$(sed -n '17p' $backup) v2ray_port=$(sed -n '19p' $backup) if [[ $v2ray_transport_opt == "4" ]]; then del_port "80" del_port "443" del_port $v2ray_port elif [[ $v2ray_transport_opt -ge 9 ]]; then del_port $v2ray_port del_port "multiport" else del_port $v2ray_port fi [ $cmd == "apt-get" ] && rm -rf /etc/network/if-pre-up.d/iptables v2ray_pid=$(ps ux | grep "/usr/bin/v2ray/v2ray" | grep -v grep | awk '{print $2}') # [ $v2ray_pid ] && systemctl stop v2ray [ $v2ray_pid ] && do_service stop v2ray rm -rf /usr/bin/v2ray rm -rf /usr/local/bin/v2ray rm -rf /etc/v2ray rm -rf /var/log/v2ray if [[ $systemd ]]; then systemctl disable v2ray >/dev/null 2>&1 rm -rf /lib/systemd/system/v2ray.service else update-rc.d -f v2ray remove >/dev/null 2>&1 rm -rf /etc/init.d/v2ray fi # clear echo echo -e "$green V2Ray 卸载完成啦 ....$none" echo echo "如果你觉得这个脚本有哪些地方不够好的话...请告诉我" echo echo "反馈问题: https://github.com/233boy/v2ray/issus" echo fi else echo -e " $red 大胸弟...你貌似毛有安装 V2Ray ....卸载个鸡鸡哦...$none 备注...仅支持卸载使用我 (233blog.com) 提供的 V2Ray 一键安装脚本 " && exit 1 fi } args=$1 [ -z $1 ] && args="online" case $args in online) #hello world ;; local) local_install=true ;; *) echo echo -e " 大佬...你输入的这个参数 <$red $args $none> ...这个是什么鬼啊...脚本不认识它哇" echo echo -e " 这个辣鸡脚本仅支持输入$green local / online $none参数" echo echo -e " 输入$yellow local $none即是使用本地安装" echo echo -e " 输入$yellow online $none即是使用在线安装 (默认)" echo exit 1 ;; esac clear while :; do echo echo "........... V2Ray 一键安装脚本 & 管理脚本 by 233blog.com .........." echo echo "帮助说明: https://233blog.com/post/16/" echo echo "搭建教程: https://233blog.com/post/17/" echo echo " 1. 安装" echo echo " 2. 卸载" echo if [[ $local_install ]]; then echo -e "$yellow 温馨提示.. 本地安装已启用 ..$none" echo fi read -p "$(echo -e "请选择 [${magenta}1-2$none]:")" choose case $choose in 1) install break ;; 2) uninstall break ;; *) error ;; esac done