您的位置:首页 > 编程语言 > ASP

通过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;

                }

                

        }
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  C# asp.net