1

我正在创建一个 IP 地址类包装器,并且我想根据RFC 5735 Section 4 - Special Use IPv4 Addresses区分地址类型。

我想要

  • 能够测试地址是否在其中一个块内。
  • 展开一个块,所以我在返回时得到一个 IPAddress 对象数组。

如果有人可以通过小示例代码帮助我,或者将我指向现有代码,我将不胜感激。可悲的是,我发现我的大脑无法理解这个主题的复杂性,这就是我特别要求示例代码的原因。我知道要求这样的源代码是不礼貌的,我很抱歉。

4

1 回答 1

0

在提出统一的 IP 地址表示时,重要的是要认识到 IPv4 地址占用 4 个字节,而 IPv6 地址需要 16 个字节。一个简单的包装器实现将使用联合加枚举鉴别器来指示地址类型。幸运的是,这不是必需的,因为在IPv6 地址中存在 IPv4 地址的明确表示。牢记这一点,您的 IP 地址包装类可能如下所示:

class address
{
  /// Top 96 bits of v4-mapped-addr.
  static std::array<uint8_t, 12> const v4_mapped_prefix =
    {{ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xff, 0xff }};

public:
  address() = default;

  bool is_v4() const
  {
    return std::memcmp(&bytes_, &v4_mapped_prefix, 12) == 0;
  }

private:
  std::array<uint8_t, 16> bytes_;
};

现在要检查您是否有某一类地址,您可以随意添加成员函数。以下是环回、广播和多播的示例:

bool is_loopback() const
{
  if (is_v4())
    return bytes_[12] == 127;
  else
    return ((bytes_[0] == 0) && (bytes_[1] == 0) &&
            (bytes_[2] == 0) && (bytes_[3] == 0) &&
            (bytes_[4] == 0) && (bytes_[5] == 0) &&
            (bytes_[6] == 0) && (bytes_[7] == 0) &&
            (bytes_[8] == 0) && (bytes_[9] == 0) &&
            (bytes_[10] == 0) && (bytes_[11] == 0) &&
            (bytes_[12] == 0) && (bytes_[13] == 0) &&
            (bytes_[14] == 0) && (bytes_[15] == 1));
}

bool is_broadcast() const
{
  return is_v4() &&
    bytes_[12] == 0xff && bytes_[13] == 0xff &&
    bytes_[14] == 0xff && bytes_[15] == 0xff;
}

bool is_multicast() const
{
  return is_v4() ? bytes_[12] == 224 : bytes_[0] == 0xff;
}
于 2013-07-04T10:00:19.130 回答