搭建Xray最新Reality协议
若用 REALITY 取代 TLS,可消除服务端 TLS 指纹特征,仍有前向保密性等,且证书链攻击无效,安全性超越常规 TLS
可以指向别人的网站,无需自己买域名、配置 TLS 服务端,更方便,实现向中间人呈现指定 SNI 的全程真实 TLS
安装Xray
bash -c "$(curl -L https://github.com/XTLS/Xray-install/raw/main/install-release.sh)" @ install --beta
生成uuid
cd /usr/local/bin/
./xray uuid
生成公钥私钥
./xray x25519
配置Xray
配置文件示例如下(可以复制到电脑文本文件里修改)
{ "inbounds": [ // 服务端入站配置 { "listen": "0.0.0.0", "port": 443, "protocol": "vless", "settings": { "clients": [ { "id": "刚才生产的uuid", //必填,执行 ./xray uuid 生成,或 1-30 字节的字符串 "flow": "xtls-rprx-vision" // 选填,若有,客户端必须启用 XTLS } ], "decryption": "none" }, "streamSettings": { "network": "tcp", "security": "reality", "realitySettings": { "show": false, // 选填,若为 true,输出调试信息 "dest": "www.amazon.com:443", // 必填,格式同 VLESS fallbacks 的 dest "xver": 0, // 选填,格式同 VLESS fallbacks 的 xver "serverNames": [ // 必填,客户端可用的 serverName 列表,暂不支持 * 通配符 "amazon.com", "www.amazon.com" ], "privateKey": "刚才生成的私钥Private key", // 必填,执行 ./xray x25519 生成, "minClientVer": "", // 选填,客户端 Xray 最低版本,格式为 x.y.z "maxClientVer": "", // 选填,客户端 Xray 最高版本,格式为 x.y.z "maxTimeDiff": 0, // 选填,允许的最大时间差 "shortIds": [ // 必填,客户端可用的 shortId 列表,可用于区分不同的客户端 "", // 若有此项,客户端 shortId 可为空,openssl rand -hex 8生成 "0123456789abcdef" // 0 到 f,长度为 2 的倍数,长度上限为 16 ] } } } ], "outbounds": [ { "protocol": "freedom", "tag": "direct" }, { "protocol": "blackhole", "tag": "blocked" } ] }
设置配置文件
nano /usr/local/etc/xray/config.json
把刚才的配置文件黏贴进去,Ctrl X 退出,按y确认。
配置完成后,运行下列命令执行
systemctl restart xray
客户端配置
微软安卓客户端可以用v2rayN,v2rayNG,苹果客户端可以用Shadowrocket、FoXray
通常代理用途,目标网站最低标准:国外网站,支持 TLSv1.3 与 H2,域名非跳转用(主域名可能被用于跳转到 www)
加分项:IP 相近(更像,且延迟低),Server Hello 后的握手消息一起加密(如 dl.google.com),有 OCSP Stapling
配置加分项:禁回国流量,TCP/80、UDP/443 也转发(REALITY 对外表现即为端口转发,目标 IP 冷门或许更好)
感谢分享,谢谢站长!!