你们在记录用户 IP 时,数据库设计有考虑 IPv6 吗?

2015-04-11 15:42:44 +08:00
 lincanbin

如题,很多网站的安全机制,为了判断用户最后登陆所在地,都会记录IP,那么你们储存IP用的字段是int(10)吗?

例如说VPS是DigitalOcean之类的支持IPv6的国外服务商,而用户是中国教育网用户,这种情况下你会设置AAAA记录开启IPv6吗?

如果开了,那么你们对应的IP储存字段是长什么样的?

http://www.94cb.com/t/2449

我自己用的字符型字段储存。

2622 次点击
所在节点    问与答
3 条回复
kslr
2015-04-11 18:01:22 +08:00
谷歌搜索MySQL IPV6我记得第一个就是大牛的回答
lincanbin
2015-04-11 21:33:57 +08:00
@kslr http://stackoverflow.com/questions/420680/how-to-store-ipv6-compatible-address-in-a-relational-database
是这个吗?
Google里前面几个都是MySQL的文档,是用两个unsigned bigint
Septembers
2015-05-05 01:18:13 +08:00
@lincanbin 2*BIGINT比较好
1. 比较性能好
2. 做分析时取特定范围查询会比较方便
伪代码(IPv4):
-- 范围8.8.8.0 - 8.8.8.255
SELECT * FROM users WHERE
ip_before = 0
and ip_after >= 0x8080800
and ip_after <= 0x80808FF
伪代码(IPv6):
-- 范围2001:cdba:0000:0000:0000:0000:3257:9652 - 2001:cdba:0000:0000:0000:0000:3257:FFFF
SELECT * FROM users WHERE
ip_before = 0x2001CDBA00000000
and ip_after >= 0x0000000032579652
and ip_after <= 0x000000003257FFFF

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/183060

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX