mirror of
				https://github.com/2dust/v2rayN.git
				synced 2025-10-26 10:14:42 +00:00 
			
		
		
		
	Merge 18ccabd193 into 18ac76e683
				
					
				
			This commit is contained in:
		
						commit
						5c4f1ea38f
					
				
					 18 changed files with 138 additions and 2 deletions
				
			
		|  | @ -8,6 +8,7 @@ using System.Runtime.InteropServices; | |||
| using System.Security.Cryptography; | ||||
| using System.Security.Principal; | ||||
| using System.Text; | ||||
| using System.Text.RegularExpressions; | ||||
| using CliWrap; | ||||
| using CliWrap.Buffered; | ||||
| 
 | ||||
|  | @ -357,6 +358,14 @@ public class Utils | |||
|         return userHostsMap; | ||||
|     } | ||||
| 
 | ||||
|     public static List<string> ParseCertSha256ToList(string certSha256Content) | ||||
|     { | ||||
|         return String2List(certSha256Content) | ||||
|                 .Select(s => s.Replace(":", "").Replace(" ", "")) | ||||
|                 .Where(s => s.Length == 64 && Regex.IsMatch(s, @"\A\b[0-9a-fA-F]+\b\Z")) | ||||
|                 .ToList(); | ||||
|     } | ||||
| 
 | ||||
|     #endregion 转换函数 | ||||
| 
 | ||||
|     #region 数据检查 | ||||
|  |  | |||
|  | @ -253,6 +253,7 @@ public static class ConfigHandler | |||
|             item.ShortId = profileItem.ShortId; | ||||
|             item.SpiderX = profileItem.SpiderX; | ||||
|             item.Mldsa65Verify = profileItem.Mldsa65Verify; | ||||
|             item.CertSha256 = profileItem.CertSha256; | ||||
|             item.Extra = profileItem.Extra; | ||||
|             item.MuxEnabled = profileItem.MuxEnabled; | ||||
|         } | ||||
|  |  | |||
|  | @ -94,6 +94,7 @@ public class ProfileItem : ReactiveObject | |||
|     public string ShortId { get; set; } | ||||
|     public string SpiderX { get; set; } | ||||
|     public string Mldsa65Verify { get; set; } | ||||
|     public string CertSha256 { get; set; } | ||||
|     public string Extra { get; set; } | ||||
|     public bool? MuxEnabled { get; set; } | ||||
| } | ||||
|  |  | |||
|  | @ -182,6 +182,7 @@ public class Tls4Sbox | |||
|     public bool? fragment { get; set; } | ||||
|     public string? fragment_fallback_delay { get; set; } | ||||
|     public bool? record_fragment { get; set; } | ||||
|     public List<string>? certificate_sha256 { get; set; } | ||||
| } | ||||
| 
 | ||||
| public class Multiplex4Sbox | ||||
|  |  | |||
|  | @ -355,6 +355,7 @@ public class TlsSettings4Ray | |||
|     public string? shortId { get; set; } | ||||
|     public string? spiderX { get; set; } | ||||
|     public string? mldsa65Verify { get; set; } | ||||
|     public List<string>? pinnedPeerCertificateSha256 { get; set; } | ||||
| } | ||||
| 
 | ||||
| public class TcpSettings4Ray | ||||
|  |  | |||
							
								
								
									
										18
									
								
								v2rayN/ServiceLib/Resx/ResUI.Designer.cs
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										18
									
								
								v2rayN/ServiceLib/Resx/ResUI.Designer.cs
									
									
									
										generated
									
									
									
								
							|  | @ -2364,6 +2364,24 @@ namespace ServiceLib.Resx { | |||
|             } | ||||
|         } | ||||
|          | ||||
|         /// <summary> | ||||
|         ///   查找类似 Server Certificate Fingerprint (SHA-256) 的本地化字符串。 | ||||
|         /// </summary> | ||||
|         public static string TbCertSha256 { | ||||
|             get { | ||||
|                 return ResourceManager.GetString("TbCertSha256", resourceCulture); | ||||
|             } | ||||
|         } | ||||
|          | ||||
|         /// <summary> | ||||
|         ///   查找类似 Hex SHA-256, comma-separated for certificate chain 的本地化字符串。 | ||||
|         /// </summary> | ||||
|         public static string TbCertSha256Tips { | ||||
|             get { | ||||
|                 return ResourceManager.GetString("TbCertSha256Tips", resourceCulture); | ||||
|             } | ||||
|         } | ||||
|          | ||||
|         /// <summary> | ||||
|         ///   查找类似 Clear system proxy 的本地化字符串。 | ||||
|         /// </summary> | ||||
|  |  | |||
|  | @ -1515,4 +1515,10 @@ | |||
|   <data name="TbFakeIPTips" xml:space="preserve"> | ||||
|     <value>Applies globally by default, with built-in FakeIP filtering (sing-box only).</value> | ||||
|   </data> | ||||
|   <data name="TbCertSha256" xml:space="preserve"> | ||||
|     <value>Server Certificate Fingerprint (SHA-256)</value> | ||||
|   </data> | ||||
|   <data name="TbCertSha256Tips" xml:space="preserve"> | ||||
|     <value>Hex SHA-256, comma-separated for certificate chain</value> | ||||
|   </data> | ||||
| </root> | ||||
|  | @ -1515,4 +1515,10 @@ | |||
|   <data name="TbFakeIPTips" xml:space="preserve"> | ||||
|     <value>Applies globally by default, with built-in FakeIP filtering (sing-box only).</value> | ||||
|   </data> | ||||
|   <data name="TbCertSha256" xml:space="preserve"> | ||||
|     <value>Server Certificate Fingerprint (SHA-256)</value> | ||||
|   </data> | ||||
|   <data name="TbCertSha256Tips" xml:space="preserve"> | ||||
|     <value>Hex SHA-256, comma-separated for certificate chain</value> | ||||
|   </data> | ||||
| </root> | ||||
|  | @ -1515,4 +1515,10 @@ | |||
|   <data name="TbFakeIPTips" xml:space="preserve"> | ||||
|     <value>Applies globally by default, with built-in FakeIP filtering (sing-box only).</value> | ||||
|   </data> | ||||
|   <data name="TbCertSha256" xml:space="preserve"> | ||||
|     <value>Server Certificate Fingerprint (SHA-256)</value> | ||||
|   </data> | ||||
|   <data name="TbCertSha256Tips" xml:space="preserve"> | ||||
|     <value>Hex SHA-256, comma-separated for certificate chain</value> | ||||
|   </data> | ||||
| </root> | ||||
|  | @ -1515,4 +1515,10 @@ | |||
|   <data name="TbFakeIPTips" xml:space="preserve"> | ||||
|     <value>Applies globally by default, with built-in FakeIP filtering (sing-box only).</value> | ||||
|   </data> | ||||
|   <data name="TbCertSha256" xml:space="preserve"> | ||||
|     <value>Server Certificate Fingerprint (SHA-256)</value> | ||||
|   </data> | ||||
|   <data name="TbCertSha256Tips" xml:space="preserve"> | ||||
|     <value>Hex SHA-256, comma-separated for certificate chain</value> | ||||
|   </data> | ||||
| </root> | ||||
|  | @ -1512,4 +1512,10 @@ | |||
|   <data name="TbFakeIPTips" xml:space="preserve"> | ||||
|     <value>默认全局生效,内置 FakeIP 过滤,仅在 sing-box 中生效</value> | ||||
|   </data> | ||||
|   <data name="TbCertSha256" xml:space="preserve"> | ||||
|     <value>服务器证书指纹 (SHA-256)</value> | ||||
|   </data> | ||||
|   <data name="TbCertSha256Tips" xml:space="preserve"> | ||||
|     <value>十六进制 SHA-256,证书链用逗号分隔</value> | ||||
|   </data> | ||||
| </root> | ||||
|  | @ -1512,4 +1512,10 @@ | |||
|   <data name="TbFakeIPTips" xml:space="preserve"> | ||||
|     <value>Applies globally by default, with built-in FakeIP filtering (sing-box only).</value> | ||||
|   </data> | ||||
|   <data name="TbCertSha256" xml:space="preserve"> | ||||
|     <value>Server Certificate Fingerprint (SHA-256)</value> | ||||
|   </data> | ||||
|   <data name="TbCertSha256Tips" xml:space="preserve"> | ||||
|     <value>Hex SHA-256, comma-separated for certificate chain</value> | ||||
|   </data> | ||||
| </root> | ||||
|  | @ -251,6 +251,20 @@ public partial class CoreConfigSingboxService | |||
|                         fingerprint = node.Fingerprint.IsNullOrEmpty() ? _config.CoreBasicItem.DefFingerprint : node.Fingerprint | ||||
|                     }; | ||||
|                 } | ||||
|                 if (node.CertSha256.IsNotEmpty()) | ||||
|                 { | ||||
|                     // hex to raw to base64 | ||||
|                     var certSha256List = Utils.ParseCertSha256ToList(node.CertSha256) | ||||
|                         .Select(s => Convert.ToBase64String( | ||||
|                             Enumerable.Range(0, 32) | ||||
|                                       .Select(i => Convert.ToByte(s.Substring(i * 2, 2), 16)) | ||||
|                                       .ToArray())) | ||||
|                         .ToList(); | ||||
|                     if (certSha256List.Count > 0) | ||||
|                     { | ||||
|                         tls.certificate_sha256 = certSha256List; | ||||
|                     } | ||||
|                 } | ||||
|                 if (node.StreamSecurity == Global.StreamSecurityReality) | ||||
|                 { | ||||
|                     tls.reality = new Reality4Sbox() | ||||
|  |  | |||
|  | @ -277,6 +277,14 @@ public partial class CoreConfigV2rayService | |||
|                 { | ||||
|                     tlsSettings.serverName = Utils.String2List(host)?.First(); | ||||
|                 } | ||||
|                 if (node.CertSha256.IsNotEmpty()) | ||||
|                 { | ||||
|                     var certSha256List = Utils.ParseCertSha256ToList(node.CertSha256); | ||||
|                     if (certSha256List.Count > 0) | ||||
|                     { | ||||
|                         tlsSettings.pinnedPeerCertificateSha256 = certSha256List; | ||||
|                     } | ||||
|                 } | ||||
|                 streamSettings.tlsSettings = tlsSettings; | ||||
|             } | ||||
| 
 | ||||
|  |  | |||
|  | @ -709,9 +709,9 @@ | |||
|                 <Grid | ||||
|                     x:Name="gridTlsMore" | ||||
|                     Grid.Row="7" | ||||
|                     ColumnDefinitions="180,Auto" | ||||
|                     ColumnDefinitions="180,Auto,Auto" | ||||
|                     IsVisible="False" | ||||
|                     RowDefinitions="Auto,Auto,Auto,Auto,Auto"> | ||||
|                     RowDefinitions="Auto,Auto,Auto,Auto,Auto,Auto"> | ||||
| 
 | ||||
|                     <TextBlock | ||||
|                         Grid.Row="1" | ||||
|  | @ -765,6 +765,26 @@ | |||
|                         Grid.Column="1" | ||||
|                         Width="200" | ||||
|                         Margin="{StaticResource Margin4}" /> | ||||
| 
 | ||||
|                     <TextBlock | ||||
|                         Grid.Row="5" | ||||
|                         Grid.Column="0" | ||||
|                         Margin="{StaticResource Margin4}" | ||||
|                         VerticalAlignment="Center" | ||||
|                         Text="{x:Static resx:ResUI.TbCertSha256}" /> | ||||
|                     <TextBox | ||||
|                         x:Name="txtCertSha256" | ||||
|                         Grid.Row="5" | ||||
|                         Grid.Column="1" | ||||
|                         Width="400" | ||||
|                         Margin="{StaticResource Margin4}" | ||||
|                         HorizontalAlignment="Left" /> | ||||
|                     <TextBlock | ||||
|                         Grid.Row="5" | ||||
|                         Grid.Column="2" | ||||
|                         Margin="{StaticResource Margin4}" | ||||
|                         VerticalAlignment="Center" | ||||
|                         Text="{x:Static resx:ResUI.TbCertSha256Tips}" /> | ||||
|                 </Grid> | ||||
|                 <Grid | ||||
|                     x:Name="gridRealityMore" | ||||
|  |  | |||
|  | @ -189,6 +189,7 @@ public partial class AddServerWindow : WindowBase<AddServerViewModel> | |||
|             this.Bind(ViewModel, vm => vm.SelectedSource.AllowInsecure, v => v.cmbAllowInsecure.SelectedValue).DisposeWith(disposables); | ||||
|             this.Bind(ViewModel, vm => vm.SelectedSource.Fingerprint, v => v.cmbFingerprint.SelectedValue).DisposeWith(disposables); | ||||
|             this.Bind(ViewModel, vm => vm.SelectedSource.Alpn, v => v.cmbAlpn.SelectedValue).DisposeWith(disposables); | ||||
|             this.Bind(ViewModel, vm => vm.SelectedSource.CertSha256, v => v.txtCertSha256.Text).DisposeWith(disposables); | ||||
|             //reality | ||||
|             this.Bind(ViewModel, vm => vm.SelectedSource.Sni, v => v.txtSNI2.Text).DisposeWith(disposables); | ||||
|             this.Bind(ViewModel, vm => vm.SelectedSource.Fingerprint, v => v.cmbFingerprint2.SelectedValue).DisposeWith(disposables); | ||||
|  |  | |||
|  | @ -928,10 +928,12 @@ | |||
|                         <RowDefinition Height="Auto" /> | ||||
|                         <RowDefinition Height="Auto" /> | ||||
|                         <RowDefinition Height="Auto" /> | ||||
|                         <RowDefinition Height="Auto" /> | ||||
|                     </Grid.RowDefinitions> | ||||
|                     <Grid.ColumnDefinitions> | ||||
|                         <ColumnDefinition Width="180" /> | ||||
|                         <ColumnDefinition Width="Auto" /> | ||||
|                         <ColumnDefinition Width="Auto" /> | ||||
|                     </Grid.ColumnDefinitions> | ||||
| 
 | ||||
|                     <TextBlock | ||||
|  | @ -995,6 +997,29 @@ | |||
|                         Width="200" | ||||
|                         Margin="{StaticResource Margin4}" | ||||
|                         Style="{StaticResource DefComboBox}" /> | ||||
| 
 | ||||
|                     <TextBlock | ||||
|                         Grid.Row="5" | ||||
|                         Grid.Column="0" | ||||
|                         Margin="{StaticResource Margin4}" | ||||
|                         VerticalAlignment="Center" | ||||
|                         Style="{StaticResource ToolbarTextBlock}" | ||||
|                         Text="{x:Static resx:ResUI.TbCertSha256}" /> | ||||
|                     <TextBox | ||||
|                         x:Name="txtCertSha256" | ||||
|                         Grid.Row="5" | ||||
|                         Grid.Column="1" | ||||
|                         Width="400" | ||||
|                         Margin="{StaticResource Margin4}" | ||||
|                         HorizontalAlignment="Left" | ||||
|                         Style="{StaticResource DefTextBox}" /> | ||||
|                     <TextBlock | ||||
|                         Grid.Row="5" | ||||
|                         Grid.Column="2" | ||||
|                         Margin="{StaticResource Margin4}" | ||||
|                         VerticalAlignment="Center" | ||||
|                         Style="{StaticResource ToolbarTextBlock}" | ||||
|                         Text="{x:Static resx:ResUI.TbCertSha256Tips}" /> | ||||
|                 </Grid> | ||||
|                 <Grid | ||||
|                     x:Name="gridRealityMore" | ||||
|  |  | |||
|  | @ -183,6 +183,7 @@ public partial class AddServerWindow | |||
|             this.Bind(ViewModel, vm => vm.SelectedSource.AllowInsecure, v => v.cmbAllowInsecure.Text).DisposeWith(disposables); | ||||
|             this.Bind(ViewModel, vm => vm.SelectedSource.Fingerprint, v => v.cmbFingerprint.Text).DisposeWith(disposables); | ||||
|             this.Bind(ViewModel, vm => vm.SelectedSource.Alpn, v => v.cmbAlpn.Text).DisposeWith(disposables); | ||||
|             this.Bind(ViewModel, vm => vm.SelectedSource.CertSha256, v => v.txtCertSha256.Text).DisposeWith(disposables); | ||||
|             //reality | ||||
|             this.Bind(ViewModel, vm => vm.SelectedSource.Sni, v => v.txtSNI2.Text).DisposeWith(disposables); | ||||
|             this.Bind(ViewModel, vm => vm.SelectedSource.Fingerprint, v => v.cmbFingerprint2.Text).DisposeWith(disposables); | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 DHR60
						DHR60