| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369 |
- #!/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
|