v2ray
#代理 #网络
一、服务端
yum install -y wget unzip
bash <(curl -L -s https://install.direct/go.sh)服务端配置1:监听一个非常用端口,基本的配置方式
vi /etc/v2ray/config.jsonconfig.json示例内容
{
"inbounds": [{
"port": 42025,
"protocol": "vmess",
"settings": {
"clients": [
{
"id": "b831381d-6324-4d53-ad4f-8cda48b30811", # UUI相当于密码,服务端,客户端要一致
"level": 1,
"alterId": 64
}
]
}
}],
"outbounds": [{
"protocol": "freedom",
"settings": {}
},{
"protocol": "blackhole",
"settings": {},
"tag": "blocked"
}],
"routing": {
"rules": [
{
"type": "field",
"ip": ["geoip:private"],
"outboundTag": "blocked"
}
]
}
}# 启动服务
systemctl start v2ray服务端配置2:使用反向代理工具(nginx/apache/caddy)监听443端口,反向代理到v2ray服务器,以下配置以nginx+ssl+v2ray+ws(websocket),用443端口来降低被屏蔽的风险
以下是nginx的部分配置,安装nginx和获取ssl证书不做讲解 nginx配置(摘选server配置):
……
server {
listen 443 ssl;
server_name gcloud.dier.xyz;
ssl_certificate /opt/nginx/conf/nginx-ssl/gcloud.dier.xyz.pem;
ssl_certificate_key /opt/nginx/conf/nginx-ssl/gcloud.dier.xyz.key;
ssl_session_timeout 5m;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;
ssl_prefer_server_ciphers on;
charset utf-8;
location / {
root html;
index index.html;
}
location /v2 {
proxy_pass http://127.0.0.1:42025;
}
}
……v2ray配置文件config.json
{
"log": {
"access": "/var/log/v2ray/access.log",
"error": "/var/log/v2ray/error.log",
"loglevel": "warning"
},
"inbounds": [{
"port": 42026,
"protocol": "vmess",
"settings": {
"clients": [
{
"id": "33f528ed-875a-4288-9811-4d95d2bb25dc",
"level": 1,
"alterId": 64
}
]
},
"streamSettings": {
"network": "ws",
"wsSettings": {
"path": "/v2"
}
}
},
//下面的配置为再监听一个42025端口,不走nginx反代,直接通过客户端连接,可以让部分客户端(ios)无法使用上面的443端口时来连接
{
"port": 42025,
"protocol": "vmess",
"settings": {
"clients": [
{
"id": "33f528ed-875a-4288-9811-4d95d2bb25dc",
"level": 1,
"alterId": 64
}
]
}
}
],
"outbounds": [{
"protocol": "freedom",
"settings": {}
},{
"protocol": "blackhole",
"settings": {},
"tag": "blocked"
}],
"routing": {
"rules": [
{
"type": "field",
"ip": ["geoip:private"],
"outboundTag": "blocked"
}
]
}
}# 启动服务
systemctl start v2ray开户bbr加速,bbr是google[[开源]]的一个TCP拥堵控制算法,用于降低丢包率从而实现网络加速。不过需要linux内核4.10+才支持(可以通过uname -r命令查看当前linux内核版本)。所以下面的脚本会自动升级linux内核至最新并安装bbr。脚本安装完需要重启
wget --no-check-certificate https://github.com/teddysun/across/raw/master/bbr.sh && chmod +x bbr.sh && ./bbr.sh如果不能下载,保存如下内容,执行安装
#!/usr/bin/env bash
#
# Auto install latest kernel for TCP BBR
#
# System Required: CentOS 6+, Debian7+, Ubuntu12+
#
# Copyright (C) 2016-2018 Teddysun <[email protected]>
#
# URL: https://teddysun.com/489.html
#
red='\033[0;31m'
green='\033[0;32m'
yellow='\033[0;33m'
plain='\033[0m'
cur_dir=$(pwd)
[[ $EUID -ne 0 ]] && echo -e "${red}Error:${plain} This script must be run as root!" && exit 1
[[ -d "/proc/vz" ]] && echo -e "${red}Error:${plain} Your VPS is based on OpenVZ, which is not supported." && exit 1
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"
else
release=""
fi
is_digit(){
local input=${1}
if [[ "$input" =~ ^[0-9]+$ ]]; then
return 0
else
return 1
fi
}
is_64bit(){
if [ $(getconf WORD_BIT) = '32' ] && [ $(getconf LONG_BIT) = '64' ]; then
return 0
else
return 1
fi
}
get_valid_valname(){
local val=${1}
local new_val=$(eval echo $val | sed 's/[-.]/_/g')
echo ${new_val}
}
get_hint(){
local val=${1}
local new_val=$(get_valid_valname $val)
eval echo "\$hint_${new_val}"
}
#Display Memu
display_menu(){
local soft=${1}
local default=${2}
eval local arr=(\${${soft}_arr[@]})
local default_prompt
if [[ "$default" != "" ]]; then
if [[ "$default" == "last" ]]; then
default=${#arr[@]}
fi
default_prompt="(default ${arr[$default-1]})"
fi
local pick
local hint
local vname
local prompt="which ${soft} you'd select ${default_prompt}: "
while :
do
echo -e "\n------------ ${soft} setting ------------\n"
for ((i=1;i<=${#arr[@]};i++ )); do
vname="$(get_valid_valname ${arr[$i-1]})"
hint="$(get_hint $vname)"
[[ "$hint" == "" ]] && hint="${arr[$i-1]}"
echo -e "${green}${i}${plain}) $hint"
done
echo
read -p "${prompt}" pick
if [[ "$pick" == "" && "$default" != "" ]]; then
pick=${default}
break
fi
if ! is_digit "$pick"; then
prompt="Input error, please input a number"
continue
fi
if [[ "$pick" -lt 1 || "$pick" -gt ${#arr[@]} ]]; then
prompt="Input error, please input a number between 1 and ${#arr[@]}: "
continue
fi
break
done
eval ${soft}=${arr[$pick-1]}
vname="$(get_valid_valname ${arr[$pick-1]})"
hint="$(get_hint $vname)"
[[ "$hint" == "" ]] && hint="${arr[$pick-1]}"
echo -e "\nyour selection: $hint\n"
}
version_ge(){
test "$(echo "$@" | tr " " "\n" | sort -rV | head -n 1)" == "$1"
}
get_latest_version() {
latest_version=($(wget -qO- https://kernel.ubuntu.com/~kernel-ppa/mainline/ | awk -F'\"v' '/v[4-9]./{print $2}' | cut -d/ -f1 | grep -v - | sort -V))
[ ${#latest_version[@]} -eq 0 ] && echo -e "${red}Error:${plain} Get latest kernel version failed." && exit 1
kernel_arr=()
for i in ${latest_version[@]}; do
if version_ge $i 4.14; then
kernel_arr+=($i);
fi
done
display_menu kernel last
if [[ `getconf WORD_BIT` == "32" && `getconf LONG_BIT` == "64" ]]; then
deb_name=$(wget -qO- https://kernel.ubuntu.com/~kernel-ppa/mainline/v${kernel}/ | grep "linux-image" | grep "generic" | awk -F'\">' '/amd64.deb/{print $2}' | cut -d'<' -f1 | head -1)
deb_kernel_url="https://kernel.ubuntu.com/~kernel-ppa/mainline/v${kernel}/${deb_name}"
deb_kernel_name="linux-image-${kernel}-amd64.deb"
modules_deb_name=$(wget -qO- https://kernel.ubuntu.com/~kernel-ppa/mainline/v${kernel}/ | grep "linux-modules" | grep "generic" | awk -F'\">' '/amd64.deb/{print $2}' | cut -d'<' -f1 | head -1)
deb_kernel_modules_url="https://kernel.ubuntu.com/~kernel-ppa/mainline/v${kernel}/${modules_deb_name}"
deb_kernel_modules_name="linux-modules-${kernel}-amd64.deb"
else
deb_name=$(wget -qO- https://kernel.ubuntu.com/~kernel-ppa/mainline/v${kernel}/ | grep "linux-image" | grep "generic" | awk -F'\">' '/i386.deb/{print $2}' | cut -d'<' -f1 | head -1)
deb_kernel_url="https://kernel.ubuntu.com/~kernel-ppa/mainline/v${kernel}/${deb_name}"
deb_kernel_name="linux-image-${kernel}-i386.deb"
modules_deb_name=$(wget -qO- https://kernel.ubuntu.com/~kernel-ppa/mainline/v${kernel}/ | grep "linux-modules" | grep "generic" | awk -F'\">' '/i386.deb/{print $2}' | cut -d'<' -f1 | head -1)
deb_kernel_modules_url="https://kernel.ubuntu.com/~kernel-ppa/mainline/v${kernel}/${modules_deb_name}"
deb_kernel_modules_name="linux-modules-${kernel}-i386.deb"
fi
[ -z ${deb_name} ] && echo -e "${red}Error:${plain} Getting Linux kernel binary package name failed, maybe kernel build failed. Please choose other one and try again." && exit 1
}
get_opsy() {
[ -f /etc/redhat-release ] && awk '{print ($1,$3~/^[0-9]/?$3:$4)}' /etc/redhat-release && return
[ -f /etc/os-release ] && awk -F'[= "]' '/PRETTY_NAME/{print $3,$4,$5}' /etc/os-release && return
[ -f /etc/lsb-release ] && awk -F'[="]+' '/DESCRIPTION/{print $2}' /etc/lsb-release && return
}
opsy=$( get_opsy )
arch=$( uname -m )
lbit=$( getconf LONG_BIT )
kern=$( uname -r )
get_char() {
SAVEDSTTY=`stty -g`
stty -echo
stty cbreak
dd if=/dev/tty bs=1 count=1 2> /dev/null
stty -raw
stty echo
stty $SAVEDSTTY
}
getversion() {
if [[ -s /etc/redhat-release ]]; then
grep -oE "[0-9.]+" /etc/redhat-release
else
grep -oE "[0-9.]+" /etc/issue
fi
}
centosversion() {
if [ x"${release}" == x"centos" ]; then
local code=$1
local version="$(getversion)"
local main_ver=${version%%.*}
if [ "$main_ver" == "$code" ]; then
return 0
else
return 1
fi
else
return 1
fi
}
check_bbr_status() {
local param=$(sysctl net.ipv4.tcp_congestion_control | awk '{print $3}')
if [[ x"${param}" == x"bbr" ]]; then
return 0
else
return 1
fi
}
check_kernel_version() {
local kernel_version=$(uname -r | cut -d- -f1)
if version_ge ${kernel_version} 4.9; then
return 0
else
return 1
fi
}
install_elrepo() {
if centosversion 5; then
echo -e "${red}Error:${plain} not supported CentOS 5."
exit 1
fi
rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org
if centosversion 6; then
rpm -Uvh https://www.elrepo.org/elrepo-release-6-8.el6.elrepo.noarch.rpm
elif centosversion 7; then
rpm -Uvh https://www.elrepo.org/elrepo-release-7.0-3.el7.elrepo.noarch.rpm
fi
if [ ! -f /etc/yum.repos.d/elrepo.repo ]; then
echo -e "${red}Error:${plain} Install elrepo failed, please check it."
exit 1
fi
}
sysctl_config() {
sed -i '/net.core.default_qdisc/d' /etc/sysctl.conf
sed -i '/net.ipv4.tcp_congestion_control/d' /etc/sysctl.conf
echo "net.core.default_qdisc = fq" >> /etc/sysctl.conf
echo "net.ipv4.tcp_congestion_control = bbr" >> /etc/sysctl.conf
sysctl -p >/dev/null 2>&1
}
install_config() {
if [[ x"${release}" == x"centos" ]]; then
if centosversion 6; then
if [ ! -f "/boot/grub/grub.conf" ]; then
echo -e "${red}Error:${plain} /boot/grub/grub.conf not found, please check it."
exit 1
fi
sed -i 's/^default=.*/default=0/g' /boot/grub/grub.conf
elif centosversion 7; then
if [ ! -f "/boot/grub2/grub.cfg" ]; then
echo -e "${red}Error:${plain} /boot/grub2/grub.cfg not found, please check it."
exit 1
fi
grub2-set-default 0
fi
elif [[ x"${release}" == x"debian" || x"${release}" == x"ubuntu" ]]; then
/usr/sbin/update-grub
fi
}
reboot_os() {
echo
echo -e "${green}Info:${plain} The system needs to reboot."
read -p "Do you want to restart system? [y/n]" is_reboot
if [[ ${is_reboot} == "y" || ${is_reboot} == "Y" ]]; then
reboot
else
echo -e "${green}Info:${plain} Reboot has been canceled..."
exit 0
fi
}
install_bbr() {
check_bbr_status
if [ $? -eq 0 ]; then
echo
echo -e "${green}Info:${plain} TCP BBR has already been installed. nothing to do..."
exit 0
fi
check_kernel_version
if [ $? -eq 0 ]; then
echo
echo -e "${green}Info:${plain} Your kernel version is greater than 4.9, directly setting TCP BBR..."
sysctl_config
echo -e "${green}Info:${plain} Setting TCP BBR completed..."
exit 0
fi
if [[ x"${release}" == x"centos" ]]; then
install_elrepo
[ ! "$(command -v yum-config-manager)" ] && yum install -y yum-utils > /dev/null 2>&1
[ x"$(yum-config-manager elrepo-kernel | grep -w enabled | awk '{print $3}')" != x"True" ] && yum-config-manager --enable elrepo-kernel > /dev/null 2>&1
if centosversion 6; then
if is_64bit; then
rpm_kernel_name="kernel-ml-4.18.20-1.el6.elrepo.x86_64.rpm"
rpm_kernel_devel_name="kernel-ml-devel-4.18.20-1.el6.elrepo.x86_64.rpm"
rpm_kernel_url_1="http://repos.lax.quadranet.com/elrepo/archive/kernel/el6/x86_64/RPMS/"
else
rpm_kernel_name="kernel-ml-4.18.20-1.el6.elrepo.i686.rpm"
rpm_kernel_devel_name="kernel-ml-devel-4.18.20-1.el6.elrepo.i686.rpm"
rpm_kernel_url_1="http://repos.lax.quadranet.com/elrepo/archive/kernel/el6/i386/RPMS/"
fi
rpm_kernel_url_2="https://dl.lamp.sh/files/"
wget -c -t3 -T60 -O ${rpm_kernel_name} ${rpm_kernel_url_1}${rpm_kernel_name}
if [ $? -ne 0 ]; then
rm -rf ${rpm_kernel_name}
wget -c -t3 -T60 -O ${rpm_kernel_name} ${rpm_kernel_url_2}${rpm_kernel_name}
fi
wget -c -t3 -T60 -O ${rpm_kernel_devel_name} ${rpm_kernel_url_1}${rpm_kernel_devel_name}
if [ $? -ne 0 ]; then
rm -rf ${rpm_kernel_devel_name}
wget -c -t3 -T60 -O ${rpm_kernel_devel_name} ${rpm_kernel_url_2}${rpm_kernel_devel_name}
fi
if [ -f "${rpm_kernel_name}" ]; then
rpm -ivh ${rpm_kernel_name}
else
echo -e "${red}Error:${plain} Download ${rpm_kernel_name} failed, please check it."
exit 1
fi
if [ -f "${rpm_kernel_devel_name}" ]; then
rpm -ivh ${rpm_kernel_devel_name}
else
echo -e "${red}Error:${plain} Download ${rpm_kernel_devel_name} failed, please check it."
exit 1
fi
rm -f ${rpm_kernel_name} ${rpm_kernel_devel_name}
elif centosversion 7; then
yum -y install kernel-ml kernel-ml-devel
if [ $? -ne 0 ]; then
echo -e "${red}Error:${plain} Install latest kernel failed, please check it."
exit 1
fi
fi
elif [[ x"${release}" == x"debian" || x"${release}" == x"ubuntu" ]]; then
[[ ! -e "/usr/bin/wget" ]] && apt-get -y update && apt-get -y install wget
echo -e "${green}Info:${plain} Getting latest kernel version..."
get_latest_version
if [ -n ${modules_deb_name} ]; then
wget -c -t3 -T60 -O ${deb_kernel_modules_name} ${deb_kernel_modules_url}
if [ $? -ne 0 ]; then
echo -e "${red}Error:${plain} Download ${deb_kernel_modules_name} failed, please check it."
exit 1
fi
fi
wget -c -t3 -T60 -O ${deb_kernel_name} ${deb_kernel_url}
if [ $? -ne 0 ]; then
echo -e "${red}Error:${plain} Download ${deb_kernel_name} failed, please check it."
exit 1
fi
[ -f ${deb_kernel_modules_name} ] && dpkg -i ${deb_kernel_modules_name}
dpkg -i ${deb_kernel_name}
rm -f ${deb_kernel_name} ${deb_kernel_modules_name}
else
echo -e "${red}Error:${plain} OS is not be supported, please change to CentOS/Debian/Ubuntu and try again."
exit 1
fi
install_config
sysctl_config
reboot_os
}
clear
echo "---------- System Information ----------"
echo " OS : $opsy"
echo " Arch : $arch ($lbit Bit)"
echo " Kernel : $kern"
echo "----------------------------------------"
echo " Auto install latest kernel for TCP BBR"
echo
echo " URL: https://teddysun.com/489.html"
echo "----------------------------------------"
echo
echo "Press any key to start...or Press Ctrl+C to cancel"
char=`get_char`
install_bbr 2>&1 | tee ${cur_dir}/install_bbr.log
将上面的脚本内容保存后执行脚本。完成后重启系统。使用uname -r来查看升级后的linux内核版本。
执行下面两条命令,如果能看到bbr字样,表示bbr模块已经启动
sysctl net.ipv4.tcp_available_congestion_control
sysctl net.ipv4.tcp_congestion_control二、客户端
windows推荐使用v2rayN+v2ray core v2ray core github地址:https://github.com/v2ray/v2ray-core/releases v2ranN github地址:https://github.com/2dust/v2rayN/releases
将下载的两个包解压缩,并将两个目录内容合并
windows客户端配置 新建一个json文件,将如下内容添加到Json文件,
{
"inbounds": [
{
"port": 1080, // 监听端口
"protocol": "socks", // 入口协议为 SOCKS 5
"sniffing": {
"enabled": true,
"destOverride": ["http", "tls"]
},
"settings": {
"auth": "noauth" //socks的认证设置,noauth 代表不认证,由于 socks 通常在客户端使用,所以这里不认证
}
}
],
"outbounds": [
{
"protocol": "vmess", // 出口协议
"settings": {
"vnext": [
{
"address": "serveraddr.com", // 服务器地址,请修改为你自己的服务器 IP 或域名
"port": 16823, // 服务器端口
"users": [
{
"id": "b831381d-6324-4d53-ad4f-8cda48b30811", // 用户 ID,必须与服务器端配置相同
"alterId": 64 // 此处的值也应当与服务器相同
}
]
}
]
}
}
]
}以下是带路由规则的客户端配置,
{
"inbounds": [
{
"port": 1080, // 监听端口
"protocol": "socks", // 入口协议为 SOCKS 5
"sniffing": {
"enabled": true,
"destOverride": ["http", "tls"]
},
"settings": {
"auth": "noauth" //socks的认证设置,noauth 代表不认证,由于 socks 通常在客户端使用,所以这里不认证
}
}
],
"outbounds": [
{
"protocol": "vmess", // 出口协议,代理
"settings": {
"vnext": [
{
"address": "serveraddr.com", // 服务器地址,请修改为你自己的服务器 IP 或域名
"port": 16823, // 服务器端口
"users": [
{
"id": "b831381d-6324-4d53-ad4f-8cda48b30811", // 用户 ID,必须与服务器端配置相同
"alterId": 64 // 此处的值也应当与服务器相同
}
]
}
]
}
},
{
"protocol": "freedom", // 出口协议,直接,出口可以添加多个协议
"settings": {},
"tag": "direct" //如果要使用路由,这个 tag 是一定要有的,在这里 direct 就是 freedom 的一个标记,在路由中说 direct, V2Ray 就知道是这里的 freedom 了
}
],
"routing": {
"domainStrategy": "IPOnDemand",
"rules": [
{
"type": "field",
"outboundTag": "direct",
"domain": ["geosite:cn"] // 中国大陆主流网站的域名
},
{
"type": "field",
"outboundTag": "direct",
"ip": [
"geoip:cn", // 中国大陆的 IP
"geoip:private" // 私有地址 IP,如路由器等
]
}
]
}
}打开v2rayN,在“服务器”菜单中选择“添加自定义配置服务器”导入刚才的json配置,即可完成服务器添加
v2ray 订阅设置
打开 文本编辑器,按如下格式输入内容保存为config.txt。如果不知道如何填写下面的配置字典,可以用客户端手动添加一下服务器配置,然后导出配置信息,例如,v2rayN 就可以选中已经有的服务器配置,导出分享URL至剪贴板/导出订阅内容至剪贴板。导出的内容如果是以协议开头,例如: vmess:// ssr:// 加一长串无规律字符串,则可以将内容再base64转换一下。如果导出内容直接就是一长串无规律字条串,则不需要再次base64转换,直接操作最后一步即可。
{
"v": "2",
"ps": "proxy",
"add": "server.domain.com",
"port": "443",
"id": "UUID",
"aid": "64",
"net": "ws",
"type": "none",
"host": "",
"path": "/v2",
"tls": "tls"
}描述: v: 版本号,不需要修改 ps: 别名,方便识别,任意定义 add: 服务器地址 port: 服务器端口 id: UUID aid: 额外ID alterID net: 传输协议,ws tcp kcp h2 quic等 type: 伪装类型,tcp kcp quic伪装类型,一般为none host: 伪装域名,一般为空 path: ws协议用到的路径 tls: 传输安全,如果没有留空即可
将上面的字典内容找个base64转换的网站转换为base64格式或者用base64 config.txt来转换,结果如下:
JTdCJTBBJTIwJTIwJTIydiUyMiUzQSUyMCUyMjIlMjIlMkMlMEElMjAlMjAlMjJwcyUyMiUzQSUyMCUyMnByb3h5JTIyJTJDJTBBJTIwJTIwJTIyYWRkJTIyJTNBJTIwJTIyc2VydmVyLmRvbWFpbi5jb20lMjIlMkMlMEElMjAlMjAlMjJwb3J0JTIyJTNBJTIwJTIyNDQzJTIyJTJDJTBBJTIwJTIwJTIyaWQlMjIlM0ElMjAlMjJVVUlEJTIyJTJDJTBBJTIwJTIwJTIyYWlkJTIyJTNBJTIwJTIyNjQlMjIlMkMlMEElMjAlMjAlMjJuZXQlMjIlM0ElMjAlMjJ3cyUyMiUyQyUwQSUyMCUyMCUyMnR5cGUlMjIlM0ElMjAlMjJub25lJTIyJTJDJTBBJTIwJTIwJTIyaG9zdCUyMiUzQSUyMCUyMiUyMiUyQyUwQSUyMCUyMCUyMnBhdGglMjIlM0ElMjAlMjIvdjIlMjIlMkMlMEElMjAlMjAlMjJ0bHMlMjIlM0ElMjAlMjJ0bHMlMjIlMEElN0Q=然后在前面加上协议,例如常用的vmess
vmess://JTdCJTBBJTIwJTIwJTIydiUyMiUzQSUyMCUyMjIlMjIlMkMlMEElMjAlMjAlMjJwcyUyMiUzQSUyMCUyMnByb3h5JTIyJTJDJTBBJTIwJTIwJTIyYWRkJTIyJTNBJTIwJTIyc2VydmVyLmRvbWFpbi5jb20lMjIlMkMlMEElMjAlMjAlMjJwb3J0JTIyJTNBJTIwJTIyNDQzJTIyJTJDJTBBJTIwJTIwJTIyaWQlMjIlM0ElMjAlMjJVVUlEJTIyJTJDJTBBJTIwJTIwJTIyYWlkJTIyJTNBJTIwJTIyNjQlMjIlMkMlMEElMjAlMjAlMjJuZXQlMjIlM0ElMjAlMjJ3cyUyMiUyQyUwQSUyMCUyMCUyMnR5cGUlMjIlM0ElMjAlMjJub25lJTIyJTJDJTBBJTIwJTIwJTIyaG9zdCUyMiUzQSUyMCUyMiUyMiUyQyUwQSUyMCUyMCUyMnBhdGglMjIlM0ElMjAlMjIvdjIlMjIlMkMlMEElMjAlMjAlMjJ0bHMlMjIlM0ElMjAlMjJ0bHMlMjIlMEElN0Q=然后将该内容再进行一次base64转换,把转换的结果放入一个文本中,例如: info.html。如果有多个配置,可以每个配置一行,写在同一个文件中,一起进行base64转换。
dm1lc3MlM0EvL0pUZENKVEJCSlRJd0pUSXdKVEl5ZGlVeU1pVXpRU1V5TUNVeU1qSWxNaklsTWtNbE1FRWxNakFsTWpBbE1qSndjeVV5TWlVelFTVXlNQ1V5TW5CeWIzaDVKVEl5SlRKREpUQkJKVEl3SlRJd0pUSXlZV1JrSlRJeUpUTkJKVEl3SlRJeWMyVnlkbVZ5TG1SdmJXRnBiaTVqYjIwbE1qSWxNa01sTUVFbE1qQWxNakFsTWpKd2IzSjBKVEl5SlROQkpUSXdKVEl5TkRRekpUSXlKVEpESlRCQkpUSXdKVEl3SlRJeWFXUWxNaklsTTBFbE1qQWxNakpWVlVsRUpUSXlKVEpESlRCQkpUSXdKVEl3SlRJeVlXbGtKVEl5SlROQkpUSXdKVEl5TmpRbE1qSWxNa01sTUVFbE1qQWxNakFsTWpKdVpYUWxNaklsTTBFbE1qQWxNakozY3lVeU1pVXlReVV3UVNVeU1DVXlNQ1V5TW5SNWNHVWxNaklsTTBFbE1qQWxNakp1YjI1bEpUSXlKVEpESlRCQkpUSXdKVEl3SlRJeWFHOXpkQ1V5TWlVelFTVXlNQ1V5TWlVeU1pVXlReVV3UVNVeU1DVXlNQ1V5TW5CaGRHZ2xNaklsTTBFbE1qQWxNakl2ZGpJbE1qSWxNa01sTUVFbE1qQWxNakFsTWpKMGJITWxNaklsTTBFbE1qQWxNakowYkhNbE1qSWxNRUVsTjBRJTNE最后将该base64结果写入例如 info.html 的文件中,并放置在一个网站目录下,例如 https://server.domain.com/config/info.html ,在客户端订阅设置中输入该地址即可使用。
最后更新于