zoukankan      html  css  js  c++  java
  • mysql 存取ip方法

    一,mysql的inet_aton:ip->num,inet_ntoa:number->ip.

    1,创建表

    CREATE TABLE iplog (
    ip int(10) unsigned DEFAULT NULL,
    name char(10) DEFAULT NULL
    )

    2,插入ip

    insert into iplog values(inet_aton('10.0.0.1'),'nwip');

    3,取ip

    select inet_ntoa(ip) from iplog ;

    select * from iplog where ip = inet_aton('10.0.0.1') ;

    二,php

    ip2long()

    log2ip()

    三,原创方法

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <title>第一php网提供的教程--PHP实现IP--数字互相转换</title>
    <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
    </head>
    <body>
    <?php
    /*
    * 作者:XXXX
    */
    //将IP转换为数字
    function ipton($ip)
    {
        $ip_arr=explode('.',$ip);//分隔ip段
        foreach ($ip_arr as $value)
        {
            $iphex=dechex($value);//将每段ip转换成16进制
            if(strlen($iphex)<2)//255的16进制表示是ff,所以每段ip的16进制长度不会超过2
            {
                $iphex='0'.$iphex;//如果转换后的16进制数长度小于2,在其前面加一个0
            //没有长度为2,且第一位是0的16进制表示,这是为了在将数字转换成ip时,好处理
            }
            $ipstr.=$iphex;//将四段IP的16进制数连接起来,得到一个16进制字符串,长度为8
        }
        return hexdec($ipstr);//将16进制字符串转换成10进制,得到ip的数字表示
    }
     
     
    //将数字转换为IP,进行上面函数的逆向过程
    function ntoip($n)
    {
        $iphex=dechex($n);//将10进制数字转换成16进制
        $len=strlen($iphex);//得到16进制字符串的长度
        if(strlen($iphex)<8)
        {
            $iphex='0'.$iphex;//如果长度小于8,在最前面加0
            $len=strlen($iphex); //重新得到16进制字符串的长度
        }
        //这是因为ipton函数得到的16进制字符串,如果第一位为0,在转换成数字后,是不会显示的
        //所以,如果长度小于8,肯定要把第一位的0加上去
        //为什么一定是第一位的0呢,因为在ipton函数中,后面各段加的'0'都在中间,转换成数字后,不会消失
        for($i=0,$j=0;$j<$len;$i=$i+1,$j=$j+2)
        {//循环截取16进制字符串,每次截取2个长度
            $ippart=substr($iphex,$j,2);//得到每段IP所对应的16进制数
            $fipart=substr($ippart,0,1);//截取16进制数的第一位
            if($fipart=='0')
            {//如果第一位为0,说明原数只有1位
                $ippart=substr($ippart,1,1);//将0截取掉
            }
            $ip[]=hexdec($ippart);//将每段16进制数转换成对应的10进制数,即IP各段的值
        }
        $ip = array_reverse($ip);
         
        return implode('.', $ip);//连接各段,返回原IP值
    }
    echo ipton('119.255.31.226');
    echo '<br>';
    $num='379374783';
    echo strlen($num).'<br/>';
    echo ntoip($num).'<br/>';
     
     
    echo 'trueipnum:'.ip2long('119.255.31.226').'<br/>';
    echo 'trueip:'.long2ip('3793747831');
    ?>
    </body>
    </html>
    我们用一个int(11)类型(范围-2147483648 - 2147483647)来保存把一个ip地址用ip2long处理得到的结果,
    例如ip是’202.105.77.179′,那么在32位机器上得到的结果是:-899068493,而在64位机器上却得到3395898803.然后把它写入数据库,由于超过int(11)的范围,因此64位机器上的结果被保存为int(11)的最大值:2147483647.于是在从数据库中取出的时候,便得到了错误的结果,会得到”127.255.255.255″这个ip地址.
    可以用mysql的函数:INET_ATON和INET_NTOA来处理ip地址;或者把保存ip地址的字段改为bigint类型,这样在64位机器上虽然保存的是3395898803,使用long2ip函数仍能得到正确的结果.
    感谢原创作者
  • 相关阅读:
    使用Python的Mock库进行PySpark单元测试
    库龄报表的相关知识
    使用PlanViz进行ABAP CDS性能分析
    Spark SQL中列转行(UNPIVOT)的两种方法
    Spark中的一些概念
    使用Visual Studio Code进行ABAP开发
    2019年的几个目标
    Dom--样式操作
    Dom选择器--内容文本操作
    Javascript面向
  • 原文地址:https://www.cnblogs.com/Crius/p/6895305.html
Copyright © 2011-2022 走看看