6

我在 SQLSERVER 2008 数据库中将 IPV4 地址存储为 Binary(4)。所以,我在数据输入之前转换了值(并且由于公司的限制,我不能在数据库中创建函数,这不讨论了)。

public static byte[] IpToBin(string ip)
{
    return IPAddress.Parse(ip).GetAddressBytes();
}

public static string HexToIp(string ip)
{
    return new IPAddress(long.Parse(ip, NumberStyles.HexNumber)).ToString(); 
}

调用 IpToBin 后,生成的数据为(例如 0x59FC09F3)。当我调用 HexToIp 时,ip 可能由于小/大端转换而反转。

任何人都可以在没有 500 亿行代码的情况下提出一个体面的解决方案吗?

4

2 回答 2

6

我认为这里真正的问题是您将原始形式视为字符串;特别是因为它binary(4)byte[]. IpToBin很好,但HexToIp应该是:

public static IPAddress BinToIp(byte[] bin)
{
    return new IPAddress(bin);
}

然后:工作完成。但是使用您现有的HexToIp代码,您需要:

return new IPAddress(new byte[] {
    Convert.ToByte(ip.Substring(0,2), 16), Convert.ToByte(ip.Substring(2,2), 16),
    Convert.ToByte(ip.Substring(4,2), 16), Convert.ToByte(ip.Substring(6,2), 16)}
    ).ToString(); 
于 2013-01-24T10:55:34.283 回答
0
    public List<IPAddress> SubtractTwoIpAddresses(IPAddress a, IPAddress b, bool includeLeft = true, bool includeRight = true)
    {
        List<IPAddress> rv = new List<IPAddress>();
        int ipA = IPAddress.NetworkToHostOrder(BitConverter.ToInt32(IPAddress.Parse(a.ToString()).GetAddressBytes(), 0)),
            ipB = IPAddress.NetworkToHostOrder(BitConverter.ToInt32(IPAddress.Parse(b.ToString()).GetAddressBytes(), 0));
        if (includeLeft)
            rv.Add(new IPAddress(BitConverter.GetBytes(Math.Min(ipA, ipB)).Reverse().ToArray()));
        for (int i = 1; i < Math.Max(ipA, ipB) - Math.Min(ipA, ipB); i++)
            rv.Add(new IPAddress(BitConverter.GetBytes(Math.Min(ipA, ipB) + i).Reverse().ToArray()));
        if (includeRight)
            rv.Add(new IPAddress(BitConverter.GetBytes(Math.Max(ipA, ipB)).Reverse().ToArray()));
        return rv;
    }
于 2014-04-04T16:50:28.820 回答