飞翔无限fxwx.com广西经贸职业技术学院论坛

标题: [建站技术]IP转向技术------自动识别IP,并跳转到来访问者所在的城市 [打印本页]

作者: 月中水    时间: 2009-10-16 01:38
标题: [建站技术]IP转向技术------自动识别IP,并跳转到来访问者所在的城市
先去下一个最新的纯真IP数据库,然后按如下操作:( b6 j: ?! M: I/ ^3 [7 t
1.运行纯真QQIP数据库里带的ShowIP.exe,点解压,输入文件名,比如IP.txt,确定,就得到一个TXT文件。 + o: J2 l6 L' Z, ~$ s6 X
2.打开ACCESS,工具-自定义,命令选项卡,把导入选项拖动到上面的工具栏。
3 k/ ^* }' l' I* Q& ^3.建库,建一个表,四个字段 3 G/ m8 h3 u! b5 y7 J& g$ c
Startip      类型:文本 (相关城市的IP段信息)
$ `" g0 T7 S6 a, y% Y; i  LEndip      类型:文本 (相关城市的IP段信息)
( A: Z# d  c: _( V) SCountry      类型:文本 (相关城市名称)
+ x7 h9 `! N. R7 A7 C( z2 HReUrl      类型:文本 (你想要跳转的城市路径如:北京 http://bj.abc.com)  D7 }' G  Q2 Y* D0 ~
4.点导入按钮,文件类型选文本文件,找到刚才导出的IP.txt文件,导入到刚才建的表里~
' m9 A' l, M( P运算将真实IP转换为数字,比如北京的IP段是 : 1.1.0.0 -- 1.1.0.255 ! @/ b( u) Q/ z- M. `* Z
Startip:      1*256*256*256+1*256*256+0*256+0 = 16842752 (这个数字才是最终要放到数据库里)
1 u& f" b) \* E+ V9 S) d- LEndip:      1*256*256*256+1*256*256+0*256+255 = 16843007 (这个数字才是最终要放到数据库里的)
3 l, g: E. |6 x/ Z6 Q: v9 s2 n可用程序批量处理,如果没时间(像我一样)你就直接去下个动网(好像风四也带了)的IP库,它是已经处理好了的,下面是程序部分:
# j" v7 r) t& xuser_ip = Request.ServerVariables("REMOTE_ADDR")      '取得访问者IP
3 D4 Z% e) g3 z4 {& ~userip_ary=split(user_ip,".")
& t" ~6 l: @- p. N& jtmp_userip=userip_ary(0)*256*256*256+userip_ary(1)*256*256+userip_ary(2)*256+userip_ary(3)    ' 按规定转换IP为数字! S2 h1 u0 P0 E) ?
‘从数据库找出用户IP属于的城市4 m& ~: f/ b% M+ @8 D) J
set rs=Server.CreateObject("ADODB.Recordset")- c) Q, s9 v: h. O
sql="select * from ip where Startip<="&tmp_userip&" and    Endip>="&tmp_userip            
6 ?! g/ z- t! srs.open sql,conn,1,12 c/ x! ]1 P4 X  D0 p' F7 r1 e
if rs.eof then
: c7 Z0 A% M5 g; Iresponse.redirect "index.asp"        ’如果没有该城市或是IP无法识别则转到首页,也可以指定页面. f7 S( L3 M5 |8 {  {+ w
else
* e4 k3 M  {6 I" k) a8 N( xresponse.redirect rs("ReUrl")                  ’如果有转到指定页面
# O" n  t: a, p, h+ wend if
& }6 j/ b& I4 p$ |# irs.close7 T+ w1 ?( o& M0 h6 M% J
set rs=nothing
- N! \2 S( J5 G3 c: E* I将上面的程序放到你的虚拟主机默认访问首页里!或是其它的页面里(当然你同样要在虚拟主机控制面板里设置默认首先访问的是这个文件)




欢迎光临 飞翔无限fxwx.com广西经贸职业技术学院论坛 (http://www.gxjmbbs.com/) Powered by Discuz! X3.2