通过Ip得到城市实现步骤
2013-10-10 14:37
691 查看
第一步,首先把数据导入到数据库,可用cmd命令执行。
1>.在网上下载ipinfodb_one_table_full.sql文件,然后执行cmd命令:
osql -S . -U sunny -P sunny -d IPDB -i ip_group_city.sql
(注:由于文件很大,不能一次性执行,所以需要分成很多小份来操作,osql ? 可查看相关的命令,这里用到连接数据库的服务,用户名,密码,数据库,文件。文件存放路径:C:\DB\IPDB--SQL)
第二步,使用vs展现一个页面,在后台写方法
需要一个文本框输入IP,一个按钮查询,和显示相关城市信息的lable。为了方便其他地方调用,把所有操作代码封装在方法里。实现思路:方法是bool类型的,需要返回值,有两个参数:接收IP,输出城市。计算IP的方式:
ipnum = 16777216*w + 65536*x + 256*y + z 。IP地址格式一般如:210.75.17.50,所以要使用 Split 分割,把IP地址拆分成4个数据并参与计算。把涉及到的5个城市用一个数组存储,然后判断是否和数据库得到的城市相等,从而知道IP地址所在的城市是否在5个城市内,是则返回true,否则返回false.具体方法如下:
public bool IsExitCityByIP(string ip,out string city)
{
string[] ips = ip.Split('.');
double ipNum = Convert.ToDouble(ips[0]) * 16777216 + Convert.ToDouble(ips[1]) * 65536 + Convert.ToDouble(ips[2]) * 256 + Convert.ToDouble(ips[3]);
string[] cityName = { "Shenzhen", "Shanghai", "Guangzhou", "Hong Kong" };
IPGroupCity c = GetAddressByIPNum(ipNum);
city = c.City.ToString();
if (city != null)计算
{
for (int i = 0; i < cityName.Length; i++)
{
if (cityName[i].Equals(city))
{
lblAddress.Text = "您查询的IP:" + txtIP.Text + "<br>IP地址位置:" + c.Country_name + "--" + city;
return true;
}
else if (cityName[i].Equals(c.Country_name))
{
lblAddress.Text = "您查询的IP:" + txtIP.Text + "<br>IP地址位置:" + c.Country_name + "--" + city;
return true;
}
}
lblAddress.Text = "您查询的IP:" + txtIP.Text + "<br>IP地址位置:" + c.Country_name + "--" + city + "! 您没有在OpenRice所涉足的五个城市内 ";
return false;
}
else
{
ScriptManager.RegisterStartupScript(this, this.GetType(), "", "alert('您输入的IP没有相关记录')", true);
return false;
}
}
1>.在网上下载ipinfodb_one_table_full.sql文件,然后执行cmd命令:
osql -S . -U sunny -P sunny -d IPDB -i ip_group_city.sql
(注:由于文件很大,不能一次性执行,所以需要分成很多小份来操作,osql ? 可查看相关的命令,这里用到连接数据库的服务,用户名,密码,数据库,文件。文件存放路径:C:\DB\IPDB--SQL)
第二步,使用vs展现一个页面,在后台写方法
需要一个文本框输入IP,一个按钮查询,和显示相关城市信息的lable。为了方便其他地方调用,把所有操作代码封装在方法里。实现思路:方法是bool类型的,需要返回值,有两个参数:接收IP,输出城市。计算IP的方式:
ipnum = 16777216*w + 65536*x + 256*y + z 。IP地址格式一般如:210.75.17.50,所以要使用 Split 分割,把IP地址拆分成4个数据并参与计算。把涉及到的5个城市用一个数组存储,然后判断是否和数据库得到的城市相等,从而知道IP地址所在的城市是否在5个城市内,是则返回true,否则返回false.具体方法如下:
public bool IsExitCityByIP(string ip,out string city)
{
string[] ips = ip.Split('.');
double ipNum = Convert.ToDouble(ips[0]) * 16777216 + Convert.ToDouble(ips[1]) * 65536 + Convert.ToDouble(ips[2]) * 256 + Convert.ToDouble(ips[3]);
string[] cityName = { "Shenzhen", "Shanghai", "Guangzhou", "Hong Kong" };
IPGroupCity c = GetAddressByIPNum(ipNum);
city = c.City.ToString();
if (city != null)计算
{
for (int i = 0; i < cityName.Length; i++)
{
if (cityName[i].Equals(city))
{
lblAddress.Text = "您查询的IP:" + txtIP.Text + "<br>IP地址位置:" + c.Country_name + "--" + city;
return true;
}
else if (cityName[i].Equals(c.Country_name))
{
lblAddress.Text = "您查询的IP:" + txtIP.Text + "<br>IP地址位置:" + c.Country_name + "--" + city;
return true;
}
}
lblAddress.Text = "您查询的IP:" + txtIP.Text + "<br>IP地址位置:" + c.Country_name + "--" + city + "! 您没有在OpenRice所涉足的五个城市内 ";
return false;
}
else
{
ScriptManager.RegisterStartupScript(this, this.GetType(), "", "alert('您输入的IP没有相关记录')", true);
return false;
}
}
相关文章推荐
- 根据IP(有代理的情况)定位城市以及通过nginx转发的tomcat如何得到用户真实的ip
- 根据IP跳转到用户所在城市的实现步骤
- 前端通过获取广域网ip然后根据ip得到所在的城市
- Rails 如何实现通过登录IP确定城市功能
- Linux下C实现通过域名得到IP
- 把ip转换成对应的城市名的实现方法
- 如何通过terminal得到AWS EC2 instance的ip
- js实现PC端根据IP定位当前城市地理位置
- 通过外部网站返回得到内网外部IP
- 通过注册表得到IP相关信息
- 如何通过一个IP和子网掩码得到网络地址和广播地址
- 通过得到客户端IP,和从数据库中得到IP位数
- [VB代码]通过hostname得到主机IP
- linux下c实现得到给定网段的所有IP
- 如何通过JS得到访问者的IP
- Tengine笔记2:通过IP、域名、端口实现虚拟主机
- 通过外部网站返回得到内网外部IP
- java 根据 ip 得到 城市
- 通过Nginx反向代理实现IP访问分流的示例代码
- 百度地图---通过ip定位获取当前城市