- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我需要在 中检测WinRT 应用程序在哪些协议(protocol)上有互联网访问(IPv4/IPv6/两者)。我有以下代码来确定支持的协议(protocol):
enum IpVersion
{
None = 0,
IPv4 = 1,
IPv6 = 2,
IPv46 = 3
}
IpVersion GetIpVersion(ConnectionProfile profile)
{
var result = IpVersion.None;
if (profile != null && profile.NetworkAdapter != null)
{
var hostnames = NetworkInformation.GetHostNames().Where(h => h.IPInformation != null &&
h.IPInformation.NetworkAdapter != null &&
h.IPInformation.NetworkAdapter.NetworkAdapterId == profile.NetworkAdapter.NetworkAdapterId);
foreach (var hostname in hostnames)
{
if (hostname.Type == HostNameType.Ipv4)
{
result |= IpVersion.IPv4;
}
else if (hostname.Type == HostNameType.Ipv6)
{
result |= IpVersion.IPv6;
}
}
}
return result;
}
GetIpVersion(NetworkInformation.GetInternetConnectionProfile());
Wi-Fi status
中找到。 window :
NetworkConnectivityLevel.InternetAccess
,但它不包含有关存在连接的协议(protocol)的信息。
bool internetAccess = connectionProfile.GetNetworkConnectivityLevel() == NetworkConnectivityLevel.InternetAccess
最佳答案
在您的代码中,ConnectionProfile
是什么?类型?没有 a good, minimal, complete code example 就很难理解这个问题并准确解释该代码的作用以及为什么它与您想要的不同。
也就是说,如果我正确理解了这个问题,您正在尝试确定您的 Internet 连接是否同时支持 IPv4 和 IPv6。如果是这样,那么我看不出有任何方法可以从 API 级别做到这一点。本地 PC 实际上可以安装 IPv4 协议(protocol),而无需连接到允许传输该协议(protocol)上的流量的网络。即使 LAN 支持该协议(protocol),互联网连接本身也可能只支持 IPv6。
同样的事情也适用于其他方式(即具有本地 IPv6 支持,但仅支持 Internet 上的 IPv4)。
在我看来,唯一可靠的方法与许多其他情况所需的方法相同:尝试一下,看看它是否有效。 IE。尝试通过所需的协议(protocol)版本连接到 Internet 上的远程端点;如果失败,则不支持。如果成功,则支持。
编辑:
感谢您更新问题。它仍然不是最好的代码示例,但它稍微改进了这个问题。
我仍然不是 100% 你需要做的事情,也不是我是否有对你最有用的方法。但这是一个简短的程序,我认为它可以满足您的需求:
XAML:
<Page x:Class="TestSO32781692NetworkProtocolConnectivity.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:TestSO32781692NetworkProtocolConnectivity"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
DataContext="{Binding RelativeSource={RelativeSource Mode=Self}}"
mc:Ignorable="d">
<StackPanel Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">
<StackPanel.Resources>
<Style TargetType="TextBlock">
<Setter Property="FontSize" Value="24"/>
</Style>
</StackPanel.Resources>
<StackPanel Orientation="Horizontal" Margin="10, 50, 10, 0">
<TextBlock Text="IpV4: "/>
<TextBlock Text="{Binding IpV4}"/>
</StackPanel>
<StackPanel Orientation="Horizontal" Margin="10, 10, 10, 0">
<TextBlock Text="IpV6: "/>
<TextBlock Text="{Binding IpV6}"/>
</StackPanel>
<Button Content="Check Network" Click="Button_Click"/>
<ListBox ItemsSource="{Binding Profiles}"/>
</StackPanel>
</Page>
using System;
using System.Collections.ObjectModel;
using System.Linq;
using Windows.Networking;
using Windows.Networking.Connectivity;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
// The Blank Page item template is documented at http://go.microsoft.com/fwlink/?LinkId=234238
namespace TestSO32781692NetworkProtocolConnectivity
{
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page
{
public static readonly DependencyProperty IpV4Property = DependencyProperty.Register(
"IpV4", typeof(bool), typeof(MainPage), new PropertyMetadata(false));
public static readonly DependencyProperty IpV6Property = DependencyProperty.Register(
"IpV6", typeof(bool), typeof(MainPage), new PropertyMetadata(false));
public static readonly DependencyProperty ProfilesProperty = DependencyProperty.Register(
"Profiles", typeof(ObservableCollection<string>), typeof(MainPage), new PropertyMetadata(new ObservableCollection<string>()));
public bool IpV4
{
get { return (bool)GetValue(IpV4Property); }
set { SetValue(IpV4Property, value); }
}
public bool IpV6
{
get { return (bool)GetValue(IpV6Property); }
set { SetValue(IpV6Property, value); }
}
public ObservableCollection<string> Profiles
{
get { return (ObservableCollection<string>)GetValue(ProfilesProperty); }
set { SetValue(ProfilesProperty, value); }
}
public MainPage()
{
this.InitializeComponent();
}
private async void Button_Click(object sender, RoutedEventArgs e)
{
bool ipV4 = false, ipV6 = false;
ConnectionProfile internetProfile = NetworkInformation.GetInternetConnectionProfile();
Profiles.Clear();
Profiles.Add("Internet profile: " + internetProfile.ProfileName);
var hostNames = NetworkInformation.GetHostNames()
.Where(h => h.IPInformation != null &&
h.IPInformation.NetworkAdapter != null);
foreach (HostName hostName in hostNames)
{
ConnectionProfile hostConnectedProfile =
await hostName.IPInformation.NetworkAdapter.GetConnectedProfileAsync();
if (hostConnectedProfile.NetworkAdapter.NetworkAdapterId == internetProfile.NetworkAdapter.NetworkAdapterId)
{
Profiles.Add("Host adapter: " + hostName.DisplayName);
if (hostName.Type == HostNameType.Ipv4)
{
ipV4 = true;
}
else if (hostName.Type == HostNameType.Ipv6)
{
ipV6 = true;
}
}
}
IpV4 = ipV4;
IpV6 = ipV6;
}
}
}
NetworkInformation.GetConnectionProfiles()
方法。尽管这似乎是扩展您当前方法的有希望的方法,尽管
the documentation实际上 promise “调用 GetConnectionProfiles 方法会检索设备上当前建立的所有连接的配置文件,
包括 Internet 连接。”[强调我的],事实证明并非如此。特别是,至少在我安装并启用了 Hyper-V 的机器上(对于那些进行 WinRT/Windows Phone 开发的人来说这是一个常见的场景:)),
ConnectionProfile
NetworkInformation.GetInternetConnectionProfile()
返回的对象实际上不包含在
NetworkInformation.GetConnectionProfiles()
返回的配置文件集合中.
ConnectionProfile
对应的主机名对象。由
GetInternetConnectionProfile()
返回.
GetNetworkConnectivityLevel()
的明显问题外没有提供实际使用的协议(protocol),我发现该方法甚至没有返回至少直观地被认为是正确的信息。
FindConnectionProfilesAsync(new ConnectionProfileFilter { IsConnected = true })
确实返回与我用来连接到 Internet 的连接(例如无线网络)相对应的配置文件,但是当我调用
GetNetworkConnectivityLevel()
时在该配置文件上,它返回
LocalAccess
只要。我猜这与我上面提到的安装 Hyper-V 的问题有关。
ConnectionProfile
来解决。由
GetConnectedProfileAsync()
返回
NetworkAdapter
的方法
FindConnectionProfilesAsync()
返回的每个连接配置文件的到
GetInternetConnectionProfile()
返回的配置文件.对顶级配置文件的网络适配器的配置文件进行间接处理似乎会产生预期的 Internet 连接配置文件。
关于c# - 检测当前连接是否同时支持 IPv4 和 IPv6,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32781692/
目前部署在 Kubernetes 中的服务,通过 Calico BGP 将 Service 与集群外网络打通,并在外部的 nginx 中配置 Service 地址对外进行服务暴露。经过一段时间的观察
如发现here , 有一种新的 kube 服务是 IPVS 并且有很多负载均衡算法。 唯一的问题是我没有找到指定这些算法的位置。 我的理解: rr:循环法->循环调用后端pod lc:最少连接-> 将
我想尝试这种新的代理模式以及它为我们的一些应用程序提供的各种调度程序。到目前为止,我一直无法找到更改默认模式的方法 iptables至 ipvs在 GKE 节点上。 每个人都说通过--proxy-mo
我想在现有集群中为 IPVS 启用 Kube-proxy 模式。目前,它在 IPtables 上运行。如何在不影响现有工作负载的情况下将其更改为 IPVS? 我已经安装了所有必需的模块来启用它。另外,
我正在开发的应用程序作为 Kubernetes 集群中的部署运行。为此部署创建的 Pod 分布在集群中的各个节点上。我们的应用程序一次只能处理一个 TCP 连接,并且会拒绝进一步的连接。目前,我们使用
我是一名优秀的程序员,十分优秀!