AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 761345
Accepted
U. Windl
U. Windl
Asked: 2023-11-13 15:54:41 +0800 CST2023-11-13 15:54:41 +0800 CST 2023-11-13 15:54:41 +0800 CST

在接受 TCP 连接之前是否可以检查对等地址?

  • 772

我编写了一个简单的 Perl 服务器,它侦听 TCP 端口/套接字并接受连接。现在我想知道:

当想要实现基于地址的访问控制时,是否可以在接受连接之前检查请求连接的对等方的地址?

如果可能的话,我可以拒绝连接请求(我希望),而不是接受连接并立即再次关闭它。

perl
  • 4 4 个回答
  • 1322 Views

4 个回答

  • Voted
  1. Best Answer
    Artem S. Tashkinov
    2023-11-13T16:04:18+08:002023-11-13T16:04:18+08:00

    TCP/IP 连接由内核建立,然后您的应用程序开始使用该连接。

    过滤/阻止不需要的连接的唯一方法是使用内核防火墙。您还没有指定您的操作系统,但在 Linux 中,这将是 iptables/nftables。

    • 6
  2. jcaron
    2023-11-14T00:49:39+08:002023-11-14T00:49:39+08:00

    不是真正的答案,但一些评论太长了:

    在 MacOS X 上man accept说:

    通过发出 msg_iovlen 为 0 且 msg_controllen 非零的 recvmsg(2) 调用,或者发出 getsockopt(2) 请求,无需确认连接即可获取用户连接请求数据。类似地,可以通过发出仅提供控制信息的 sendmsg(2) 调用或通过调用 setsockopt(2) 来提供用户连接拒绝信息。

    (强调我的)

    man recvmsg但无法在或man getsockopt有关该主题的更多详细信息中找到man tcp。

    在 Debian 上,man accept说道:

    为了获得套接字上传入连接的通知,可以使用 select(2)、poll(2) 或 epoll(7)。当尝试新连接时,将传递一个可读事件,然后您可以调用accept()来获取该连接的套接字。或者,您可以将套接字设置为在套接字上发生活动时传递 SIGIO;详细信息请参见套接字(7)。

    恕我直言,那里唯一能够提供更多信息的就是epoll。

    但即使您实际上可以获得信息,我也不太确定如果您不喜欢它,您将如何拒绝连接。

    您最好在网络堆栈/防火墙级别(iptables 和朋友)进行过滤。

    • 5
  3. symcbean
    2023-11-13T18:48:34+08:002023-11-13T18:48:34+08:00

    我并不声称拥有 Perl 方面的任何专业知识 - 但我怀疑这是不可能的。为了控制对服务器的访问,我会限制(按优先顺序):

    1. 通过接口/绑定地址
    2. 通过内核防火墙(iptables、nftables、eBPF)
    3. 通过 TCP 包装器或主机配置

    鉴于目前不存在通过主机配置进行限制的设施,显然选择此作为起点似乎不寻常。

    假设上面的 1 和 2 不是一个选项,那么我建议使用 Perl 代码中的 TCP 包装器。这应该可以让您以最少的代码更改启动并运行,同时利用灵活、标准和强大的网络访问控制机制。另请参阅https://metacpan.org/pod/Net::TCPwrappers

    我相信它也可以通过在运行时调整 LD_LIBRARY_PATH (即没有任何代码更改)来应用 tcp 包装器,但在快速 Google 搜索中找不到对此的引用。

    • 1
  4. K. PANIK
    2023-11-20T05:19:58+08:002023-11-20T05:19:58+08:00

    传输控制协议不用于访问控制。

    我建议您检查 TLS https://en.m.wikipedia.org/wiki/Transport_Layer_Security

    此外,看看 netfilter 防火墙输入挂钩。您可以删除和拒绝不需要的对等方。

    • -1

相关问题

  • zabbix_sender 错误

  • cpanm 与 apt 升级

  • 匹配 CSV 文件中的可逆对

  • Perl:可以使用变量替换吗?

  • 如果总和小于特定值,则计算每 2 行的总和并用另一个值替换它们

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve