在项目开发的时候,需要去查询又一批手机号或者固话的具体信息(归属地 运营商)

就需要写一个脚本,来批量请求接口来得到我们想要的数据

学习源头:https://blog.csdn.net/shaerdong/article/details/45842409

一、淘宝网API

API地址: http://tcc.taobao.com/cc/json/mobile_tel_segment.htm?tel=15850781443
参数:
tel:手机号码
返回:JSON

二、百付宝API

API地址: https://www.baifubao.com/callback?cmd=1059&callback=phone&phone=15850781443
参数:
phone:手机号码
callback:回调函数
cmd:未知(必须)
返回:JSON

三: 这我没试过

http://www.haoservice.com/docs/14

有兴趣可以研究一下

这两个迄今为止 实测可以使用的;其他的我试了是不行的,比较是免费的么.能用就很开心了

PHP调用淘宝API实例:

<?php
$mobile = "150********"; //要查询的电话号码
$content = get_mobile_area($mobile);
print_r($content); function get_mobile_area($mobile){
$sms = array('province'=>'', 'supplier'=>''); //初始化变量
//根据淘宝的数据库调用返回值
$url = "http://tcc.taobao.com/cc/json/mobile_tel_segment.htm?tel=".$mobile."&t=".time(); $content = file_get_contents($url);
$sms['province'] = substr($content, "56", "4"); //截取字符串
$sms['supplier'] = substr($content, "81", "4");
return $sms;
}

自己之前用的是淘宝的api,开始还算稳定,但是过了一段时间,突然发现速度越来越慢,更是经常出现访问超时的问题,后来不得不放弃第三方,改用自己的库来保存手机号数据!这样一来,在自己的服务器上来判断手机号归属地,最后的结果相信大家也都想到了!

在这里,贴出2015版最新的手机号归属地数据库mysql版(包含170字段)的下载链接:http://download.csdn.net/detail/shaerdong/8715347

上面是之前博主的,我自己是用的curl去请求的

curl_get封装方法

function get_api($url){
$curl = curl_init(); // 启动一个CURL会话
$header[] = "Content-type: text/html;charset=utf-8";
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_HEADER, 0);
curl_setopt($curl, CURLOPT_HTTPHEADER, $header);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false); // 跳过证书检查
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false); // 从证书中检查SSL加密算法是否存在
curl_setopt($curl,CURLOPT_ENCODING,'gzip,deflate');
$contents = curl_exec($curl); //返回api的json对象
$contents = mb_convert_encoding($contents, 'utf-8', 'GBK,UTF-8,ASCII');
//关闭URL请求
curl_close($curl);
// dd($contents);
return $contents; //返回json对象
}

excel处理方法

// 一个读取excel 查询对应数据 并且处理数据 再导出excel的处理脚本
public function ioexcel()
{
// 读取excel文件内容
$tmp_file = public_path('ioexcel')."/录音正常通话统计.xls";
// dd($tmp_file);
Excel::load($tmp_file, function($reader) { $reader = $reader->getSheet(2);
//获取表中的数据
$results = $reader->toArray();
// $results = $reader->get()->toArray();
// dd($results);
$cellData[0] = ['录音编号','uuid','商家名称','客户号码', '客户号码归属地', '客户号码运营商','客服号码', '客服号码类型(固话/手机)','客服号码归属地', '客服号码运营商'];
foreach ($results as $key => $value) {
if ($key == 0) {
continue;
}
$data_id = $value[0]; // 数据id
if ($data_id == null) {
continue;
}
// dd($data_id);
// 根据读取到的数据id去查询数据
$res = DB::table('a_data')->where('id', $data_id)->first();
// dd($res);
$uuid = $res->uu_id;
$data_packet_id = $res->data_packet_id;
// 根据数据包id查询对应的商家id和商家名称
$bus_id = \ai\Models\Datapacket::getDpDetail($data_packet_id)->business_id;
$bus_name = \ai\Models\Business::getBus($bus_id)->name;
// 查询客户信息
$kh_phone = $res->kh_phone;
$kh_info = $this->getPhone($kh_phone);
// 查询客服信息
$kf_phone = $res->called_phone;
// dd($kf_phone);
if ($kf_phone) {
$kf_info = $this->getPhone($kf_phone);
}
$cellData[$key+1] = [$data_id, $uuid, $bus_name, $kh_phone, $kh_info[0], $kh_info[1], $kf_phone ? $kf_phone : '', $kf_phone ? $kf_info[2] : '', $kf_phone ? $kf_info[0] : '', $kf_phone ? $kf_info[1] : ''];
// dd($cellData[$key+1]);
}
$exp_res = Excel::create("通话正常质量调查统计-第一段处理版",function($excel) use ($cellData){
$excel->sheet('score', function($sheet) use ($cellData){
$sheet->rows($cellData);
});
})->export('xls');
});
} // 读取手机号的客户号码归属地 客户号码运营商 客服号码类型(固话/手机)等信息
private function getPhone($phone)
{
// $phone = '05532611908';
// 判断是固话还是移动电话 固话都是以0开头的
$type = '手机'; // 移动电话
if ($phone[0] == 0) {
$type = '固话'; // 固话
}
$url = "https://tcc.taobao.com/cc/json/mobile_tel_segment.htm?tel={$phone}";
$info = get_api($url);
preg_match_all("/(\w+):'([^']+)/", $info, $match);
// $info = str_replace ( "\r\n", '', $info );
// $info = str_replace ( "\n", '', $info );
// $info = str_replace ( "\t", '', $info );
// $info = strstr($info,'__GetZoneResult_'); // $info = json_decode($info); // dd($match);
if ($type == '手机') {
$province = $match[2][1];
$catName = $match[2][2];
} else if ($type == '固话') {
$province = $match[2][0];
$catName = '';
} // dd($province, $catName);
$data = [$province, $catName, $type];
return $data; // $sms = array('province'=>'', 'supplier'=>''); //初始化变量
// //根据淘宝的数据库调用返回值
// $url = "https://tcc.taobao.com/cc/json/mobile_tel_segment.htm?tel=".$phone."&t=".time();
//
// $content = file_get_contents($url);
// dd($content);
// $sms['province'] = substr($content, "56", "4"); //截取字符串
// $sms['supplier'] = substr($content, "81", "4");
// return $sms;
}

在我用curl方法的过程中,发现返回的结果不是json格式的,

然后我就又百度了一下

学习源头:https://bbs.csdn.net/topics/390804729

在 php 中使用的话可以这样解析

 
   
$s = file_get_contents('http://tcc.taobao.com/cc/json/mobile_tel_segment.htm?tel=15850781443');
preg_match_all("/(\w+):'([^']+)/", $s, $m);
$a = array_combine($m[1], $m[2]);
print_r($a);

Array
(
    [mts] => 1585078
    [province] => 江苏
    [catName] => 中国移动
    [telString] => 15850781443
    [areaVid] => 30511
    [ispVid] => 3236139
    [carrier] => 江苏移动
)

PHP 判断手机号归属地 和 运营商的免费接口的更多相关文章

  1. WordPress显示评论者IP归属地、浏览器、终端设备、电信运营商

    在网上查资料闲逛,偶然间看到了张戈博客的评论框有点意思,于是就收走拿到了我的米扑博客. 本文为米扑博客原创:总结分享 WordPress显示评论者IP归属地.浏览器.终端设备.电信运营商 WordPr ...

  2. PHP判断手机号运营商(详细介绍附代码)

    道理很简单,知道手机号规则 进行正则判断就可以 移动:134.135.136.137.138.139.150.151.157(TD).158.159.187.188 联通:130.131.132.15 ...

  3. Python(phone)模块获取手机号归属地、区号、运营商等

    Python(phone)模块获取手机号归属地.区号.运营商等 一.我使用的是python3,可以自行搜索下载 二.安装phone模块, pip install phone 三.测试代码如下: fro ...

  4. iOS开发判断手机号及其运营商

    根据三大运营商出现的号段(号段来自百度百科) 判断是否是手机号 + (BOOL)isMobile:(NSString *)str { NSString *MOBILE = @"^1(3[0- ...

  5. 记 判断手机号运营商function

    /* 移动:134.135.136.137.138.139.150.151.157(TD).158.159.187.188 联通:130.131.132.152.155.156.185.186 电信: ...

  6. php 判断手机号运营商

    /* 移动:134.135.136.137.138.139.150.151.157(TD).158.159.187.188 联通:130.131.132.152.155.156.185.186 电信: ...

  7. java判断手机号三大运营商归属的工具类

    package com.tymk.front.third; import java.util.regex.Pattern; public class OperatorsUtil { /** * 中国电 ...

  8. android判断网络连接状态、联网类型、运营商

    /** * 获取上网方式 * * @param mContext * @return */ public static String getNetType(Context mContext) { St ...

  9. Android手机上判断网络运营商

    我们想获取手机的运营商信息.通常都会去调用系统的TelephonyManager类的取数据.但是很多时候可能取不到卡的信息(例如双卡手机和 一些特殊卡),这样就区别不了运营商了.但是有时候我们的需求要 ...

随机推荐

  1. JSP数据交互(一)

    1.JSP内置对象 请求对象:request 输出对象:out 响应对象:response 应用程序对象:application 会话对象:session 页面上下文对象:pageContext 页面 ...

  2. Map 的 key、value 是否允许为null

    Map的key和value是否允许null? 直接写程序验证一下: import java.util.HashMap; import java.util.Hashtable; import java. ...

  3. Springboot- Spring缓存抽象学习笔记

    Spring缓存作用准备: 1.准备数据(准备一个有数据的库和表/导入数据库文件,准备好表和表里面的数据) 2.创建javaBean封装数据 3.整合MyBatis操作数据库( 这里用MyBatis) ...

  4. 关于JDK1.8 HashMap扩容部分源码分析

    今天回顾hashmap源码的时候发现一个很有意思的地方,那就是jdk1.8在hashmap扩容上面的优化. 首先大家可能都知道,1.8比1.7多出了一个红黑树化的操作,当然在扩容的时候也要对红黑树进行 ...

  5. extundelete实现Linux下文件/文件夹数据恢复!

    我用的是Centos系统,在安装extundelete之前需要安装e2fsprogs,e2fsprogs-libs,e2fsprogs-devel. 这里用:yum install e2fsprogs ...

  6. python twisted教程[资料]

    python twisted教程 一,异步编程 http://www.douban.com/note/232200511/   python twisted教程 二:缓慢的诗 http://www.d ...

  7. 数据库连接池 c3p0 druid

    druid 数据库连接池 c3p0 使用C3P0数据源时需要依赖 mchange-commons-java-0.2.3.4.jar包.缺少该jar包则会报错!

  8. jquery制作选项卡

    思路:点击按钮后,先让所有的按钮的class属性都为“”,所有的div的display样式都为none:再让当前被点击按钮的class属性为active,以及所对应的div的display样式为blo ...

  9. 011-对象——interface接口说明与使用方式实例

    <?php /** interface接口说明与使用方式实例 * * 接口里面的方法全是抽象方法,没有实体的方法.这样的类我们就叫做接口.定义的时候用Interface定义.实现接口时用impl ...

  10. 【51nod-1605】棋盘问题

    上帝创造了一个n*m棋盘,每一个格子都只有可能是黑色或者白色的. 亚当和夏娃在玩一个游戏,每次寻找边长为x的正方形,其中每个格子必须为黑色,然后将这些格子染白. 如果谁不能操作了,那么那个人就输了. ...