찾다
컴퓨터 튜토리얼컴퓨터 지식Douyin의 IP 위치를 쿼리하는 방법(Douyin의 IP 위치를 표시하는 방법)

Douyin의 IP 위치를 쿼리하는 방법(Douyin의 IP 위치를 표시하는 방법)

1. 배경

PHP 편집자 Xiaoxin이 Douyin의 IP 위치를 쿼리하는 방법을 소개합니다. Douyin 앱을 사용할 때 특정 사용자의 IP 주소가 어디에 속하는지 알고 싶은 경우가 종종 있습니다. IP 위치를 쿼리하면 사용자의 대략적인 위치 정보를 알 수 있습니다. 그렇다면 Douyin의 IP 위치를 확인하는 방법은 무엇입니까? 다음으로 자세한 답변을 드리겠습니다.

다음으로 Java 백엔드가 IP 속성 기능을 구현하는 방법에 중점을 두겠습니다. 실제로 다음 두 단계만 필요합니다.

2 클라이언트 IP 인터페이스 얻기

웹 개발을 해본 사람이라면 누구나 이해할 것입니다. 모바일이든 PC이든 요청 인터페이스는 HttpServletRequest 객체로 캡슐화됩니다. 이 객체에는 요청 주소, 매개변수, 제출된 데이터 등 클라이언트가 요청한 다양한 정보가 포함되어 있습니다.

서버가 IP를 직접 노출하는 경우 request.getRemoteAddr()을 사용하여 클라이언트 IP를 얻을 수 있습니다.

현재 널리 사용되는 아키텍처에서는 대부분의 서버가 IP 주소를 직접 노출하지 않지만 하나 이상의 역방향 프록시 계층을 통해 요청을 처리합니다. 일반적인 역방향 프록시 도구는 nginx입니다. 프록시를 도입하면 서버와 클라이언트 사이에 추가 계층이 있으므로 request.getRemoteAddr() 메서드를 사용하여 얻은 IP 주소는 클라이언트의 IP 주소가 아닌 프록시 서버의 IP 주소가 됩니다. 원래 클라이언트의 IP 주소를 추적하기 위해 일반적으로 X-Forwarded-For와 같은 정보가 전달 헤더에 추가됩니다. 이 정보는 요청의 실제 소스를 확인하는 데 사용될 수 있습니다.

X-Forwarded-For는 Squid에서 개발한 필드로 HTTP 프록시나 로드 밸런싱 서버를 통과할 때만 추가됩니다. 형식은 X-Forwarded-For:client1,proxy1,proxy2입니다. 일반적으로 첫 번째 IP 주소는 클라이언트의 실제 IP이고, 다음 IP 주소는 통과한 프록시 서버의 IP입니다. 위의 코드 주석에 따르면 첫 번째 IP 주소를 직접 가로챌 수 있습니다. Proxy-Client-IP/WL-Proxy-Client-IP는 Apache HTTP 서버에서 요청할 때만 존재하는 헤더입니다. Apache HTTP를 프록시로 사용하는 경우 일반적으로 Proxy-Client-IP 요청 헤더가 추가되며, WL-Proxy-Client-IP는 WebLogic 플러그인에 의해 추가되는 헤더입니다. 이 경우 헤더 정보를 직접 얻을 수도 있습니다. HTTP_CLIENT_IP는 일부 프록시 서버가 추가할 수 있는 요청 헤더입니다. X-Real-IP는 Nginx에서 일반적으로 사용하는 요청 헤더입니다.

일상적인 개발에서는 클라이언트를 추적하기 위해 어떤 헤더 정보를 사용해야 하는지 명확하게 지정되어 있지 않습니다. 얻을 때까지 하나씩 시도해야 합니다. 해당 코드는 다음과 같습니다.

ini

Copy code

@Slf4jpublic class IpUtils { private static final String UNKNOWN_VALUE = “unknown”; private static final String LOCALHOST_V4 = “127.0.0.1”; private static final String LOCALHOST_V6 = " 0:0:0:0:0:0:0:1"; private static final String X_FORWARDED_FOR = "X-Forwarded-For"; private static final String private static final String PROXY_CLIENT_IP = "프록시 -Client-IP”; private static final String WL_PROXY_CLIENT_IP = “WL-Proxy-Client-IP”; private static final String HTTP_CLIENT_IP = “HTTP_CLIENT_IP”; private static final String IP_DATA_PATH = ”/Users/shepherdmy /Desktop/ip2region.xdb”
; private static byte[] contentBuff; /*** 클라이언트 IP 주소 가져오기 * @param 요청 * @return*/ public static String getRemoteHost(HttpServletRequest request) { String ip = request.getHeader(X_FORWARDED_FOR); if ( StringUtils.isNotEmpty(ip) && !UNKNOWN_VALUE.equalsIgnoreCase(ip)) { // 여러 역방향 프록시 후에는 여러 개의 IP 값이 있으며 첫 번째 IP는 실제 IP입니다. int index = ip.indexOf(“,”)
; if (index != -1) { return ip.substring(0, index); } else { return ip; } }ip = request.getHeader( X_REAL_IP); if (StringUtils.isNotEmpty (ip) && !UNKNOWN_VALUE.equalsIgnoreCase(ip)) { return ip
; } if (StringUtils.isBlank(ip) ||UNKNOWN_VALUE.equalsIgnoreCase(ip)) {ip = request.getHeader(PROXY_CLIENT_IP)
; } if (StringUtils.isBlank(ip) ||UNKNOWN_VALUE.equalsIgnoreCase(ip)) {ip = request.getHeader(WL_PROXY_CLIENT_IP)
; } if (StringUtils.isBlank(ip) ||UNKNOWN_VALUE.equalsIgnoreCase(ip)) {ip = request.getRemoteAddr()
;} if (StringUtils.isBlank(ip) ||UNKNOWN_VALUE.equalsIgnoreCase(ip)) {ip = request.getHeader(HTTP_CLIENT_IP)
; } if (StringUtils.isBlank(ip) ) ||UNKNOWN_VALUE.equalsIgnoreCase(ip)) {ip = request.getRemoteAddr()
; } return ip.equals(LOCALHOST_V6) ? LOCALHOST_V4 : ip; } }

项目推荐:基于SpringBoot2.x、SpringCloud和SpringCloudAlibaba企业级系统架构底层框架封装,解决业务开发时常见的非功能性需求,防止重复造轮子,方便业务快速开发和企业技术栈框架统一管理。引入组件化的思想实现高内聚低耦合并且高度可配置化,做到可插拔。严格控制包依赖和统一版本管理,做到最少化依赖。注重代码规范和注释,非常适合个人学习和企业使用

Github地址:github.com/plasticene/…

Gitee地址:gitee.com/plasticene3…

微信公众号:Shepherd进阶笔记

交流探讨群:Shepherd_126

3.获取ip归属地

通过上面我们就能获取到客户端用户的ip地址,接下来就可以通过ip解析获取归属地了。

如果我们在网上搜索资料教程,大部分都是说基于各大平台(eg:淘宝,新浪)提供的ip库进行查询,不过不难发现这些平台已经不怎么维护这个功能,现在处于“半死不活”的状态,根本不靠谱,当然有些平台提供可靠的获取ip属地接口,但是收费、收费、收费。

本着作为一个程序员的严谨:“能白嫖的就白嫖,避免出现要买的是你,不会用也是你的尴尬遭遇”。扯远了言归正传,为了寻求可靠有效的解决方案,只能去看看github有没有什么项目能满足需求,果然功夫不负有心人,发现一个宝藏级项目:ip2region,一个准确率 99.9% 的离线 IP 地址定位库,0.0x 毫秒级查询,ip2region.db 数据库只有数 MB的项目,提供了众多主流编程语言的 xdb 数据生成和查询客户端实现,这里只能说:开源真香,开源万岁。

3.1 Ip2region 特性

标准化的数据格式

每个 ip 数据段的 region 信息都固定了格式:国家|区域|省份|城市|ISP,只有中国的数据绝大部分精确到了城市,其他国家部分数据只能定位到国家,其余选项全部是0。

数据去重和压缩

xdb 格式生成程序会自动去重和压缩部分数据,默认的全部 IP 数据,生成的 ip2region.xdb 数据库是 11MiB,随着数据的详细度增加数据库的大小也慢慢增大。

极速查询响应

即使是完全基于 xdb 文件的查询,单次查询响应时间在十微秒级别,可通过如下两种方式开启内存加速查询:

vIndex 索引缓存 :使用固定的 512KiB 的内存空间缓存 vector index 数据,减少一次 IO 磁盘操作,保持平均查询效率稳定在10-20微秒之间。xdb 整个文件缓存:将整个 xdb 文件全部加载到内存,内存占用等同于 xdb 文件大小,无磁盘 IO 操作,保持微秒级别的查询效率。

IP 数据管理框架

v2.0 格式的 xdb 支持亿级别的 IP 数据段行数,region 信息也可以完全自定义,例如:你可以在 region 中追加特定业务需求的数据,例如:GPS信息/国际统一地域信息编码/邮编等。也就是你完全可以使用 ip2region 来管理你自己的 IP 定位数据。

99.9% 准确率

数据聚合了一些知名 ip 到地名查询提供商的数据,这些是他们官方的的准确率,经测试着实比经典的纯真 IP 定位准确一些。

ip2region 的数据聚合自以下服务商的开放 API 或者数据(升级程序每秒请求次数 2 到 4 次):

01,>80%,淘宝IP地址库,ip.taobao.com/%5C02,≈10%,GeoIP,geoip.com/%5C03,≈2%,纯真 IP 库,www.cz88.net/%5C

备注:如果上述开放 API 或者数据都不给开放数据时 ip2region 将停止数据的更新服务。

3.2 整合Ip2region客户端进行查询

提供了众多主流编程语言的 xdb 数据生成和查询客户端实现,已经集成的客户端有:java、C#、php、c、python、nodejs、php扩展(php5 和 php7)、golang、rust、lua、lua_c,nginx。这里讲一下java的客户端。

首先我们需要引入依赖:

xml

复制代码

org.lionsoulip2region2.6.5

接下来我们需要先去下载数据文件ip2region.xdb到本地,然后基于数据文件进行查询,下面查询方法文件路径改为你本地路径即可,ip2region提供三种查询方式:

完全基于文件的查询

java

复制代码

import
org.lionsoul.ip2region.xdb.Searcher;import java.io.*;import
java.util.concurrent.TimeUnit;publicclassSearcherTest {publicstaticvoidmain(String[] args) {// 1、创建 searcher 对象StringdbPath=”ip2region.xdb file path”;Searchersearcher=null;try { searcher = Searcher.newWithFileOnly(dbPath); } catch (IOException e) { System.out.printf(“failed to create searcher with `%s`: %s\\n”, dbPath, e);return; }// 2、查询try {Stringip=”1.2.3.4″;longsTime= System.nanoTime();Stringregion= searcher.search(ip);longcost=
TimeUnit.NANOSECONDS.toMicros((long) (System.nanoTime() – sTime)); System.out.printf(“{region: %s, ioCount: %d, took: %d μs}\\n”, region, searcher.getIOCount(), cost); } catch (Exception e) { System.out.printf(“failed to search(%s): %s\\n”, ip, e); }// 3、关闭资源 searcher.close();// 备注:并发使用,每个线程需要创建一个独立的 searcher 对象单独使用。 }}

缓存 VectorIndex 索引

我们可以提前从 xdb 文件中加载出来 VectorIndex 数据,然后全局缓存,每次创建 Searcher 对象的时候使用全局的 VectorIndex 缓存可以减少一次固定的 IO 操作,从而加速查询,减少 IO 压力。

java

复制代码

import
org.lionsoul.ip2region.xdb.Searcher;import java.io.*;import
java.util.concurrent.TimeUnit;publicclassSearcherTest {publicstaticvoidmain(String[] args) {StringdbPath=”ip2region.xdb file path”;// 1、从 dbPath 中预先加载 VectorIndex 缓存,并且把这个得到的数据作为全局变量,后续反复使用。byte[] vIndex;try { vIndex =
Searcher.loadVectorIndexFromFile(dbPath); } catch (Exception e) { System.out.printf(“failed to load vector index from `%s`: %s\\n”, dbPath, e);return; }// 2、使用全局的 vIndex 创建带 VectorIndex 缓存的查询对象。 Searcher searcher;try { searcher =
Searcher.newWithVectorIndex(dbPath, vIndex); } catch (Exception e) { System.out.printf(“failed to create vectorIndex cached searcher with `%s`: %s\\n”, dbPath, e);return; }// 3、查询try {Stringip=”1.2.3.4″;longsTime= System.nanoTime();Stringregion= searcher.search(ip);longcost=
TimeUnit.NANOSECONDS.toMicros((long) (System.nanoTime() – sTime)); System.out.printf(“{region: %s, ioCount: %d, took: %d μs}\\n”, region, searcher.getIOCount(), cost); } catch (Exception e) { System.out.printf(“failed to search(%s): %s\\n”, ip, e); }// 4、关闭资源 searcher.close();// 备注:每个线程需要单独创建一个独立的 Searcher 对象,但是都共享全局的制度 vIndex 缓存。 }}

缓存整个 xdb 数据

我们也可以预先加载整个 ip2region.xdb 的数据到内存,然后基于这个数据创建查询对象来实现完全基于文件的查询,类似之前的 memory search。

java

复制代码

import
org.lionsoul.ip2region.xdb.Searcher;import java.io.*;import
java.util.concurrent.TimeUnit;publicclassSearcherTest {publicstaticvoidmain(String[] args) {StringdbPath=”ip2region.xdb file path”;// 1、从 dbPath 加载整个 xdb 到内存。byte[] cBuff;try { cBuff =
Searcher.loadContentFromFile(dbPath); } catch (Exception e) { System.out.printf(“failed to load content from `%s`: %s\\n”, dbPath, e);return; }// 2、使用上述的 cBuff 创建一个完全基于内存的查询对象。 Searcher searcher;try { searcher = Searcher.newWithBuffer(cBuff); } catch (Exception e) { System.out.printf(“failed to create content cached searcher: %s\\n”, e);return; }// 3、查询try {Stringip=”1.2.3.4″;longsTime= System.nanoTime();Stringregion= searcher.search(ip);longcost=
TimeUnit.NANOSECONDS.toMicros((long) (System.nanoTime() – sTime)); System.out.printf(“{region: %s, ioCount: %d, took: %d μs}\\n”, region, searcher.getIOCount(), cost); } catch (Exception e) { System.out.printf(“failed to search(%s): %s\\n”, ip, e); }// 4、关闭资源 – 该 searcher 对象可以安全用于并发,等整个服务关闭的时候再关闭 searcher// searcher.close();// 备注:并发使用,用整个 xdb 数据缓存创建的查询对象可以安全的用于并发,也就是你可以把这个 searcher 对象做成全局对象去跨线程访问。 }}

3.3 springboot整合示例

首先我们也需要像上面一样引入maven依赖。然后就可以基于上面的查询方式进行封装成工具类了,我这里选择了上面的第三种方式:缓存整个 xdb 数据

ini

复制代码

@slf4jpublic class iputils {private static final string ip_data_path =”
/users/shepherdmy/goodtop/ip2grecion.xdb”; 개인 정적 byte [] contentbuff; 。contentBuff =Searcher.loadContentFromFile(IP_DATA_PATH)
; } catch (IOException e) { e.printStackTrace(); } } /*** IP 기반 위치 쿼리, 고정 형식: China|0|Zhejiang Province|Hangzhou City|Telecom * @param ip * @return*/ public static IpRegion getIpRegion(String ip) { Searcher searcher = null; IpRegion ipRegion = new IpRegion(); 시도해 보세요 {searcher = Searcher.newWithBuffer(contentBuff); String Region = searcher.search(ip); String[]info = StringUtils.split(region, “|”); ipRegion.setCountry(info[0]); ipRegion.setArea(info[1]); ipRegion.setProvince(info[2]); ipRegion.setCity(info[3 ]); ipRegion.setIsp(info[4]); } catch (Exception e) { log.error(“get ip 지역 오류: “, e); } finally { if (searcher != null ) { try { searcher.close(); } catch (IOException e) { log.error(“검색기 닫기 오류:”, e); } } } return ipRegion; }}

위 내용은 Douyin의 IP 위치를 쿼리하는 방법(Douyin의 IP 위치를 표시하는 방법)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 晶发科技에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
抖音商品卡是什么抖音商品卡是什么Nov 03, 2022 am 10:48 AM

商品卡是一种可在抖音关注流中直接分发的商品形态,它可以帮助商家多维度展示商品,更加突出展示商品细节及用途,让粉丝用户对商品有更多了解,提升用户浏览停留时长,从而辅助提高商品的粉丝触达率及商品转化,也可通过发布粉丝专属商品提高粉丝复购。

抖音为什么不能下载保存视频了抖音为什么不能下载保存视频了Apr 25, 2023 pm 12:12 PM

抖音不能下载保存视频的原因有:1、视频作者关闭了“允许下载”权限,没有办法解决;2、作品优质,平台限制其他用户下载,无法解除;3、网络故障所致,切换网络或重启App即可解决。

抖音怎么查看好友在线状态抖音怎么查看好友在线状态Sep 08, 2023 pm 04:58 PM

抖音查看好友在线状态方法有查看他人主页、私信聊天、查看好友动态、使用“看一看”功能等等。详细介绍:1、查看他人主页,可以通过搜索好友的名字并进入其主页中,来看到好友最新发布的视频和动态,如果好友最新发布的视频中有一些互动以及评论,那么说明好友正在抖音上活跃;2、私信聊天,通过私信聊天的方式来直接联系好友,已读就证明在线;3、查看好友动态等等方法。

一个手机号能注册几个抖音一个手机号能注册几个抖音Jun 15, 2023 pm 01:11 PM

一个手机号只能注册一个抖音,注册抖音的步骤:1、点击抖音进入主页面之后,点击页面中的“我”这一选项;2、页面将会进入登录页面,点击页面中的“其他手机号码登录”;3、切换页面之后,勾选页面上方的用户协议,再输入手机号,最后点击“验证并登录”即可注册抖音了。

抖音gmv是什么意思抖音gmv是什么意思Oct 26, 2022 pm 03:07 PM

抖音gmv是指一定时间段内成交总额,可以叫商品交易总额或者电商结算的成交总额,常用于电商平台对交易规模的衡量,换算关系“gmv=销售额+取消订单金额+拒收订单金额+退货订单金额”;gmv虽不是实际交易数据,但同样可以作为参考依据,因为只要顾客点击购买,都会统计在gmv里面。

抖音中黄v和蓝v的区别是什么抖音中黄v和蓝v的区别是什么Nov 01, 2022 am 10:42 AM

区别:1、黄v是指个人账号认证;蓝v是指企业账号认证,需要绑定企业以及公司的相关资料通过官方审核后才能认证成功。2、黄v认证设计的东西比较多,并不是每个人都可以申请的;但蓝v只要达到要求都是可以认证的。3、蓝v的权重要比黄v高,能够发放个人的产品,宣传产品等一些功能。

抖音不能下载保存视频怎么办抖音不能下载保存视频怎么办Aug 24, 2023 am 11:07 AM

抖音不能下载保存视频的解决方法:1、使用第三方应用,可以在应用商店搜索“抖音下载”或者“抖音保存”,会有很多应用提供这样的功能;2、使用屏幕录制工具,屏幕录制工具可以记录你手机屏幕上的所有操作,包括播放抖音视频,可以在应用商店搜索“屏幕录制”或者“屏幕录像”,会有很多应用提供这样的功能;3、使用链接下载,可以复制抖音视频链接,然后浏览器打开,再长按视频,选择“保存视频”。

为什么抖音清理完缓存还占内存为什么抖音清理完缓存还占内存Sep 28, 2023 pm 05:44 PM

抖音占用内存的问题是由于其工作原理和设计目标所致。其解决方法如下:1、定期清理缓存可以释放一些内存空间,从而减轻抖音对手机内存的占用;2、在手机的设置中,可以找到抖音的应用程序信息,并关闭后台运行;3、在抖音的设置中,可以选择仅在WIFI环境下下载视频,以减少对手机流量和内存的占用;4、升级手机或者购买一张内存卡,以增加可用的内存空间。

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.