v2ray

#代理 #网络

一、服务端

yum install -y wget unzip
bash <(curl -L -s https://install.direct/go.sh)

服务端配置1:监听一个非常用端口,基本的配置方式

vi /etc/v2ray/config.json

config.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 ,在客户端订阅设置中输入该地址即可使用。

最后更新于