您当前的位置: 首页 > 网站编程 > PHP教程 > 将IP地址转换为整型数字的PHP方法、Asp方法和MsSQL方法、MySQL方

将IP地址转换为整型数字的PHP方法、Asp方法和MsSQL方法、MySQL方

作者:不详 来源:网络 发布时间: 2014-08-15 09:02 点击:
首先我们要先了解一下IP地址转换为整型(严格来说应该说是长整型)的原理~ 【转换原理】: 假设IP为:w.x.y.z,则IP地址转为整型数字的计算公式为:intIP = 256*256*256*w + 256*256*x + 256*y + z 【PHP的互转】: PHP的转换方式比较简单,它内置了两个函数 int ip2long

将IP地址转换为整型数字的PHP方法、Asp方法和MsSQL方法、MySQL方

  首先我们要先了解一下IP地址转换为整型(严格来说应该说是长整型)的原理~

  【转换原理】:假设IP为:w.x.y.z,则IP地址转为整型数字的计算公式为:intIP = 256*256*256*w + 256*256*x + 256*y + z

  【PHP的互转】:PHP的转换方式比较简单,它内置了两个函数

  int ip2long ( string $ip_address )和 string long2ip ( string $proper_address )

  可以直接调用使用~

  【Asp的互转】:自定义函数如下,

  '.-----------------------------------------------------------.

  '| describtion: 将IP转换为int型数字                          |

  '|     Authors: abandonship(http://jb51.net)           |

  '~-----------------------------------------------------------~

  Function IP2Num(ByVal strIP)

     Dim nIP

     Dim nIndex

     Dim arrIP

     arrIP = Split(strIP, ".", 4)

     For nIndex = 0 To 3

         If Not nIndex = 3 Then

             arrIP(nIndex) = arrIP(nIndex) * (256 ^ (3 - nIndex))

         End If

         nIP = nIP + arrIP(nIndex)

     Next

     IP2Num = nIP

  End Function

  '.-----------------------------------------------------------.

  '| describtion: 将int型数字转换为IP                          |

  '|     Authors: abandonship(http://jb51.net)           |

  '~-----------------------------------------------------------~

  Function Num2IP(ByVal nIP)

     Dim strIP

     Dim nTemp

     Dim nIndex

     For nIndex = 3 To 0 Step -1

     nTemp = Int(nIP / (256 ^ nIndex))

     strIP = strIP & nTemp & "."

     nIP = nIP - (nTemp * (256 ^ nIndex))

     Next

     strIP = Left(strIP, Len(strIP) - 1)

     Num2IP = strIP

  End Function

  【MsSQL的互转】:自定义函数如下,

  
/***************************************************************

  * 将IP转换为int型数字                        |

  * Code CreateBy abandonship(http://jb51.net)       |

  **************************************************************/

  CREATE FUNCTION [dbo].[ipToInt]( 

  @strIp varchar(15) 

  )RETURNS bigint 

  AS 

  BEGIN 

  declare @nIp bigint 

  set @nIp = 0  

  select

    @nIp = @nIp + LEFT( @strIp, charindex('.',@strIp+'.')-1)*Id

  from( 

    select Id = cast(1*256*256*256 as bigint) 

    union all select 1*256*256 

    union all select 1*256 

    union all select 1

  ) as T

  return (@nIp)

  END

  /***************************************************************

  * 将int型数字转换为IP                        |

  * Code CreateBy abandonship(http://jb51.net)       |

  **************************************************************/

  CREATE FUNCTION [dbo].[intToIP](

  @nIp bigint 

  )RETURNS varchar(15) 

  As 

  BEGIN 

  declare @strIp varchar(15) 

  set @strIp = '' 

  select

    @strIp = @strIp +'.'+ cast(@nIp/ID as varchar), @nIp = @nIp%ID

  from( 

    select ID = cast(1*256*256*256 as bigint) 

    union all select 1*256*256 

    union all select 1*256 

    union all select 1

  ) as T 

  return(stuff(@strIp,1,1,'')) 

  END

  【MySQL的互转】:相对于MsSQL来说MySQL的转换方式比较简单,它和PHP一样也内置了两个函数

  IP转为整型: select INET_ATON (IP地址) 和 整型转为IP: select INET_NTOA ( IP的整型数值 )

  可以直接调用使用~
分享到:
本文"将IP地址转换为整型数字的PHP方法、Asp方法和MsSQL方法、MySQL方"由远航站长收集整理而来,仅供大家学习与参考使用。更多网站制作教程尽在远航站长站。
顶一下
(0)
0%
踩一下
(0)
0%
[点击 次] [返回上一页] [打印]
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 密码: 验证码:
关于本站 - 联系我们 - 网站声明 - 友情连接- 网站地图 - 站点地图 - 返回顶部
Copyright © 2007-2013 www.yhzhan.com(远航站长). All Rights Reserved .
远航站长:为中小站长提供最佳的学习与交流平台,提供网页制作与网站编程等各类网站制作教程.
官方QQ:445490277 网站群:26680406 网站备案号:豫ICP备07500620号-4