当前位置:海洋目录网 » 站长资讯 » 教育考试 » 文章详细 订阅RssFeed

【mysql】ipv4地址转换为4字节整数

来源:本站原创 浏览:46次 时间:2022-12-08
有时需要记录ipv4地址到数据库,直接保存字符varchar(15)可能有些浪费,如果直接保存一个整数的话性价比会更好一些,ipv4有4段,每段取值范围都是0~255,使用1个字节就可以保存,如果转换为一个整数4个字节就可以搞定,注意mysql需使用无符号int。

注意在java中Integer是有符号的,最大值为2147483647,所以需要Long来盛放转换后的整数;位移运算优先级低于加法运算,位移处加了括号:

public static Long getIpNum(final String ip) {
   Long ipNum = 0L;
   final String[] ipStr = ip.trim().split("\\.");
   for (final String str : ipStr) {
       ipNum = (ipNum << 8) + Integer.parseInt(str);
   }
   return ipNum;
}
同时mysql也提供了相关函数,可以方便进行转换:
select INET_ATON('255.255.255.255');-- 4294967295
select INET_NTOA(4294967295);-- 255.255.255.255

本文代码出发点是考虑包括两个极端的情况,即0.0.0.0~255.255.255.255,所以代码中使用Long类型,Long类型占用8字节,而数据库支持无符号整型,4字节就可以保存。由整数转为ipv4地址可以直接使用mysql的函数,也可以在代码中使用右移操作取出每个字节所代表的的整数,然后拼接"."。


  推荐站点

  • At-lib分类目录At-lib分类目录

    At-lib网站分类目录汇集全国所有高质量网站,是中国权威的中文网站分类目录,给站长提供免费网址目录提交收录和推荐最新最全的优秀网站大全是名站导航之家

    www.at-lib.cn
  • 中国链接目录中国链接目录

    中国链接目录简称链接目录,是收录优秀网站和淘宝网店的网站分类目录,为您提供优质的网址导航服务,也是网店进行收录推广,站长免费推广网站、加快百度收录、增加友情链接和网站外链的平台。

    www.cnlink.org
  • 35目录网35目录网

    35目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向35目录推荐、提交优秀网站。

    www.35mulu.com
  • 就要爱网站目录就要爱网站目录

    就要爱网站目录,按主题和类别列出网站。所有提交的网站都经过人工审查,确保质量和无垃圾邮件的结果。

    www.912219.com
  • 伍佰目录伍佰目录

    伍佰网站目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向伍佰目录推荐、提交优秀网站。

    www.wbwb.net