通过Ip得到城市实现步骤

第一步,首先把数据导入到数据库,可用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)