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

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

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

    如题,很多网站的安全机制,为了判断用户最后登陆所在地,都会记录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
    kslr
        1
    kslr  
       2015-04-11 18:01:22 +08:00 via Android
    谷歌搜索MySQL IPV6我记得第一个就是大牛的回答
    lincanbin
        2
    lincanbin  
    OP
       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
        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
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3704 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 33ms · UTC 00:50 · PVG 08:50 · LAX 16:50 · JFK 19:50
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.