手机
当前位置:查字典教程网 >编程开发 >Access数据库 >根据IP跳转到用户所在城市的实现步骤
根据IP跳转到用户所在城市的实现步骤
摘要:先去下一个最新的纯真IP数据库,然后按如下操作:1.运行纯真QQIP数据库里带的ShowIP.exe,点解压,输入文件名,比如IP.txt,...

先去下一个最新的纯真IP数据库,然后按如下操作:

1.运行纯真QQIP数据库里带的ShowIP.exe,点解压,输入文件名,比如IP.txt,确定,就得到一个TXT文件。

2.打开ACCESS,工具-自定义,命令选项卡,把导入选项拖动到上面的工具栏。

3.建库,建一个表,四个字段

Startip 类型:文本 (相关城市的IP段信息)

Endip 类型:文本 (相关城市的IP段信息)

Country 类型:文本 (相关城市名称)

ReUrl 类型:文本 (你想要跳转的城市路径如:北京 http://bj.abc.com)

4.点导入按钮,文件类型选文本文件,找到刚才导出的IP.txt文件,导入到刚才建的表里~

运算将真实IP转换为数字,比如北京的IP段是 : 1.1.0.0 -- 1.1.0.255

Startip: 1*256*256*256+1*256*256+0*256+0 = 16842752 (这个数字才是最终要放到数据库里)

Endip: 1*256*256*256+1*256*256+0*256+255 = 16843007 (这个数字才是最终要放到数据库里的)

可用程序批量处理,如果不会,而且没时间(像我一样)你就直接去下个动网的IP库,它是已经处理好了的,下面是程序部分:

user_ip = Request.ServerVariables("REMOTE_ADDR") ''取得访问者IP

userip_ary=split(user_ip,".")

tmp_userip=userip_ary(0)*256*256*256+userip_ary(1)*256*256+userip_ary(2)*256+userip_ary(3) '' 按规定转换IP为数字

‘从数据库找出用户IP属于的城市

set rs=Server.CreateObject("ADODB.Recordset")

sql="select * from ip where Startip<="&tmp_userip&" and Endip>="&tmp_userip

rs.open sql,conn,1,1

if rs.eof then

response.redirect "index.asp" '如果没有该城市或是IP无法识别则转到首页,也可以指定页面

else

response.redirect rs("ReUrl") '如果有转到指定页面

end if

rs.close

set rs=nothing

将上面的程序放到你的虚拟主机默认访问首页里!或是其它的页面里(当然你同样要在虚拟主机控制面板里设置默认首先访问的是这个文件) OK

【根据IP跳转到用户所在城市的实现步骤】相关文章:

Access使用宏控制程序 4.常用的宏操作

Access字符串处理函数整理

Access使用宏控制程序之一个宏的实例检验口令

获取ACCESS2000数据库中所有表的名称

Access 2000建立一个空的数据库

使用ACCESS时最容易忽略的工作

Microsoft Access 数据库常规规格

Access随机显示记录解决方案

access判断表是否存在语句写法

Access使用宏控制程序--1.5.一个宏的实例——检验口令

精品推荐
分类导航