Browse Source

添加 'xray-ui.sh'

cnbugs 1 month ago
parent
commit
e1913bb6c4
1 changed files with 369 additions and 0 deletions
  1. 369 0
      xray-ui.sh

+ 369 - 0
xray-ui.sh

@@ -0,0 +1,369 @@
+#!/bin/bash
+curl -sS -H "Accept: application/vnd.github.v3+json" -o "/tmp/tmp_file" 'https://api.github.com/repos/qist/xray-ui/releases/latest'
+releases_version=($(sed 'y/,/\n/' "/tmp/tmp_file" | grep 'tag_name' | awk -F '"' '{print $4}'))
+rm /tmp/tmp_file -f
+red='\033[0;31m'
+green='\033[0;32m'
+yellow='\033[0;33m'
+bblue='\033[0;34m'
+plain='\033[0m'
+
+red() { echo -e "\033[31m\033[01m$1\033[0m"; }
+green() { echo -e "\033[32m\033[01m$1\033[0m"; }
+yellow() { echo -e "\033[33m\033[01m$1\033[0m"; }
+blue() { echo -e "\033[36m\033[01m$1\033[0m"; }
+white() { echo -e "\033[37m\033[01m$1\033[0m"; }
+readp() { read -p "$(yellow "$1")" $2; }
+remoteV=${releases_version}
+clear
+white "Github项目  :github.com/qist/xray-ui"
+yellow "感谢xray-ui代码贡献者们(vaxilu)"
+green "当前安装版本: $remoteV"
+yellow "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"
+sleep 2
+cur_dir=$(pwd)
+
+# check root
+[[ $EUID -ne 0 ]] && echo -e "${red}错误:${plain} 必须使用root用户运行此脚本!\n" && exit 1
+
+# check os
+
+if [[ -f /etc/redhat-release ]]; then
+    release="centos"
+elif cat /etc/issue | grep -Eqi "debian"; then
+    release="debian"
+elif cat /etc/issue | grep -Eqi "ubuntu"; then
+    release="ubuntu"
+elif cat /etc/issue | grep -Eqi "centos|red hat|redhat"; then
+    release="centos"
+elif cat /proc/version | grep -Eqi "debian"; then
+    release="debian"
+elif cat /proc/version | grep -Eqi "ubuntu"; then
+    release="ubuntu"
+elif cat /proc/version | grep -Eqi "centos|red hat|redhat"; then
+    release="centos"
+elif cat /etc/system-release-cpe | grep -Eqi "amazon_linux"; then
+    release="amazon_linux"
+else
+    echo -e "${red}未检测到系统版本,请联系脚本作者!${plain}\n" && exit 1
+fi
+
+arch() {
+    case "$(uname -m)" in
+    x86_64 | x64 | amd64) echo 'amd64' ;;
+    i*86 | x86) echo '386' ;;
+    armv8* | armv8 | arm64 | aarch64) echo 'arm64' ;;
+    armv7* | armv7 | arm) echo 'armv7' ;;
+    armv6* | armv6) echo 'armv6' ;;
+    armv5* | armv5) echo 'armv5' ;;
+    s390x) echo 's390x' ;;
+    *) echo -e "${green}Unsupported CPU architecture! ${plain}" && rm -f install.sh && exit 1 ;;
+    esac
+}
+
+echo "arch: $(arch)"
+
+sys() {
+    [ -f /etc/os-release ] && grep -i pretty_name /etc/os-release | cut -d \" -f2 && return
+    [ -f /etc/lsb-release ] && grep -i description /etc/lsb-release | cut -d \" -f2 && return
+    [ -f /etc/redhat-release ] && awk '{print $0}' /etc/redhat-release && return
+}
+op=$(sys)
+version=$(uname -r | awk -F "-" '{print $1}')
+vi=$(systemd-detect-virt)
+white "VPS操作系统: $(blue "$op") \c" && white " 内核版本: $(blue "$version") \c" && white " CPU架构 : $(blue "$arch") \c" && white " 虚拟化类型: $(blue "$vi")"
+sleep 2
+
+if [ $(getconf WORD_BIT) != '32' ] && [ $(getconf LONG_BIT) != '64' ]; then
+    echo "本软件不支持 32 位系统(x86),请使用 64 位系统(x86_64),如果检测有误,请联系作者"
+    exit -1
+fi
+
+os_version=""
+
+# os version
+if [[ -f /etc/os-release ]]; then
+    os_version=$(awk -F'[= ."]' '/VERSION_ID/{print $3}' /etc/os-release)
+fi
+if [[ -z "$os_version" && -f /etc/lsb-release ]]; then
+    os_version=$(awk -F'[= ."]+' '/DISTRIB_RELEASE/{print $2}' /etc/lsb-release)
+fi
+
+if [[ x"${release}" == x"centos" ]]; then
+    if [[ ${os_version} -le 6 ]]; then
+        echo -e "${red}请使用 CentOS 7 或更高版本的系统!${plain}\n" && exit 1
+    fi
+elif [[ x"${release}" == x"ubuntu" ]]; then
+    if [[ ${os_version} -lt 16 ]]; then
+        echo -e "${red}请使用 Ubuntu 16 或更高版本的系统!${plain}\n" && exit 1
+    fi
+elif [[ x"${release}" == x"debian" ]]; then
+    if [[ ${os_version} -lt 8 ]]; then
+        echo -e "${red}请使用 Debian 8 或更高版本的系统!${plain}\n" && exit 1
+    fi
+elif [[ x"${release}" == x"amazon_linux" ]]; then
+    if [[ ${os_version} -lt 2 ]]; then
+        echo -e "${red}请使用 Amazon Linux 2 或更高版本的系统!${plain}\n" && exit 1
+    fi
+fi
+ports=$(/usr/local/xray-ui/xray-ui 2>&1 | grep tcp | awk '{print $5}' | sed "s/://g")
+if [[ -n $ports ]]; then
+    green "经检测,xray-ui已安装"
+    echo
+    acp=$(/usr/local/xray-ui/xray-ui setting -show 2>/dev/null)
+    green "$acp"
+    echo
+    readp "是否直接重装xray-ui,请输入Y/y键并回车。如不重装,输入N/n键回车退出脚本):" ins
+    if [[ $ins = [Yy] ]]; then
+        systemctl stop xray-ui
+        systemctl disable xray-ui
+        rm /etc/systemd/system/xray-ui.service -f
+        systemctl daemon-reload
+        systemctl reset-failed
+        rm /etc/xray-ui/ -rf
+        rm /usr/local/xray-ui/ -rf
+        rm -rf /root/rayuil.sh /root/acme.sh
+        sed -i '/xrayuil.sh/d' /etc/crontab
+        sed -i '/xray-ui restart/d' /etc/crontab
+    else
+        exit 1
+    fi
+fi
+install_base() {
+    if [[ x"${release}" == x"centos" ]]; then
+        if [[ ${os_version} =~ 8 ]]; then
+            yum clean all && yum makecache
+        fi
+        yum install epel-release -y && yum install wget curl tar gzip lsof -y
+
+        setenforce 0 >/dev/null 2>&1
+    else
+        apt update && apt install wget curl tar lsof gzip -y
+    fi
+}
+generate_random_string() {
+    local n=$1
+    # 定义数字、大写字母和小写字母的集合
+    local characters='0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'
+
+    # 生成随机字符并限制在指定字符集中
+    # 从 /dev/urandom 生成随机字节,使用 tr 进行过滤
+    local random_string=$(cat /dev/urandom | tr -dc "$characters" | fold -w "$n" | head -n 1)
+
+    echo "$random_string"
+}
+
+install_xray-ui() {
+    systemctl stop xray-ui
+    cd /usr/local/
+    if [ $# == 0 ]; then
+        wget --no-check-certificate -O /usr/local/xray-ui-linux-$(arch).tar.gz https://github.com/qist/xray-ui/releases/download/${releases_version}/xray-ui-linux-$(arch).tar.gz
+        if [[ $? -ne 0 ]]; then
+            echo -e "${red}下载 xray-ui 失败,请确保你的服务器能够下载 Github 的文件${plain}"
+            rm -f install.sh
+            exit 1
+        fi
+    else
+        last_version=$1
+        url="https://github.com/qist/xray-ui/releases/download/${releases_version}/xray-ui-linux-$(arch).tar.gz"
+        echo -e "开始安装 xray-ui v$1"
+        wget  --no-check-certificate -O /usr/local/xray-ui-linux-$(arch).tar.gz ${url}
+        if [[ $? -ne 0 ]]; then
+            echo -e "${red}下载 xray-ui v$1 失败,请确保此版本存在${plain}"
+            rm -f install.sh
+            exit 1
+        fi
+    fi
+
+    if [[ -e /usr/local/xray-ui/ ]]; then
+        rm /usr/local/xray-ui/ -rf
+    fi
+
+    tar -zxvf xray-ui-linux-$(arch).tar.gz
+    rm xray-ui-linux-$(arch).tar.gz -f
+    cd xray-ui
+    # Check the system's architecture and rename the file accordingly
+    if [[ $(arch) == "armv5" || $(arch) == "armv6" || $(arch) == "armv7" ]]; then
+        mv bin/xray-linux-$(arch) bin/xray-linux-arm
+        chmod +x bin/xray-linux-arm
+    fi   
+    chmod +x xray-ui bin/xray-linux-$(arch)
+    cp -f xray-ui.service /etc/systemd/system/
+    wget --no-check-certificate -O /usr/bin/xray-ui https://raw.githubusercontent.com/qist/xray-ui/main/xray-ui.sh
+    chmod +x /usr/bin/xray-ui
+    systemctl daemon-reload
+    systemctl enable xray-ui
+    systemctl start xray-ui
+    sleep 2
+    cat >/root/xrayuil.sh <<-\EOF
+#!/bin/bash
+xui=`ps -aux |grep "xray-ui" |grep -v "grep" |wc -l`
+xray=`ps -aux |grep "xray-linux" |grep -v "grep" |wc -l`
+sleep 1
+if [ $xui = 0 ];then
+xray-ui restart
+fi
+if [ $xray = 0 ];then
+xray-ui restart
+fi
+EOF
+    chmod +x /root/xrayuil.sh
+    sed -i '/xrayuil.sh/d' /etc/crontab
+    echo "*/1 * * * * root bash /root/xrayuil.sh >/dev/null 2>&1" >>/etc/crontab
+    sed -i '/xray-ui restart/d' /etc/crontab
+    echo "0 1 1 * *  root xray-ui restart >/dev/null 2>&1" >>/etc/crontab
+    sleep 1
+    echo -e ""
+    blue "以下设置内容建议自定义,以防止账号密码路径及端口泄露"
+    echo -e ""
+    readp "设置xray-ui登录用户名(回车跳过为随机6位字符):" username
+    if [[ -z ${username} ]]; then
+        uauto=$(date +%s%N | md5sum | cut -c 1-6)
+        username=$uauto
+    fi
+    sleep 1
+    green "xray-ui登录用户名:${username}"
+    echo -e ""
+    readp "设置xray-ui登录密码(回车跳过为随机6位字符):" password
+    if [[ -z ${password} ]]; then
+        pauto=$(date +%s%N | md5sum | cut -c 1-6)
+        password=$pauto
+    fi
+    green "xray-ui登录密码:${password}"
+    /usr/local/xray-ui/xray-ui setting -username ${username} -password ${password} >/dev/null 2>&1
+    sleep 1
+    echo -e ""
+    readp "设置xray-ui登录端口[1-65535](回车跳过为2000-65535之间的随机端口):" port
+    if [[ -z $port ]]; then
+        port=$(shuf -i 2000-65535 -n 1)
+        until [[ -z $(ss -ntlp | awk '{print $4}' | grep -w "$port") ]]; do
+            [[ -n $(ss -ntlp | awk '{print $4}' | grep -w "$port") ]] && yellow "\n端口被占用,请重新输入端口" && readp "自定义xray-ui端口:" port
+        done
+    else
+        until [[ -z $(ss -ntlp | awk '{print $4}' | grep -w "$port") ]]; do
+            [[ -n $(ss -ntlp | awk '{print $4}' | grep -w "$port") ]] && yellow "\n端口被占用,请重新输入端口" && readp "自定义xray-ui端口:" port
+        done
+    fi
+    /usr/local/xray-ui/xray-ui setting -port $port >/dev/null 2>&1
+    green "xray-ui登录端口:${port}"
+    sleep 1
+    echo -e ""
+    readp "设置xray-ui web 路径 (回车跳过为随机10位字符):" path
+    if [[ -z ${path} ]]; then
+        path=$(generate_random_string 10)
+    fi
+    /usr/local/xray-ui/xray-ui setting -webBasePath $path >/dev/null 2>&1
+    green "xray-ui web 路径:${path}"
+    sleep 1
+    xray-ui restart
+    xuilogin() {
+        v4=$(curl -s4m8 http://ip.sb -k)
+        v6=$(curl -s6m8 http://ip.sb -k)
+        if [[ -z $v4 ]]; then
+            int="${green}请在浏览器地址栏复制${plain}  ${bblue}[$v6]:$ports/$path${plain}  ${green}进入xray-ui登录界面\n当前xray-ui登录用户名:${plain}${bblue}${username}${plain}${green} \n当前xray-ui登录密码:${plain}${bblue}${password}${plain}"
+        elif [[ -n $v4 && -n $v6 ]]; then
+            int="${green}请在浏览器地址栏复制${plain}  ${bblue}$v4:$ports/$path${plain}  ${yellow}或者${plain}  ${bblue}[$v6]:$ports/$path${plain}  ${green}进入xray-ui登录界面\n当前xray-ui登录用户名:${plain}${bblue}${username}${plain}${green} \n当前xray-ui登录密码:${plain}${bblue}${password}${plain}"
+        else
+            int="${green}请在浏览器地址栏复制${plain}  ${bblue}$v4:$ports/$path${plain}  ${green}进入xray-ui登录界面\n当前xray-ui登录用户名:${plain}${bblue}${username}${plain}${green} \n当前xray-ui登录密码:${plain}${bblue}${password}${plain}"
+        fi
+    }
+ssh_forwarding() {
+    # 获取 IPv4 和 IPv6 地址
+    v4=$(curl -s4m8 http://ip.sb -k)
+    v6=$(curl -s6m8 http://ip.sb -k)
+
+    echo -e ""
+    read -p "设置 xray-ui ssh 转发端口 [1-65535](回车跳过为 2000-65535 之间的随机端口):" ssh_port
+
+    # 如果未输入端口,则随机生成一个2000-65535之间的端口
+    if [[ -z $ssh_port ]]; then
+        ssh_port=$(shuf -i 2000-65535 -n 1)
+    fi
+
+    # 检查端口是否被占用,直到找到未占用的端口
+    while [[ -n $(ss -ntlp | awk '{print $4}' | grep -w ":$ssh_port") ]]; do
+        echo -e "\n端口 $ssh_port 被占用,请重新输入端口"
+        read -p "自定义 xray-ui ssh 转发端口:" ssh_port
+        if [[ -z $ssh_port ]]; then
+            ssh_port=$(shuf -i 2000-65535 -n 1)
+        fi
+    done
+
+    # 检查 IP 并输出相应的 SSH 和浏览器访问信息
+    if [[ -z $v4 ]]; then
+        # echo -e "${green}请在 xray-ui 服务器系统输入${plain} ${bblue}ssh  -f -N -L [::]:$ssh_port:127.0.0.1:$ports root@127.0.0.1${plain} 输入 root 密码进行转发 不建议使用"
+        # echo -e "${green}请在浏览器地址栏复制${plain} ${bblue}[$v6]:$ssh_port/$path${plain} ${green}进入 xray-ui 登录界面"
+        echo -e "${green}客户端转发 安全性高${plain} ${bblue}ssh  -f -N -L [::]:$ssh_port:127.0.0.1:$ports root@[$v6]${plain} 输入 root 密码进行转发"
+        echo -e "${green}请在浏览器地址栏复制${plain} ${bblue}[::1]:$ssh_port/$path${plain} ${green}进入 xray-ui 登录界面"
+        echo -e "${green}当前 xray-ui 登录用户名:${plain}${bblue}${username}${plain}"
+        echo -e "${green}当前 xray-ui 登录密码:${plain}${bblue}${password}${plain}"
+        yellow "不使用ssh 转发请配置nginx https代理或者xray-ui 配置证书"
+    elif [[ -n $v4 && -n $v6 ]]; then
+        # echo -e "${green}请在  xray-ui 服务器系统输入${plain} ${bblue}ssh  -f -N -L 0.0.0.0:$ssh_port:127.0.0.1:$ports root@127.0.0.1${plain} ${yellow}或者 ${bblue}ssh  -f -N -L [::]:$ssh_port:127.0.0.1:$ports root@127.0.0.1${plain} 输入 root 密码进行转发 不建议使用"
+        # echo -e "${green}请在浏览器地址栏复制${plain} ${bblue}$v4:$ssh_port/$path${plain} ${yellow}或者${plain} ${bblue}[$v6]:$ssh_port/$path${plain} ${green}进入 xray-ui 登录界面"
+        echo -e "${green}客户端转发 安全性高 ${plain} ${bblue}ssh  -f -N -L 0.0.0.0:$ssh_port:127.0.0.1:$ports root@$v4${plain} ${yellow}或者 ${bblue}ssh  -f -N -L [::]:$ssh_port:127.0.0.1:$ports root@[$v6]${plain} 输入 root 密码进行转发"
+        echo -e "${green}请在浏览器地址栏复制${plain} ${bblue}127.0.0.1:$ssh_port/$path${plain} ${yellow}或者${plain} ${bblue}[::1]:$ssh_port/$path${plain} ${green}进入 xray-ui 登录界面"
+        echo -e "${green}当前 xray-ui 登录用户名:${plain}${bblue}${username}${plain}"
+        echo -e "${green}当前 xray-ui 登录密码:${plain}${bblue}${password}${plain}"
+        yellow "不使用ssh 转发请配置nginx https代理或者xray-ui 配置证书"
+    else
+        # echo -e "${green}请在  xray-ui 服务器系统输入${plain} ${bblue}ssh  -f -N -L 0.0.0.0:$ssh_port:127.0.0.1:$ports root@127.0.0.1${plain} 输入 root 密码进行转发 "
+        # echo -e "${green}请在浏览器地址栏复制${plain} ${bblue}$v4:$ssh_port/$path${plain} ${green}进入 xray-ui 登录界面"
+        echo -e "${green}客户端转发 安全性高${plain} ${bblue}ssh  -f -N -L 0.0.0.0:$ssh_port:127.0.0.1:$ports root@$v4${plain} 输入 root 密码进行转发"
+        echo -e "${green}请在浏览器地址栏复制${plain} ${bblue}127.0.0.1:$ssh_port/$path${plain} ${green}进入 xray-ui 登录界面"
+        echo -e "${green}当前 xray-ui 登录用户名:${plain}${bblue}${username}${plain}"
+        echo -e "${green}当前 xray-ui 登录密码:${plain}${bblue}${password}${plain}"
+        yellow "不使用ssh 转发请配置nginx https代理或者xray-ui 配置证书"
+    fi
+    }
+    ports=$(/usr/local/xray-ui/xray-ui 2>&1 | grep "tcp" | awk '{print $5}' | cut -d':' -f2)
+    if [[ -n $ports ]]; then
+        echo -e ""
+        yellow "xray-ui $remoteV 安装成功,请稍等3秒,检测IP环境,输出xray-ui登录信息……"
+        ssh_forwarding
+        yellow "下面是xray-ui tls mTLS 配置信息"
+        yellow "证书管理 xray-ui ssl_main  cf 证书申请 xray-ui ssl_CF"
+        yellow "TLS 配置 /usr/local/xray-ui/xray-ui cert -webCert /root/cert/你的域名/fullchain.pem -webCertKey /root/cert/你的域名/privkey.pem 重启 xray-ui restart 生效"
+        yellow "mTLS 配置 /usr/local/xray-ui/xray-ui cert -webCert /root/cert/你的域名/fullchain.pem -webCertKey /root/cert/你的域名/privkey.pem -webCa /root/cert/ca.cer 重启 xray-ui restart 生效"
+        yellow "访问:https://你的域名:$ports/$path"
+        yellow "mTLS windows 使用....."
+        yellow "生成windows客户端证书 client.p12..."
+        yellow "openssl pkcs12 -export -out client.p12 -inkey /root/cert/你的域名/privkey.pem -in  /root/cert/${domain}.cer -certfile /root/cert/ca.cer"
+        yellow "client.p12: windows客户端证书 记得设置密码 导入证书需要密码"
+        yellow "client.p12 文件导入windows系统 桌面双击打开->导入->下一步->将所有证书都放入下列存储->个人->完成 如果导入失败开始菜单搜证书 打开管理用户证书管理->个人->所有任务->导入->输入密码"
+    
+    else
+        red "xray-ui安装失败,请查看日志,运行 xray-ui log"
+    fi
+    sleep 1
+    echo -e ""
+    echo -e "$int"
+    echo -e ""
+    echo -e "xray-ui 管理脚本使用方法: "
+    echo -e "----------------------------------------------"
+    echo -e "xray-ui              - 显示管理菜单"
+    echo -e "xray-ui start        - 启动 xray-ui 面板"
+    echo -e "xray-ui stop         - 停止 xray-ui 面板"
+    echo -e "xray-ui restart      - 重启 xray-ui 面板"
+    echo -e "xray-ui status       - 查看 xray-ui 状态"
+    echo -e "xray-ui enable       - 设置 xray-ui 开机自启"
+    echo -e "xray-ui disable      - 取消 xray-ui 开机自启"
+    echo -e "xray-ui log          - 查看 xray-ui 日志"
+    echo -e "xray-ui v2-ui        - 迁移本机器的 v2-ui 账号数据至 xray-ui"
+    echo -e "xray-ui update       - 更新 xray-ui 面板"
+    echo -e "xray-ui geoip        - 更新 geoip ip库"
+    echo -e "xray-ui update_shell - 更新 xray-ui 脚本"
+    echo -e "xray-ui install      - 安装 xray-ui 面板"
+    echo -e "xray-ui x25519       - REALITY  key 生成"
+    echo -e "xray-ui ssl_main     - SSL 证书管理"
+    echo -e "xray-ui ssl_CF       - Cloudflare SSL 证书"
+    echo -e "xray-ui crontab      - 添加geoip到任务计划每天凌晨1.30执行"    
+    echo -e "xray-ui uninstall    - 卸载 xray-ui 面板"
+    echo -e "----------------------------------------------"
+    rm -f install.sh
+}
+
+echo -e "${green}开始安装xray-ui必要依赖${plain}"
+install_base
+echo -e "${green}开始安装xray-ui核心组件${plain}"
+install_xray-ui $1