使用IPAddress Java库与ColdFusion标准化IPv4和IPv6地址

使用IPAddress Java库与ColdFusion标准化IPv4和IPv6地址

💡 原文英文,约600词,阅读约需2分钟。
📝

内容提要

我们的Microsoft IIS服务器仅支持IPv4,IP地址记录为VARCHAR(15)。尽管云服务商支持IPv6,但我们通过WAF获取IPv6地址。由于SQL BIGINT限制,我们决定使用BINARY(16)存储IPv4和IPv6地址,并使用Java库IPAddress进行一致的日志格式化。

🎯

关键要点

  • 我们的Microsoft IIS服务器仅支持IPv4,IP地址记录为VARCHAR(15)。
  • 自2012年起,IPv6未在我们的网络上启用,因此未受到影响。
  • 通过云服务商获取的日志中包含IPv6地址,IPv6流量通过云WAF提供商代理。
  • IPv4地址来自CGI.REMOTE_ADDR,不应用于阻止或记录。
  • 需要从HTTP头中显式获取IPv6地址,并在数据库中存储为VARCHAR(45)。
  • 由于SQL BIGINT限制,决定使用BINARY(16)存储IPv4和IPv6地址。
  • 使用Java库IPAddress进行IP地址和子网的处理,提供一致的日志格式化。
  • IPAddress库被许多公司使用,提供多种IP相关功能。

延伸问答

为什么我们的Microsoft IIS服务器只支持IPv4?

因为服务器配置仅接受IPv4连接,并且IP地址记录为VARCHAR(15)。

如何在数据库中存储IPv4和IPv6地址?

决定使用BINARY(16)存储IPv4和IPv6地址,以避免SQL BIGINT的限制。

如何从HTTP头中获取IPv6地址?

需要显式从HTTP头中获取IPv6地址,使用getHttpRequestData(false)方法。

IPAddress Java库有什么功能?

IPAddress库用于处理IPv4和IPv6地址,提供多种IP相关功能,如一致的日志格式化。

为什么选择使用BINARY(16)而不是VARCHAR存储IP地址?

使用BINARY(16)可以提高索引和查找速度,同时避免VARCHAR的存储限制。

IPv6流量是如何通过云WAF提供商代理的?

IPv6流量通过云WAF提供商代理,IPv6地址可以通过Forwarded-For HTTP头访问。

➡️

继续阅读