java 后台实现查询号码归属地

java 后台实现查询号码归属地

测试展示

Paste_Image.png

代码
package com.wuage.clm.util;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.URL;
import java.net.URLConnection;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.regex.Pattern;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;


/**
 * 类PhoneNumberBelongsUtil.java的实现描述:
 * 
 * 根据手机号码查询归属地
 * @since 1.0.0
 * @author tangjinhui 2017年6月26日 上午10:39:13
 */
public class PhoneNumberBelongsUtil {
    
    private static final  Logger  logger                = LoggerFactory.getLogger(PhoneNumberBelongsUtil.class);
    private static final  String  formatSpecifier       = "^1[3|4|5|7|8][0-9]{9}$";
    //正则模板:编译
    private static        Pattern fsPattern             = Pattern.compile(formatSpecifier);
    /**
     * 查询手机号码查询归属地
     * @author tangjinhui
     * @param  phoneNumber 手机号码
     * @since  1.0.0
     * @return map (省<prov>、市<city>归属)
     */
    public static Map<String,Object> checkPhoneNumberBelongs(String phoneNumber){
        logger.info("begin to check phoneNumber={} belongs to  the ground",phoneNumber);
        Map<String, Object> map = new HashMap<>();
        //校验是否为手机号码
        if(phoneNumber.length() !=11||!fsPattern.matcher(phoneNumber).matches()){
            return map;
        }
        
        StringBuffer url = new StringBuffer();
        url.append("https://sp0.baidu.com/8aQDcjqpAAV3otqbppnN2DJv/api.php?query=");
        url.append(phoneNumber);
        url.append("&co=&resource_id=6004&t=1498214330640&ie=utf8&oe=gbk&cb=op_aladdin_callback&format=json&tn=baidu&cb=jQuery110206964374771341681_1498213853507&_=1498213853531");
        
        URL openUrl = null;
        URLConnection conn=null;
        BufferedReader br =null;
        String inputLine = null;
        
        try {
            openUrl = new URL(url.toString());
            conn = openUrl.openConnection();
            br = new BufferedReader(new InputStreamReader(conn.getInputStream(), "GBK"));
            StringBuffer sb = new StringBuffer();
            while ((inputLine = br.readLine()) != null) {
                sb.append(inputLine);
            }
            
            List<String> asList = Arrays.asList(String.valueOf(sb).split(","));
            for (String string : asList) {
                if (string.contains("city") || string.contains("prov")) {
                    String[] split = string.replaceAll(" ","").replaceAll("\"", "").split(":");
                    map.put(split[0], split[1]);
                    continue;
                }
            }
         
        } catch (Exception e) {
            logger.error("PhoneNumberBelongsUtil类中checkPhoneNumberBelongs方法:param ={}, error:{}",phoneNumber,e);
            return map;
        } finally {
            try {
                br.close();
            } catch (IOException e) {
                logger.error("close io exception error message:{}", e);
            }
        }
        return map;
    }
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏AILearning

Oracle部分笔记

SQL> --instr(a,b) 从a中,查找b,找到返回下标;下标从1开始,否则返回0 SQL> select instr('Hello world','l...

22360
来自专栏北京马哥教育

SQL函数汇总【精选篇】

1.绝对值 SQL:select abs(-1) value O:select abs(-1) value from dual 2.取整(大) ...

33390
来自专栏机器学习从入门到成神

Hibernate查询技术之HQL语句

1、session中的get( )和load( )方法来查询对象。但其查询功能有限。

45810
来自专栏Java帮帮-微信公众号-技术文章全总结

Oracle应用实战六——函数+集合

函数 字符函数 接收字符输入返回字符或者数值,dual是伪表 1. 把小写的字符转换成大小的字符 upper('smith') ? 2. 把大写字符变成小写字符...

31550
来自专栏java架构师

Stream篇(3)【StreamReader】

说明:实现一个TextReader,是其子类。父类是Text读取器,子类是流读取器 一、构造函数: 1、StreamReader(Stream stream)s...

33060
来自专栏乐沙弥的世界

PL/SQL 集合的方法

    PL/SQL中提供了常用的三种集合联合数组、嵌套表、变长数组,而对于这几个集合类型中元素的操作,PL/SQL提供了相应的函数或过程来操 纵数组中的元素...

8730
来自专栏Java学习之路

Hibernate学习---单表查询

我们都知道SQL是非常强大的,为什么这么说呢?相信学过数据库原理的同学们都深有体会,SQL语句变化无穷,好毫不夸张的说可以实现任意符合我们需要的数据库操作,既然...

31270
来自专栏Ryan Miao

Mybatis - 动态sql

learn from:http://www.mybatis.org/mybatis-3/dynamic-sql.html mybatis支持动态拼接sql语句。...

38460
来自专栏乐沙弥的世界

PL/SQL变长数组

  PL/SQL变长数组时PL/SQL集合数据类型中的一种,其使用方法与PL/SQL嵌套表大同小异,唯一的区别则是变长数组的元素的最大个数是有限 制的。也即是说...

9920
来自专栏菩提树下的杨过

无限级分类(非递归算法/存储过程版/GUID主键)完整数据库示例_(3)删除记录

-- ============================= -- Author:  <杨俊明,Jimmy.yang@cntvs.com or yjmyz...

21580

扫码关注云+社区

领取腾讯云代金券