0
我想知道當我的應用程序在SQL Server本地運行。這是備份和恢復所必需的。如何通過連接獲取SQL Server的IP地址或DNS名稱?
我想知道當我的應用程序在SQL Server本地運行。這是備份和恢復所必需的。如何通過連接獲取SQL Server的IP地址或DNS名稱?
我從Connection.DataSource獲取服務器的IP地址(DNS名稱)。然後我檢查一下,是否有此名稱的列表:
localNames = new List<string>()
{
".", "localhost", "(local)", "127.0.0.1", Environment.MachineName.ToLower(),
};
localNames.AddRange(GetIP().Select(a=>a.ToString()));
if (localNames.Contains(GetServer(connection.DataSource).ToLower()))
{
//do something
}
方法:
IEnumerable<IPAddress> GetIP()
{
foreach (var ip in Dns.GetHostEntry(Dns.GetHostName()).AddressList.Where(ip => ip.AddressFamily == AddressFamily.InterNetwork))
{
yield return ip;
}
}
string GetServer(string dataSource)
{
return dataSource.Split('\\').First().Split(',').First().Split(':').Last();
}
數據源可以是: