[玩转系统] 使用 PowerShell 查找 IP 地理位置
作者:精品下载站 日期:2024-12-14 13:25:51 浏览:12 分类:玩电脑
使用 PowerShell 查找 IP 地理位置
因此,您已经获得了 IP 列表,并想知道它们的地理位置。
也许您在研究被黑的 Office 365 帐户时使用 Search-UnifiedAuditLog 从 Office 365 审核日志中编译了 IP 列表?或者可能来自您的 VPN 服务、受密码保护的 Extranet 或远程桌面会话列表。
无论如何,您可以使用 PowerShell 和众多免费的在线 IP 地理定位 API 之一来查找这些 IP 的地理位置。我会告诉你如何做。
地理定位查找服务的使用
ip-api 就是此类在线 IP 地理定位 API 提供商之一。 ip-api 允许您查询任何 IP 地址,并将返回带有地理位置信息的格式良好的 JSON 对象。例如,让我们尝试使用 PowerShell 查找 Whitehouse.gov:
PS C:\> Resolve-DnsName whitehouse.gov -Type A | ft Name,IPAddress
Name IPAddress
---- ---------
whitehouse.gov 23.197.12.199
PS C:\> Invoke-RestMethod -Method Get -Uri "http://ip-api.com/json/23.197.12.199"
as : AS16625 Akamai Technologies, Inc.
city : Düsseldorf
country : Germany
countryCode : DE
isp : Akamai Technologies
lat : 51.2277
lon : 6.77346
org : Akamai International, BV
query : 23.197.12.199
region : NW
regionName : North Rhine-Westphalia
status : success
timezone : Europe/Berlin
zip : 40213
DNS 主机名解析为 IP 地址,并且该 IP 地址用于对 ip-api.com 的常规 Web 查询。
毫不奇怪,whitehouse.gov 当然位于德国西部! ?
JSON 响应中返回多个属性。对于 IP 地址列表的标准取证分析,我建议抓住以下四个属性:
- 查询(正在查询的IP地址)
- 城市
- 国家
- 互联网服务供应商
分析 IP 地址列表
假设您有一长串要分析的(唯一)IP,让我们创建一个脚本,为您提供每个 IP 地址的有价值的地理信息。
为了让生活更轻松,我们首先创建一个 PowerShell 函数来客观化地理位置信息:
function Get-IPGeolocation {
Param
(
[string]$IPAddress
)
$request = Invoke-RestMethod -Method Get -Uri "http://ip-api.com/json/$IPAddress"
[PSCustomObject]@{
IP = $request.query
City = $request.city
Country = $request.country
Isp = $request.isp
}
}
现在只需针对此函数迭代 IP 列表即可。
但是——请注意! ip-api.com 提供商受到每分钟 45 次查询的限制,免受滥用!如果你超过这个限制,你的IP将被封锁,你必须登录他们的网站才能再次解锁(当你被封锁时,这并不容易!)。
由于您可能有一长串 +45 个 IP,因此我为您省去了麻烦,并创建了一个脚本,每 40 个查询将等待 70 秒(为了安全起见)。
请注意!如果您已经是 ip-api.com 的客户,则需要使用稍微不同的 URL 并将您的 API 密钥包含在请求正文中,如下所示:
$request = Invoke-RestMethod -Method Get -Uri "http://pro.ip-api.com/json/$IPAddress" -Body @{key='API_KEY'}
最终脚本如下所示:
function Get-IPGeolocation {
Param
(
[string]$IPAddress
)
$request = Invoke-RestMethod -Method Get -Uri "http://ip-api.com/json/$IPAddress"
[PSCustomObject]@{
IP = $request.query
City = $request.city
Country = $request.country
Isp = $request.isp
}
}
$OutputFile = ".\IP_GeoLocation.csv"
$i = 0
$IPs = Get-Content ".\IPs.txt"
ForEach ($IP In $IPs) {
$i++ # More than 45 queries per minute gets you banned from ip-api.com
If ($i -gt 40) {
Write-Host Just pausing a minute to avoid IP blocking from ip-api.com
Start-Sleep 70
$i = 0
}
Get-IPGeolocation($IP) | Select-Object IP, City, Country, Isp | Export-Csv $OutputFile -NoTypeInformation -Append
}
该脚本假设您有一个输入文件“IPs.txt”,其中包含唯一 IP 地址列表。
查看数据
上面的脚本生成一个 Excel 输出,可能类似于以下内容:
现在,这只是一个例子——我并不是想暗示尼日利亚有任何可疑之处。但假设您没有任何员工在该国家/地区工作或访问,则发现尼日利亚 IP 地址连接到您的 Office 365 环境(或 VPN 或远程桌面或您正在分析的任何日志文件)可能会显得很奇怪。
更深入的分析
当您识别出一个或多个可疑 IP 后,请使用它们进一步分析您的日志文件。例如,如果您正在调查 Office 365 漏洞,请将可疑 IP 放入输入文件中并运行以下脚本:
$IPs = get-content ".\Suspicious_IPs.txt"
$OutputFile = ".\UnifiedAuditLog_IPs.csv"
$EndDate = Get-Date -Date (Get-Date -Format “yyyy-MM-dd”)
$intDays = 90
For ($i=0; $i -le $intDays; $i++){
$Audit = Search-UnifiedAuditLog -EndDate $EndDate.AddDays(-$i + 1) -StartDate $EndDate.AddDays(-$i) -IPAddresses $IPs -ResultSize 5000
$ConvertAudit = $Audit | Select-Object -ExpandProperty AuditData | ConvertFrom-Json
$ConvertAudit | Select-Object CreationTime,UserId,Operation,Workload,ObjectID,SiteUrl,SourceFileName,ClientIP,UserAgent | Export-Csv $OutputFile -NoTypeInformation -Append
Write-Host $i `t $Audit.Count
}
这将生成一个输出文件,其中准确列出使用了哪些凭据以及使用可疑 IP 访问了哪些资源。这是非常有用的信息,对于进一步控制损失以及作为您想要采取法律行动的证据。
总结一下
我强烈建议主动使用此技术:如果您的用户群在地理上受到限制(某些国家或地区),您可以为关键资源设置警报,以防检测到不规则访问。
有关使用 PowerShell 分析 Office 365 审核日志的更多详细信息,请参阅这篇文章。
猜你还喜欢
- 03-30 [玩转系统] 如何用批处理实现关机,注销,重启和锁定计算机
- 02-14 [系统故障] Win10下报错:该文件没有与之关联的应用来执行该操作
- 01-07 [系统问题] Win10--解决锁屏后会断网的问题
- 01-02 [系统技巧] Windows系统如何关闭防火墙保姆式教程,超详细
- 12-15 [玩转系统] 如何在 Windows 10 和 11 上允许多个 RDP 会话
- 12-15 [玩转系统] 查找 Exchange/Microsoft 365 中不活动(未使用)的通讯组列表
- 12-15 [玩转系统] 如何在 Windows 上安装远程服务器管理工具 (RSAT)
- 12-15 [玩转系统] 如何在 Windows 上重置组策略设置
- 12-15 [玩转系统] 如何获取计算机上的本地管理员列表?
- 12-15 [玩转系统] 在 Visual Studio Code 中连接到 MS SQL Server 数据库
- 12-15 [玩转系统] 如何降级 Windows Server 版本或许可证
- 12-15 [玩转系统] 如何允许非管理员用户在 Windows 中启动/停止服务
取消回复欢迎 你 发表评论:
- 精品推荐!
-
- 最新文章
- 热门文章
- 热评文章
[影视] 黑道中人 Alto Knights(2025)剧情 犯罪 历史 电影
[古装剧] [七侠五义][全75集][WEB-MP4/76G][国语无字][1080P][焦恩俊经典]
[实用软件] 虚拟手机号 电话 验证码 注册
[电视剧] 安眠书店/你 第五季 You Season 5 (2025) 【全10集】
[电视剧] 棋士(2025) 4K 1080P【全22集】悬疑 犯罪 王宝强 陈明昊
[软件合集] 25年6月5日 精选软件22个
[软件合集] 25年6月4日 精选软件36个
[短剧] 2025年06月04日 精选+付费短剧推荐33部
[短剧] 2025年06月03日 精选+付费短剧推荐25部
[软件合集] 25年6月3日 精选软件44个
[剧集] [央视][笑傲江湖][2001][DVD-RMVB][高清][40集全]李亚鹏、许晴、苗乙乙
[电视剧] 欢乐颂.5部全 (2016-2024)
[电视剧] [突围] [45集全] [WEB-MP4/每集1.5GB] [国语/内嵌中文字幕] [4K-2160P] [无水印]
[影视] 【稀有资源】香港老片 艺坛照妖镜之96应召名册 (1996)
[剧集] 神经风云(2023)(完结).4K
[剧集] [BT] [TVB] [黑夜彩虹(2003)] [全21集] [粤语中字] [TV-RMVB]
[实用软件] 虚拟手机号 电话 验证码 注册
[资源] B站充电视频合集,包含多位重量级up主,全是大佬真金白银买来的~【99GB】
[影视] 内地绝版高清录像带 [mpg]
[书籍] 古今奇书禁书三教九流资料大合集 猎奇必备珍藏资源PDF版 1.14G
[电视剧] [突围] [45集全] [WEB-MP4/每集1.5GB] [国语/内嵌中文字幕] [4K-2160P] [无水印]
[剧集] [央视][笑傲江湖][2001][DVD-RMVB][高清][40集全]李亚鹏、许晴、苗乙乙
[电影] 美国队长4 4K原盘REMUX 杜比视界 内封简繁英双语字幕 49G
[电影] 死神来了(1-6)大合集!
[软件合集] 25年05月13日 精选软件16个
[精品软件] 25年05月15日 精选软件18个
[绝版资源] 南与北 第1-2季 合集 North and South (1985) /美国/豆瓣: 8.8[1080P][中文字幕]
[软件] 25年05月14日 精选软件57个
[短剧] 2025年05月14日 精选+付费短剧推荐39部
[短剧] 2025年05月15日 精选+付费短剧推荐36部
- 最新评论
-
- 热门tag