update 优化 !pr73 代码结构

2.X
疯狂的狮子li 2 years ago
parent 1f8155f5de
commit 3fc3d52ba4

@ -337,6 +337,13 @@
<version>${tencent.sms.version}</version> <version>${tencent.sms.version}</version>
</dependency> </dependency>
<!-- 离线IP地址定位库 ip2region -->
<dependency>
<groupId>org.lionsoul</groupId>
<artifactId>ip2region</artifactId>
<version>${ip2region.version}</version>
</dependency>
<!-- 临时修复 snakeyaml 漏洞 --> <!-- 临时修复 snakeyaml 漏洞 -->
<dependency> <dependency>
<groupId>org.yaml</groupId> <groupId>org.yaml</groupId>
@ -350,13 +357,6 @@
<version>${fastjson.version}</version> <version>${fastjson.version}</version>
</dependency> </dependency>
<!-- 离线IP地址定位库 ip2region -->
<dependency>
<groupId>org.lionsoul</groupId>
<artifactId>ip2region</artifactId>
<version>${ip2region.version}</version>
</dependency>
</dependencies> </dependencies>
</dependencyManagement> </dependencyManagement>

@ -78,6 +78,12 @@
<artifactId>swagger-annotations</artifactId> <artifactId>swagger-annotations</artifactId>
</dependency> </dependency>
<!-- 离线IP地址定位库 -->
<dependency>
<groupId>org.lionsoul</groupId>
<artifactId>ip2region</artifactId>
</dependency>
<dependency> <dependency>
<groupId>org.projectlombok</groupId> <groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId> <artifactId>lombok</artifactId>
@ -104,12 +110,6 @@
<artifactId>spring-boot-configuration-processor</artifactId> <artifactId>spring-boot-configuration-processor</artifactId>
</dependency> </dependency>
<!-- 离线IP地址定位库 -->
<dependency>
<groupId>org.lionsoul</groupId>
<artifactId>ip2region</artifactId>
</dependency>
</dependencies> </dependencies>
</project> </project>

@ -20,18 +20,14 @@ public class AddressUtils {
public static final String UNKNOWN = "XX XX"; public static final String UNKNOWN = "XX XX";
public static String getRealAddressByIP(String ip) { public static String getRealAddressByIP(String ip) {
String address = UNKNOWN;
if (StringUtils.isBlank(ip)) { if (StringUtils.isBlank(ip)) {
return address; return UNKNOWN;
} }
// 内网不查询 // 内网不查询
ip = "0:0:0:0:0:0:0:1".equals(ip) ? "127.0.0.1" : HtmlUtil.cleanHtmlTag(ip); ip = "0:0:0:0:0:0:0:1".equals(ip) ? "127.0.0.1" : HtmlUtil.cleanHtmlTag(ip);
if (NetUtil.isInnerIP(ip)) { if (NetUtil.isInnerIP(ip)) {
return "内网IP"; return "内网IP";
} }
// if (RuoYiConfig.isAddressEnabled()) {
return RegionUtils.getCityInfo(ip); return RegionUtils.getCityInfo(ip);
// }
// return address;
} }
} }

@ -1,16 +1,14 @@
package com.ruoyi.common.core.utils.ip; package com.ruoyi.common.core.utils.ip;
import cn.hutool.core.io.FileUtil; import cn.hutool.core.io.FileUtil;
import cn.hutool.core.net.Ipv4Util; import cn.hutool.core.io.resource.ClassPathResource;
import cn.hutool.core.util.ObjectUtil; import cn.hutool.core.util.ObjectUtil;
import cn.hutool.extra.servlet.ServletUtil;
import com.ruoyi.common.core.exception.ServiceException; import com.ruoyi.common.core.exception.ServiceException;
import com.ruoyi.common.core.utils.file.FileUtils;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.lionsoul.ip2region.xdb.Searcher; import org.lionsoul.ip2region.xdb.Searcher;
import javax.servlet.http.HttpServletRequest;
import java.io.File; import java.io.File;
import java.io.InputStream;
/** /**
* ip线 * ip线
@ -21,35 +19,17 @@ import java.io.InputStream;
@Slf4j @Slf4j
public class RegionUtils { public class RegionUtils {
private static final String LOCAL_REMOTE_HOST = "0:0:0:0:0:0:0:1"; private static final Searcher SEARCHER;
private static final Searcher searcher;
/**
* ip
*/
public static String getIp(HttpServletRequest request) {
if (ObjectUtil.isEmpty(request)) {
return Ipv4Util.LOCAL_IP;
} else {
try {
String remoteHost = ServletUtil.getClientIP(request);
return LOCAL_REMOTE_HOST.equals(remoteHost) ? Ipv4Util.LOCAL_IP : remoteHost;
} catch (Exception e) {
return Ipv4Util.LOCAL_IP;
}
}
}
static { static {
String fileName = "/ip2region.xdb"; String fileName = "/ip2region.xdb";
File existFile = FileUtil.file(FileUtil.getTmpDir() + FileUtil.FILE_SEPARATOR + fileName); File existFile = FileUtils.file(FileUtil.getTmpDir() + FileUtil.FILE_SEPARATOR + fileName);
if (!FileUtil.exist(existFile)) { if (!FileUtils.exist(existFile)) {
InputStream resourceAsStream = RegionUtils.class.getResourceAsStream(fileName); ClassPathResource fileStream = new ClassPathResource(fileName);
if (ObjectUtil.isEmpty(resourceAsStream)) { if (ObjectUtil.isEmpty(fileStream.getStream())) {
throw new ServiceException(">>>>>>>> IpAddressUtil初始化失败原因IP地址库数据不存在"); throw new ServiceException("RegionUtils初始化失败原因IP地址库数据不存在");
} }
FileUtil.writeFromStream(resourceAsStream, existFile); FileUtils.writeFromStream(fileStream.getStream(), existFile);
} }
String dbPath = existFile.getPath(); String dbPath = existFile.getPath();
@ -59,13 +39,13 @@ public class RegionUtils {
try { try {
cBuff = Searcher.loadContentFromFile(dbPath); cBuff = Searcher.loadContentFromFile(dbPath);
} catch (Exception e) { } catch (Exception e) {
throw new ServiceException(">>>>>>>> IpAddressUtil初始化失败原因从ip2region.xdb文件加载内容失败" + e.getMessage()); throw new ServiceException("RegionUtils初始化失败原因从ip2region.xdb文件加载内容失败" + e.getMessage());
} }
// 2、使用上述的 cBuff 创建一个完全基于内存的查询对象。 // 2、使用上述的 cBuff 创建一个完全基于内存的查询对象。
try { try {
searcher = Searcher.newWithBuffer(cBuff); SEARCHER = Searcher.newWithBuffer(cBuff);
} catch (Exception e) { } catch (Exception e) {
throw new ServiceException(">>>>>>>> IpAddressUtil初始化失败,原因:" + e.getMessage()); throw new ServiceException("RegionUtils初始化失败,原因:" + e.getMessage());
} }
} }
@ -76,7 +56,7 @@ public class RegionUtils {
try { try {
ip = ip.trim(); ip = ip.trim();
// 3、执行查询 // 3、执行查询
String region = searcher.search(ip); String region = SEARCHER.search(ip);
return region.replace("0|", "").replace("|0", ""); return region.replace("0|", "").replace("|0", "");
} catch (Exception e) { } catch (Exception e) {
log.error("IP地址离线获取城市异常 {}", ip); log.error("IP地址离线获取城市异常 {}", ip);

Loading…
Cancel
Save