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 条评论
登录 后参与评论

相关文章

来自专栏与神兽党一起成长

Sizzle.selectors.match/leftMatch

对象Sizzle.selectors.match/leftMatch中存放了表达式类型和正则的映射,正则用于确定块表达式的类型,并解析其中的参数。

842
来自专栏chenssy

【死磕Sharding-jdbc】---SQL解析-词法分析

sharding-jdbc对SQL解析的源码主要在下图所示parsing模块中,由下图可知SQL解析主要分为两部分:lexer和parser。lexer就是本文...

822
来自专栏Ryan Miao

Mybatis - 动态sql

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

2966
来自专栏AILearning

Oracle部分笔记

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

1866
来自专栏北京马哥教育

SQL函数汇总【精选篇】

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

2779
来自专栏Android Note

Android—Room数据库多表查询(Relationships)

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

Hibernate查询技术之HQL语句

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

1641
来自专栏JetpropelledSnake

Django学习笔记之Models与ORM操作

1016
来自专栏aCloudDeveloper

string 之 strcmp函数

Author: bakari  Date: 2012/8/9 继上篇。。。。。 下面是我写的代码与源码作的一些比较,均已严格测试通过,分别以“string 之”...

1847
来自专栏JavaEE

mybatis的association以及collection的用法association:一对一关联(has one)collection:一对多关联(has many)

4038

扫码关注云+社区