作者in2 (海带呀海带~~)
看板IPv6
标题Re: [心得]写IPv6相容网页要注意IP长度问题
时间Thu Feb 24 10:12:49 2011
※ 引述《SmallBeeWayn (喵喵叫的蜜蜂猫)》之铭言:
: 最近登入一个之前写的旧网站
: 怎样都登不进去,一直在研究程式码哪里有问题了
: 结果後来发现,因为我有纪录登入IP,是在MySQL中一个varchar(15)的纪录
: 拿来记录IPv4("255.255.255.255")是刚好
: 可是IPv6最长长度可以到39byte
: ("ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff")
: 从而导致登入失败...
: 记录一下提醒给其他将网站转往IPv6的人...
题外话,
我以为一般都是用 ip2long() / long2ip() 这类的把 ipv4
转成 unsigned 32bit integer, 而不是用 string 存 15 bytes.
也有人改了个 ipv6 的版本,
http://thesocialexpo.com/?a=SUBS_Blog_Display&id=12981930190593528
只不过有个问题是这样子会生出一个 unsigned 128bit integer,
比 mysql 最大的 BIGINT (64bit) 还长一倍,
不知道是要怎麽存比较好呢 orz
--
▂▅▇▇▅ ╚╩╯╭○ ╔═══╗ ▃ ◢◢
▊ /
╔═╗╬╦ ╠═══╣╔╦ ╔╦╗╠══╣ ◢ ▃ ██
▎ ◤◢█◤ ╚╦╝║║ ╚═══╝╯/╗╔╬╗╯╭═╣ ◥◤▌◢◢◢
▌ ▎◣ ◢▎ ║║║║║ ══╦═╯/ ║╠╬╣╔╬═╗ ◢ ◣
◣ ╯╝╯╯╚ ╯═╩╩╯ ║║╚╬╝╚╬═○ _ '_ ' _
◢█\ ¯◤ ╚╝╰╯╯╰╯╰╯ ◥ ▼ \◤
--
※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 210.242.246.248
1F:推 pichubaby:我的话是留48bytes的字元 02/24 10:34
2F:→ pichubaby:如果真的要转成数字进去的话 可以考虑把网路ID 02/24 10:34
3F:→ pichubaby:(前64)和HOST ID(後64)分开来放进去 02/24 10:35
4F:→ in2:咦, 也是可以~ 02/24 10:36
5F:推 SmallBeeWayn:String 15Byte可读性比较高 02/24 12:25
6F:→ SmallBeeWayn:前64後64有实作吗?感觉不会配这麽大耶... 02/24 12:27
7F:推 pichubaby:楼上在讲v4还v6? 02/25 13:36
8F:→ in2:省 storage 应该比较重要, 要读的情况比较少, 所以需要时再转 02/25 15:27