修正vless协议配置问题

(cherry picked from commit 5cbb1654e22841b5078829e926946def1a10201e)
This commit is contained in:
Rust 2025-11-01 11:49:17 +08:00 committed by speakeloudest
parent 765b45c0fc
commit 54b0cc44ff

View File

@ -251,7 +251,9 @@ class KROutboundItem {
Map<String, dynamic>? securityConfig;
// 🔧 protocols
print('🔍 检查 protocols 字段: isEmpty=${nodeListItem.protocols.isEmpty}, length=${nodeListItem.protocols.length}');
if (nodeListItem.protocols.isNotEmpty) {
print('✅ protocols 字段不为空,开始解析...');
try {
final protocolsList = jsonDecode(nodeListItem.protocols) as List;
print('📄 解析到 protocols 数组,共 ${protocolsList.length} 个协议');
@ -314,17 +316,49 @@ class KROutboundItem {
final tlsEnabled = security == 'tls' || security == 'reality';
securityConfig = {
'tls_enabled': tlsEnabled, // TLS
'tls_enabled': tlsEnabled,
'security_type': security, // 🔧 tls/reality
'sni': matchedProtocol['sni'] ?? matchedProtocol['server_name'],
'allow_insecure': matchedProtocol['allow_insecure'] ?? matchedProtocol['insecure'] ?? true,
'fingerprint': matchedProtocol['fingerprint'] ?? 'chrome',
};
// 🔧 Reality Reality
if (security == 'reality') {
securityConfig['reality_enabled'] = true;
securityConfig['reality_public_key'] = matchedProtocol['reality_public_key'] ?? '';
securityConfig['reality_short_id'] = matchedProtocol['reality_short_id'] ?? '';
securityConfig['reality_server_name'] = matchedProtocol['reality_server_addr'] ?? matchedProtocol['reality_server_name'] ?? '';
print(' 🔒 Reality 配置:');
print(' - public_key: ${securityConfig['reality_public_key']}');
print(' - short_id: ${securityConfig['reality_short_id']}');
print(' - server_name: ${securityConfig['reality_server_name']}');
}
print(' ✅ Security config: security=$security, tls_enabled=$tlsEnabled, config=$securityConfig');
}
// 🔧 flow VLESS xtls-rprx-vision
if (matchedProtocol['flow'] != null && matchedProtocol['flow'].toString().isNotEmpty) {
securityConfig ??= {};
securityConfig['flow'] = matchedProtocol['flow'].toString();
print(' 📊 Flow: ${securityConfig['flow']}');
}
// 🔧 encryption VLESS
if (matchedProtocol['encryption'] != null) {
securityConfig ??= {};
securityConfig['encryption'] = matchedProtocol['encryption'].toString();
print(' 🔐 Encryption: ${securityConfig['encryption']}');
}
}
} catch (e) {
} catch (e, stackTrace) {
print('⚠️ 解析 protocols 字段失败: $e');
print('📍 堆栈跟踪: $stackTrace');
}
} else {
print('❌ protocols 字段为空,跳过解析');
}
// config API格式
@ -373,15 +407,33 @@ class KROutboundItem {
final bool isDomain = !RegExp(r'^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$')
.hasMatch(nodeListItem.serverAddr);
// 🔧 使 security_config SNI
// 🔧 Reality
final bool isReality = securityConfig?['security_type'] == 'reality';
final bool vlessTlsEnabled = securityConfig?['tls_enabled'] ?? false;
// 🔧 server_nameReality 使 reality_server_name TLS 使 sni
String serverName = nodeListItem.serverAddr;
if (securityConfig != null && securityConfig['sni'] != null && securityConfig['sni'].toString().isNotEmpty) {
if (isReality && securityConfig?['reality_server_name'] != null && securityConfig!['reality_server_name'].toString().isNotEmpty) {
serverName = securityConfig['reality_server_name'].toString();
print('🔒 Reality server_name: $serverName');
} else if (securityConfig != null && securityConfig['sni'] != null && securityConfig['sni'].toString().isNotEmpty) {
serverName = securityConfig['sni'].toString();
}
// 🔧 security_config TLS
final bool vlessTlsEnabled = securityConfig?['tls_enabled'] ?? false;
print('🔐 VLESS TLS 状态: enabled=$vlessTlsEnabled');
print('🔐 VLESS 配置: TLS=$vlessTlsEnabled, Reality=$isReality, isDomain=$isDomain');
print('🔐 Server Name: $serverName');
if (isReality) {
print('🔒 Reality 详细配置:');
print(' - public_key: ${securityConfig?['reality_public_key']}');
print(' - short_id: ${securityConfig?['reality_short_id']}');
print(' - server_name: ${securityConfig?['reality_server_name']}');
print(' - flow: ${securityConfig?['flow']}');
}
// 🔧 flowvision
final bool hasFlow = securityConfig?['flow'] != null &&
securityConfig!['flow'].toString().isNotEmpty &&
securityConfig['flow'].toString() != 'none';
config = {
"type": "vless",
@ -389,11 +441,25 @@ class KROutboundItem {
"server": nodeListItem.serverAddr,
"server_port": nodeListItem.port,
"uuid": nodeListItem.uuid,
// 🔧 flow xtls-rprx-vision
if (hasFlow)
"flow": securityConfig['flow'].toString(),
// 🔧 packet_encoding flow
// flow packet_encoding
if (!hasFlow)
"packet_encoding": "",
if (transportConfig != null) "transport": transportConfig,
if (vlessTlsEnabled) "tls": {
"enabled": true,
if (isDomain) "server_name": serverName,
// 🔧 Reality server_name TLS
if (isReality || isDomain) "server_name": serverName,
"insecure": securityConfig?['allow_insecure'] ?? true,
// 🔧 Reality
if (isReality) "reality": {
"enabled": true,
"public_key": securityConfig?['reality_public_key'] ?? '',
"short_id": securityConfig?['reality_short_id'] ?? '',
},
"utls": {
"enabled": true,
"fingerprint": securityConfig?['fingerprint'] ?? "chrome"