ip库引入,查询工具类

pull/2/head
dark 2022-12-11 22:20:43 +08:00
parent 7f131a3853
commit 0b5aa560b3
4 changed files with 160 additions and 0 deletions

View File

@ -20,12 +20,34 @@
</description>
<url>https://github.com/YunaiV/ruoyi-vue-pro</url>
<properties>
<ip2region.version>2.6.6</ip2region.version>
</properties>
<dependencies>
<dependency>
<groupId>cn.iocoder.boot</groupId>
<artifactId>yudao-common</artifactId>
</dependency>
<!-- IP地址检索 -->
<dependency>
<groupId>org.lionsoul</groupId>
<artifactId>ip2region</artifactId>
<version>${ip2region.version}</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<scope>provided</scope> <!-- 设置为 provided只有工具类需要使用到 -->
</dependency>
<!-- Test 测试相关 -->
<dependency>
<groupId>cn.iocoder.boot</groupId>

View File

@ -1,11 +1,94 @@
package cn.iocoder.yudao.framework.ip.core.utils;
import cn.iocoder.yudao.framework.common.exception.ServiceException;
import cn.iocoder.yudao.framework.ip.core.Area;
import lombok.extern.slf4j.Slf4j;
import org.lionsoul.ip2region.xdb.Searcher;
import java.io.IOException;
import static cn.iocoder.yudao.framework.common.exception.enums.GlobalErrorCodeConstants.INTERNAL_SERVER_ERROR;
/**
* IP
* <p>
* ip2region.xdb<a href="https://gitee.com/zhijiantianya/ip2region"/>
* region
*
* @author
*/
@Slf4j
public class IPUtils {
/**
* ip
*
*/
private static Searcher SEARCHER;
/**
* SEARCHER
*/
private final static IPUtils INSTANCE = new IPUtils();
/**
*
*/
private IPUtils() {
String dbPath = "ip2region.xdb";
dbPath = IPUtils.class.getClassLoader().getResource(dbPath).getPath();
try {
SEARCHER = Searcher.newWithBuffer(Searcher.loadContentFromFile(dbPath));
} catch (IOException e) {
// 加载xdb文件异常,不影响启动
log.error("启动加载IP SEARCH异常", e);
SEARCHER = null;
}
}
/**
* IPID127.0.0.1
* @param ip ip
* @return id
*/
public static Integer getAreaId(String ip) {
try {
return Integer.parseInt(SEARCHER.search(ip));
} catch (Exception e) {
throw new ServiceException(INTERNAL_SERVER_ERROR);
}
}
/**
* IPID{@link Searcher#checkIP(String)}
* @param ip ip
* @return id
*/
public static Integer getAreaId(long ip) {
try {
return Integer.parseInt(SEARCHER.search(ip));
} catch (Exception e) {
throw new ServiceException(INTERNAL_SERVER_ERROR);
}
}
/**
* IP127.0.0.1
* @param ip ip
* @return
*/
public static Area getArea(String ip) {
return AreaUtils.getArea(getAreaId(ip));
}
/**
* IP{@link Searcher#checkIP(String)}
* @param ip ip
* @return
*/
public static Area getArea(long ip) {
return AreaUtils.getArea(getAreaId(ip));
}
}

View File

@ -0,0 +1,55 @@
package cn.iocoder.yudao.framework.ip.core.utils;
import cn.iocoder.yudao.framework.ip.core.Area;
import org.junit.jupiter.api.Test;
import org.lionsoul.ip2region.xdb.Searcher;
import static org.junit.jupiter.api.Assertions.assertEquals;
/**
* {@link IPUtils}
*/
class IPUtilsTest {
@Test
void getAreaId() {
// 120.202.4.0|120.202.4.255|420600
Integer areaId = IPUtils.getAreaId("120.202.4.50");
assertEquals(420600, areaId);
}
@Test
void testGetAreaId() {
// 120.203.123.0|120.203.133.255|360900
long ip = 0L;
try {
ip = Searcher.checkIP("120.203.123.250");
} catch (Exception e) {
// ignore
}
Integer areaId = IPUtils.getAreaId(ip);
assertEquals(360900, areaId);
}
@Test
void getArea() {
// 120.202.4.0|120.202.4.255|420600
Area area = IPUtils.getArea("120.202.4.50");
assertEquals("襄阳市", area.getName());
}
@Test
void testGetArea() {
// 120.203.123.0|120.203.133.255|360900
long ip = 0L;
try {
ip = Searcher.checkIP("120.203.123.252");
} catch (Exception e) {
// ignore
}
Area area = IPUtils.getArea(ip);
assertEquals("宜春市", area.getName());
}
}