ahxcjxzxh 发表于 2017-12-30 12:32:36

通过 WebService 调用获取数据

  在网上找到一个是由手机在线提供的一个不错的简单实用的接口。
  该网站提供的接口包括如下类型:


[*]通过 WebService 调用获取数据
[*]通过 HTTP Post/Get 获取 XML 格式的数据
[*]通过 HTTP Post/Get 获取 JSON 格式的数据
[*]通过 HTTP Post/Get 获取普通文本格式数据
[*]通过 form 或 iframe 标签插入 Web 页面
[*]通过 JavaScript 和 HTML 标签插入 Web 页面
通过 WebService 调用获取数据
  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="请输入手机号码">  <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="请输入手机号码">  <input type="submit" value="查询" />
  </form>
  

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

<iframe name="frameLocating" src="http://api.showji.com/Locating/query.aspx">  

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

<html>  <head>
  <meta http-equiv="Content-Type" content="text/html; " />
  </head>
  <body>
  <form >

  请输入手机号码:<input>  <input type="Submit" value="查询" />
  </form>
  <div>
  <span>您输入的手机号码有误</span>
  </div>
  

  

  <div>
  手机号码:<span></span><br/>
  

所属省份:<span></span><br/>  所属城市:<span></span><br/>
  区  号:<span></span><br/>
  邮  编:<span></span><br/>
  类  型:<span></span><br/>
  

  

</div>  <div>
  </div>
  <script type="text/javascript" src="http://blog.163.com/lgh_2002/blog/http://api.showji.com/Locating/Query.js">
  </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="请输入手机号码">  <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>
  
页: [1]
查看完整版本: 通过 WebService 调用获取数据