所以我的网络中的客户端通过我的计算机与arpspoof连接到路由器.当我知道要停止数据包转发时,我执行:
iptables -A FORWARD -j REJECT
这是我的预期工作.但当我尝试做类似的事情时:
iptables -A FORWARD -j ACCEPT
我无法像开始那样让数据包通过.
我做错了什么或者我还应该使用与“接受”不同的任何其他论点吗?
解决方法
IPtables有一个规则列表,对于每个数据包,它按顺序检查规则列表.一旦找到匹配数据包的规则并指定策略(ACCEPT,REJECT,DROP),就确定匹配数据包的命运;没有更多的规则被审查.
这意味着您运行命令的顺序非常重要.当您使用iptables -A时,您将规则添加到规则列表的末尾,因此最终会得到如下所示的规则列表:
Chain FORWARD (policy ACCEPT) target prot opt source destination REJECT all -- anywhere anywhere reject-with icmp-host-prohibited ACCEPT all -- anywhere anywhere
由于REJECT规则在ACCEPT规则之前,它首先被触发,因此不会发生转发.
因此,您需要删除REJECTrule而不是添加ACCEPT规则.要删除REJECT规则,请运行
iptables -D FORWARD -j REJECT
有关更多信息,请阅读iptables联机帮助页.
原文地址:https://www.jb51.cc/linux/400815.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。