PHP实现手机号码归属地查询

在网上找到一个是由手机在线提供的一个不错的简单实用的接口。

该网站提供的接口包括如下类型:

  1. 通过 WebService 调用获取数据
  2. 通过 HTTP Post/Get 获取 XML 格式的数据
  3. 通过 HTTP Post/Get 获取 JSON 格式的数据
  4. 通过 HTTP Post/Get 获取普通文本格式数据
  5. 通过 form 或 iframe 标签插入 Web 页面
  6. 通过 JavaScript 和 HTML 标签插入 Web 页面

Web Service 地址:http://api.showji.com/locating/Mobile.asmx

只含有一个对象:Mobile。其成员如下:

获取手机号码归属地信息

函数原型:

bool Query(string Mobile, out string Province, out string City, out string AreaCode, out
string PostCode, out string Corp, out string Card);

参数:

Mobile: 待查询的手机号码。
Province: 返回手机号码归属地的省份。
City: 返回手机号码归属地的城市。
AreaCode: 返回手机号码归属地的区号。
PostCode: 返回手机号码归属地的邮编。
Corp: 返回所属运营商。
Card: 返回所属卡类型。

返回值:

返回 bool 值,表示用户输入的号码是否可识别。

获取当前服务状态

函数原型:

bool GetStatus();

返回值:

返回 bool 值,表示当前服务是否可用。
使用php开源的soap库直接调用即可,这个调用比较简单,在这里就不在多说,具体详细的介绍,可参考我的另一篇
博文:使用PHP SOAP库调用标准Webservice接口

通过 HTTP Post/Get 获取 XML/JSON/普通文本 格式的数据

调用接口形式:http://api.showji.com/locating/?m=$mobile&output=$type
参数说明:
$mobile:要查询的手机号码(可以全部11位号码,也可只输入前7位)。
$type:查询结果的数据格式类型,其值可为:xml, json或text三个值。

通过PHP来实现,可以采用curl的方式来获取数据进行展示,对于xml和json在实际中我们直接通过处理来获取数据。

程序实现如下:

<?php
$mobile ='13844033329';
$type = 'text';
$url = "http://api.showji.com/locating/?m=$mobile&output=$type";
$ch = curl_init();
curl_setopt($ch,CURLOPT_URL,$url);
curl_setopt($ch,CURLOPT_POST,1);
curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);
$data = curl_exec($ch);
curl_close($ch);
//输出手机归属地相关信息
echo $data."/n";
//输出结果:
Mobile:13844033329
QueryResult:True
Province:吉林
City:长春
AreaCode:0431
PostCode:130000
Corp:中国移动
Card:GSM
?>

通过 form 或 iframe 标签插入 Web 页面

这种方式可以在您的网站中嵌入手机归属地查询程序,以便提供给用户使用,提升您的网站的用户黏性。

1.基于form提交的有两种形式,一种是直接在新窗口打开完整页面,另一个是打开小窗口,代码形式分别如下:

打开完整新窗口代码:

<form name="formLocating" action="http://api.showji.com/Locating/query.aspx" method="GET" target="_blank">
<input type="text" name="m" value="请输入手机号码" onclick=this.value="" />
<input type="submit" value="查询" />
</form>

打开小窗口代码:

<form name="formLocating" action="http://api.showji.com/Locating/query.aspx" method="GET" target="Locating">
<input type="text" name="m" value="请输入手机号码" onclick=this.value="" />
<input type="submit" value="查询" onclick="window.open('','Locating','width=500,height=300,status=yes,toolbar=no,menubar=no,location=no');" />
</form>

2.使用iframe包含直接嵌入到网页中

<iframe name="frameLocating" src="http://api.showji.com/Locating/query.aspx" width="500" height="300" marginwidth="0" marginheight="0" hspace="0" vspace="0" frame scrolling="no"></iframe>

通过 JavaScript 和 HTML 标签插入 Web 页面

这种方式可以实现样式的任意定制,客户端仅需要包含一个 JavaScript 脚本和显示结果的 HTML 代码即可。并且,定制的页面支持来自 GET 方式的提交,从而本地可以定制多种查询情况。

页面 part1.htm,实现完整的查询页面:

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
</head>
<body>
<form onsubmit="return query();">
请输入手机号码:<input >您输入的手机号码有误</span>
</div>

<div ></span><br/>

   所属省份:<span ></span><br/>
</div>
<div >
</script>
</body>
</html>

页面 part2.htm,简单的查询文本框,可提交查询至 part1.htm(如果要修改文件名,请确保其一致)。

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
</head>
<body>
<form name="formLocating" action="part1.htm" method="GET">
<input type="text" name="m" value="请输入手机号码" onclick=this.value="" />
<input type="submit" />
</form>
</body>
</html>

页面 part2.htm 如果使用 POST 方式提交,必须满足以下条件:part1.htm 必须经服务器端脚本解析。例如使用

part1.asp 取代 part1.htm。同时,必须在引用 Query.js 前,增加如下代码:

<script type="text/javascript">
strMobile=“<%=Request("m")%>”;
</script>