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显示评论者的位置信息(三)》。
转载:https://typecodes.com/web/wptaoiplibapitwo.html
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/112576.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...