日期:2014-05-16 浏览次数:20802 次
“IP地址的长度为32位,分为4段,每段8位,用十进制数字表示,每段数字范围为0~255,段与段之间用句点隔开。”
由此我们了解到,IP地址实际上是一个32位正整数,在C#中可以使用uint类型来表示,但SQLServer数据库里好像没有对应的类型;转而使用数据库支持的int类型的话,则会出现溢出的情况;因此我们做出妥协:使用long(bigint)类型。
TIP:
int取值范围:-2,147,483,648 到 2,147,483,647
uint取值范围:0 到 4,294,967,295
long取值范围:-9,223,372,036,854,775,808 到 9,223,372,036,854,775,807
那么如何将IP地址转为整数呢?我们看到IPAddress类中有一个“[否决的]”实例属性Address,这个属性的确可以返回一个long值,但是测试一下,得到的数据确实这样的:
“127.0.0.1” -> 16777343
“127.0.0.2” –> 33554559
的确该让它“否决”,这样的整数对我们来说毫无意义,我们是无法通过这样的方法比较传入的IP是否介于两个IP值之间的。
那么只有自己动手了,我们将通过IPAddress类的GetAddressBytes()实例方法获取IP的4个段的值,然后将它们组合为一个整数,下面将提供这个扩展方法:
/// <summary>
/// 将IP地址转为整数形式
/// </summary>