js判断手机号码归属地查询接口--精确到地市

3 篇文章 0 订阅

js判断手机号码归属地查询接口–精确到地市

开发中遇到什么学习什么:

  • 测试了很多次,但是都不太理想,前台的后台的都试过了,最后写的这篇文章
  • 其实没有你想象的难,一个js就搞定了

这是你试用过的方法

1、淘宝网((精确到省份)
API地址: http://tcc.taobao.com/cc/json/mobile_tel_segment.htm?tel=手机号码

2、百度(精确到地市)
API地址:http://mobsec-dianhua.baidu.com/dianhua_api/open/location?tel=手机号码

等等等等其他大神都写过了 我就不整理了。。。
其用时最长的就是2方法:
js版:
ajax 没想到 获取json解析不了呢,有会的给出答案。
在这里插入图片描述
java版:
比较悲催:Run as java Application 可以 放到服务器调用报错 就不用了

public static String getMobileCity(String mobileNumber) {
        //百度的API地址
        String urlString = "http://mobsec-dianhua.baidu.com/dianhua_api/open/location?tel=" + mobileNumber;
        StringBuilder sb = new StringBuilder();
        BufferedReader buffer;
        String provinces = "";
        String city = "";
        String operators = "";
        try {
            URL url = new URL(urlString);
            //获取URL地址中的页面内容
            InputStream in = url.openStream();
            // 解决乱码问题
            buffer = new BufferedReader(new InputStreamReader(in, "utf8"));
            String line = null;
            //一行一行的读取数据
            while ((line = buffer.readLine()) != null) {
                sb.append(line);
            }
            in.close();
            buffer.close();
            //定义字符串
//            String objectStr = "{"response":{"***********":{"detail":{"area":[{"city":"开封"}],"province":"河南","type":"domestic","operator":"移动"},"location":"河南开封移动"}},"responseHeader":{"status":200,"time":1532934563306,"version":"1.1.0"}}";
            //1、使用JSONObject
            JSONObject jsonObject2 = JSONObject.parseObject(sb.toString());
            String result = jsonObject2.getString("response");
//          使用fastjson的parseObject方法将json字符串转换成Map
            LinkedHashMap<String, String> jsonMap = JSON.parseObject(result, new TypeReference<LinkedHashMap<String, String>>() {
            });
            for (Map.Entry<String, String> entry : jsonMap.entrySet()) {
                String value = entry.getValue();
                LinkedHashMap<String, String> jsonMap1 = JSON.parseObject(value, new TypeReference<LinkedHashMap<String, String>>() {
                });
                for (Map.Entry<String, String> entry1 : jsonMap1.entrySet()) {
                    if (entry1.getKey().equals("detail")) {
                        String value1 = entry1.getValue();
                        LinkedHashMap<String, String> jsonMap2 = JSON.parseObject(value1, new TypeReference<LinkedHashMap<String, String>>() {
                        });
                        for (Map.Entry<String, String> entry2 : jsonMap2.entrySet()) {
                            if (entry2.getKey().equals("province")) {
                                provinces = entry2.getValue();
                            }
                            if (entry2.getKey().equals("operator")) {
                                operators = entry2.getValue();
                            }
                            if (entry2.getKey().equals("area")) {
                                String value2 = entry2.getValue();
                                String value3 = value2.substring(1, value2.length() - 1);
                                LinkedHashMap<String, String> jsonMap3 = JSON.parseObject(value3, new TypeReference<LinkedHashMap<String, String>>() {
                                });
                                for (Map.Entry<String, String> entry3 : jsonMap3.entrySet()) {
                                    city = entry3.getValue();
                                }
                            }
                        }
                    }
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        //从JSONObject对象中读取城市名称
        return provinces+" "+city+" "+operators;
    }
}

最后找到一个好用的

http://api.online-service.vip/phone?number=手机号
然后就好了
在这里插入图片描述

最后一个js就搞定了:

<script type="text/javascript">
 function gainPhoneCity(phone){
	var pp = ''
	$.ajax({
        url:"http://api.online-service.vip/phone?number="+phone,
        type:"get",
        datatype:"json",
        success:function(data){
        	pp = data.city;
        }
    });
	return pp;
}
</script>
  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值