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

相关文章

来自专栏Java3y

Hibernate【inverse和cascade属性】知识要点

Inverse属性 Inverse属性:表示控制权是否转移.. true:控制权已转移【当前一方没有控制权】 false:控制权没有转移【当前一方有控制权】 I...

2764
来自专栏GreenLeaves

EF 通过DataAnnotations配置属性和类型

 一、通过Attribute配置约束 1、主键约束 通过KeyAttribute来配置主键约束,代码如下: [Key] public int PrimaryKe...

1705
来自专栏IT可乐

mybatis 详解(五)------动态SQL

  前面几篇博客我们通过实例讲解了用mybatis对一张表进行的CRUD操作,但是我们发现写的 SQL 语句都比较简单,如果有比较复杂的业务,我们需要写复杂的 ...

25110
来自专栏C# 编程

[C#]使用Join与GroupJoin将两个集合进行关联与分组

本文为原创文章、源代码为原创代码,如转载/复制,请在网页/代码处明显位置标明原文名称、作者及网址,谢谢! 本文使用的开发环境是VS2017及dotNet4.0,...

1890
来自专栏hbbliyong

LINQ分页和排序,skip和Take 用法

LINQ分页和排序,skip和Take 用法 dbconn.BidRecord.OrderBy(p=>p.bid_id).ToList<BidRecord>()...

3409
来自专栏程序员的SOD蜜

使用操作符重载,生成ORM实体类的SQL条件语句

ORM框架的一个不可或缺的功能就是根据实体类,生成操作数据库的SQL语句,这其中,最难处理的就是那些复杂的SQL条件比较语句。比如,有下面这样一个SQL语句: ...

21510
来自专栏风口上的猪的文章

.NET面试题系列[14] - LINQ to SQL与IQueryable

"理解IQueryable的最简单方式就是,把它看作一个查询,在执行的时候,将会生成结果序列。" - Jon Skeet

611
来自专栏Python

Django中Q查询及Q()对象

问题 一般我们在Django程序中查询数据库操作都是在QuerySet里进行进行,例如下面代码: >>> q1 = Entry.objects.filter(h...

1985
来自专栏PingCAP的专栏

TiDB 源码阅读系列文章(四)Insert 语句概览

本文为 TiDB 源码阅读系列文章的第四篇。上一篇文章简单介绍了整体流程,无论什么语句,大体上是在这个框架下运行,DDL 语句也不例外。

3805
来自专栏cnblogs

NHibernate联合主键详细示例

使用NHibernate实现一对多,多对一的关联很是简单,可如果要用复合主键实现确实让人有些淡淡的疼。虽然很淡疼但还是要去抹平这个坑,在下不才,愿意尝试。 以示...

1688

扫码关注云+社区