1 淘宝IP地址库的接口说明
在上一篇文章《WordPress使用淘宝IP地址库的API显示评论者的位置信息(一)》中,vfhky使用了新浪工具提供的这个IP接口显示博客评论者的位置信息。那么这篇文章就接着写在WordPress中使用淘宝IP地址库的API显示评论者的位置信息。这个功能的实现需要储备一些jQuery、json等基础知识,所以如果说上一篇是jQuery版本的新浪IP地址库的API应用,那么这篇文章就是jQuery版本的淘宝IP地址库的API应用。淘宝IP地址库的接口说明文档地址是:http://ip.taobao.com/instructions.php,大家可以去参考下。下面是在WP博客中如何利用淘宝IP地址库实现评论者位置详情的显示。
2.1 修改主题评论WEB结构(functis.php)
正如上一篇文章提到的,我们首先需要找到评论信息显示列表的那个文件(博主的是functions.php),在相应的位置加上如下代码。其作用是在jQuery获取IP信息之前,显示“正在查询……”的字样。代码中的waiting.gif是上面省略号的动态图片,这个看个人喜好来决定需不需要用;$ip代表从数据查询出来的评论者的IP数据。
<span class="vfhkyipquery" data-ip="' . $ip . '">正在查询<img src="' . get_bloginfo('template_url') . '/images/waiting.gif" alt="..." style="vertical-align:baseline;" /></span>
2.2 修改JS文件
找到主题文件目录下的一个js文件,然后添加以下代码(注意该js文件一定要是会在文章页面加载的哦!)最终的显示效果会类似于:中国江苏南京 电信。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29 | /************
*** @Function:jQuery获取淘宝IP地址库API返回的信息
*** @Author:vfhky http://vfhky.sinaapp.com 20130825
*** @param string GhpcyBpcy94db71979d35aBhIGV4YW1wbGUd7ebf4317e0de919 由Jquery传送过来的IP地址
*** @return string "<span class=ipinfo>中国江苏南京 电信</span>"
************/
$(document).ready(function(c){
function d(){
c(".vfhkyipquery").each(function(){
var a=c.trim(c(this).attr("data-ip")),i=c(this),h="";
var b="http://vfhky.sinaapp.com/MTBkN2ViZjQzMTdlMGR.php?GhpcyBpcy94db71979d35aBhIGV4YW1wbGUd7ebf4317e0de919=";
b+=a;
c.getJSON(b,function(e){
h+=e.data.country;
h+=e.data.region;
h+=e.data.city;
h+=" ";
h+=e.data.isp;
h=h.replace(/省/g,'');
h=h.replace(/市/g,'');
i.replaceWith("<span class=ipinfo>"+h+"</span>")
})
})
}
c(function(){
d();
})
});
|
2.3 新建一个任意命名的PHP文件
新建一个平PHP文件,任意命名(但尽量复杂点),例如MTBkN2ViZjQzMTdlMGR.php。然后把这个文件放在博客的FTP根目录或者主题目录下面,只要记录这个文件的路径就行了,因为待会在jQuery中会用到它。这个PHP文件的主要功能是接收由Jquery文件传送过来的IP参数,然后拼接成一个淘宝IP库的API标准请求URL并读取接口返回的所有数据信息。具体代码如下所示:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47 | <?php
/*********
*** @Filename:MTBkN2ViZjQzMTdlMGR.php
*** @Function:淘宝API的标准get请求报文
*** @Author:vfhky http://vfhky.sinaapp.com 20130825
*** @param string GhpcyBpcy94db71979d35aBhIGV4YW1wbGUd7ebf4317e0de919 其值代表由Jquery传送过来的IP地址
*** @return string $data 淘宝API返回的数据(包括Json格式的IP地址信息详情)
**********/
//prevent load this file directly
if (empty($_SERVER['HTTP_REFERER']) || strpos($_SERVER['HTTP_REFERER'], $_SERVER['HTTP_HOST']) === false) {
exit;
}
$c572bd935510d7ebf4317e0de91994db71979d35a = trim($_GET['GhpcyBpcy94db71979d35aBhIGV4YW1wbGUd7ebf4317e0de919']);
//check if the ip address is ipv4
if(!filter_var($c572bd935510d7ebf4317e0de91994db71979d35a, FILTER_VALIDATE_IP, FILTER_FLAG_IPV4)) {
exit;
}
//if the ip address is ipv4 then
$ip=explode(".",$c572bd935510d7ebf4317e0de91994db71979d35a);
//check if the $ip is legel
for($i=0;$i<count($ip);$i++)
{
if($ip[$i]>255){
exit;
}
}
//prevent the sql-injection(From:http://vfhky.sinaapp.com/web/php/20.html)
$c572bd935510d7ebf4317e0de91994db71979d35a = trim($c572bd935510d7ebf4317e0de91994db71979d35a);
$c572bd935510d7ebf4317e0de91994db71979d35a = strip_tags($c572bd935510d7ebf4317e0de91994db71979d35a,"");
$c572bd935510d7ebf4317e0de91994db71979d35a = str_replace("\n", "", str_replace(" ", "", $c572bd935510d7ebf4317e0de91994db71979d35a));
$c572bd935510d7ebf4317e0de91994db71979d35a = str_replace("\t","",$c572bd935510d7ebf4317e0de91994db71979d35a);
$c572bd935510d7ebf4317e0de91994db71979d35a = str_replace("\r\n","",$c572bd935510d7ebf4317e0de91994db71979d35a);
$c572bd935510d7ebf4317e0de91994db71979d35a = str_replace("\r","",$c572bd935510d7ebf4317e0de91994db71979d35a);
//request for TAOBAO API to get data-infomation
$url572bd935510d7ebf4317e0de91994db71979d35a = "http://ip.taobao.com/service/getIpInfo.php?ip=".$c572bd935510d7ebf4317e0de91994db71979d35a;
$data = file_get_contents($url572bd935510d7ebf4317e0de91994db71979d35a);
//output the return data from TAOBAO API including json-data(Format:http://ip.taobao.com/instructions.php)
echo $data;
?>
|
3 后记
三步就搞定了,也不是很难吧!那么这篇《WordPress使用淘宝IP地址库的API显示评论者的位置信息(二)》就算是jQuery版本的淘宝IP地址库的API调用。当然大家可能想到了,直接用PHP就可以实现了嘛。于是,下一篇文章就是PHP版本的《WordPress使用淘宝IP地址库的API显示评论者的位置信息(三)》。
Comments »