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

相关文章

来自专栏Android Note

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

2982
来自专栏java架构师

Stream篇(3)【StreamReader】

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

3156
来自专栏Java学习之路

Hibernate学习---单表查询

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

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

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

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

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

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

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

2865
来自专栏chenssy

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

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

1172
来自专栏JavaEE

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

4618
来自专栏AILearning

Oracle部分笔记

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

2076
来自专栏一个会写诗的程序员的博客

Spring Boot 结合 spring data jpa中的 DTO 映射查询《Spring Boot 开发实战》

我们知道,在 MyBatis 中直接 DTO 映射查询的时候,写起来非常简单。只要字段对应上即可:

1305
来自专栏乐沙弥的世界

PL/SQL 集合的方法

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

773

扫码关注云+社区