如何简单判断某个port是否被防火墙block

在存储系统中经常遇到要上传一些code到存储中做升级,但是通过客户网络死活搞不定的情况,其实很多时候是由于客户内部有防火墙的设置,某些端口是被block屏蔽的。本文就介绍几个命令用来快速判断是否这些port被客户做了block。如果确认是被block了,要么就想其他办法,不要通过网络了,直连存储,usb或者找客户网络部门暂时打开这个port。

需要进一步沟通,可添加 vx: StorageExpert

1. 使用 Telnet 工具

  • 步骤:
    1. 打开命令行终端(Windows 下是 CMD,Linux/MacOS 下是终端)。
    2. 输入 telnet <目标IP地址> <端口号>,例如 telnet 192.168.1.1 80。
    3. 如果端口开放且未被防火墙阻止,连接会成功。如果端口被阻止,可能会显示连接失败或超时。

PS C:\IPMItool> telnet 192.168.31.99 5000

Trying 192.168.31.99...

Connected to 192.168.31.99.

Escape character is '^]'.

Connection closed by foreign host.

PS C:\IPMItool>

2. 使用 Netcat(nc)工具

  • Netcat 是一个功能强大的网络工具,可以用于测试端口连通性。
  • 步骤:
    1. 在 Linux/MacOS 系统中,输入 nc -zv <目标IP地址> <端口号>。
    2. 在 Windows 系统中,可以使用 ncat -zv <目标IP地址> <端口号>(Ncat 是 Netcat 的一个版本)。

在windows中默认是没有这个工具的,需要单独安装才可以,所以也不是一个灵活简单的工具。windows中如果要安装,也是去nmap.org去下载nmap软件。

  1. 如果端口开放,工具会显示“成功连接”消息;如果被阻止,会显示“连接失败”或“超时”。

3. 使用 Nmap 扫描

  • Nmap 是一个功能强大的网络扫描工具,可以用来检测开放的端口。
  • 步骤:
    1. 安装 Nmap(可以在 Nmap官网 下载)。
    2. 使用命令 nmap -p <端口号> <目标IP地址> 进行扫描。例如:nmap -p 80 192.168.1.1。
    3. 扫描结果会显示端口是“open”还是“filtered”。“filtered”意味着端口可能被防火墙屏蔽。

4. 使用 PowerShell(Windows 环境)

  • Windows 用户可以使用 PowerShell 测试端口连通性。
  • 步骤:
    1. 打开 PowerShell。
    2. 输入 Test-NetConnection -ComputerName <目标IP地址> -Port <端口号>。
    3. 结果会显示端口是否开放。如果 TcpTestSucceeded 为 True,表示端口未被阻止;如果为 False,可能表示被防火墙阻止。

PS C:\IPMItool> test-netconnection -computername 13.107.4.52 -port 5000

警告: TCP connect to (13.107.4.52 : 5000) failed

ComputerName           : 13.107.4.52

RemoteAddress          : 13.107.4.52

RemotePort             : 5000

InterfaceAlias         : WLAN

SourceAddress          : 192.168.31.102

PingSucceeded          : True

PingReplyDetails (RTT) : 88 ms

TcpTestSucceeded       : False

5. 直接在防火墙规则中检查

  • 如果你有对防火墙设备的访问权限,可以直接检查防火墙配置,看是否有阻止该端口的规则。
  • 例如,在 Linux iptables 中,可以使用 iptables -L -n -v 查看当前规则。

window.open跨域拦截是指在前端开发中,当使用window.open方法打开一个跨域的URL时,浏览器会默认进行拦截,以保护用户隐私和安全。这是因为跨域访问可能导致一些潜在的安全问题,如恶意脚本注入、数据泄露等。 浏览器拦截跨域打开URL的方式是通过Same-Origin Policy(同源策略)来实现的。同源策略要求打开的URL与当前页面具有相同的协议、域名和端口,否则就被认为是跨域访问。 如果要在前端中突破跨域限制打开一个跨域的URL,可以考虑以下几种方法: 1. 使用代理:通过在自己的后端服务器上设置代理接口,将跨域请求发送到目标URL,在后端进行请求并返回结果给前端。这样前端实际请求的是同源的接口,避免了跨域问题。 2. 跨文档通信(PostMessage):可以使用window.postMessage方法在不同窗口(甚至跨域)之间进行通信。通过在目标窗口中监听message事件,接收并处理消息,可以实现跨域通信和数据传递。 3. 使用CORS(跨域资源共享):如果目标URL的服务器支持CORS,可以在响应头中添加Access-Control-Allow-Origin字段,允许指定域名或通配符来接受跨域请求。 4. JSONP:如果目标URL的服务器支持JSONP(JSON with Padding),可以通过动态创建script标签,指定src为目标URL,并在URL中传递一个回调函数的名称。服务器返回的响应数据会作为回调函数的参数传入,从而实现跨域请求和数据获取。 5. WebSocket:WebSocket协议可以在不受同源策略限制的情况下进行跨域通信,可以使用WebSocket API进行跨域数据传输和实时通信。 这些方法可以根据具体需求选择使用,具体选择哪种方式要根据项目的需求和安全考虑来决定。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值