首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
宝塔
V2EX  ›  问与答

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

  •  
  •   lincanbin · 2015-04-11 15:42:44 +08:00 · 1639 次点击
    这是一个创建于 1683 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

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

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

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

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

    3 回复  |  直到 2015-05-05 01:18:13 +08:00
        1
    kslr   2015-04-11 18:01:22 +08:00 via Android
    谷歌搜索MySQL IPV6我记得第一个就是大牛的回答
        2
    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
        3
    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
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   1030 人在线   最高记录 5043   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 21ms · UTC 19:18 · PVG 03:18 · LAX 11:18 · JFK 14:18
    ♥ Do have faith in what you're doing.