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
    • 最新
    • 标签
主页 / server / 问题 / 107117
In Process
Ali Burak Kulakli
Ali Burak Kulakli
Asked: 2010-01-29 01:23:32 +0800 CST2010-01-29 01:23:32 +0800 CST 2010-01-29 01:23:32 +0800 CST

检查点上的手动 NAT(将所有 http 请求重定向到本地 Web 服务器)

  • 772

我们的内部网络中有一个代理服务器,我想将所有 Internet http 请求重定向到本地网络中的 Web 服务器。它就像一个网络广告牌,上面写着“没有可用的直接连接。设置您的代理等。” 例如:

  • 用户启动计算机
  • 打开浏览器
  • 尝试打开 www.google.com
  • 应该在本地网络上看到 Web 服务器输出
  • 尝试互联网上的另一个网站
  • 应该在本地网络上看到 Web 服务器输出
  • 设置代理
  • 尝试连接到网站
  • 应该加载网站

我添加了一个简单的手动 NAT 规则来解决检查点防火墙中的地址转换,但它根本不起作用。这是我的地址翻译规则

Source Destination Service T.Source T.Destination T.Service
MY_PC  A_GOOGLE_IP ALL     ORIGINAL INT_WEB_SRV   ORIGINAL

然后当我 ping 时A_GOOGLE_IP,回复来自INT_WEB_SRV,正如我所料。但是,当我尝试A_GOOGLE_IP 从浏览器 ( http://A_GOOGLE_IP ) 进行连接时,SYN_SENT 没有回复并陷入超时。当我查看防火墙日志时INT_WEB_SRV,我可以看到来自 MY_PC 的传入连接请求被接受并且没有拒绝。顺便说一句,从浏览器中查看INT_WEB_SRV(http://INT_WEB_SRV )没有问题。

我的理解是,我在检查点 NGX R60 的 NAT 规则不包括返回数据包。我肯定需要一些帮助。

http nat proxy web-server checkpoint
  • 3 3 个回答
  • 4696 Views

3 个回答

  • Voted
  1. JakeRobinson
    2010-07-24T08:54:42+08:002010-07-24T08:54:42+08:00

    当遇到 NAT 问题时,我总是先打开几个 SSH 会话并在内部和外部接口上执行 tcpdumps。

    就像是:

    tcpdump -i eth0 proto ICMP
    

    或者

    tcpdump -i eth0 host A_GOOGLE_IP
    

    并观察 Nat'd IP 地址是什么。这至少应该给你一个开始的地方!

    • 1
  2. Cian
    2012-06-17T04:46:25+08:002012-06-17T04:46:25+08:00

    检查点的返回流量应该是 natted。流量是否显示在网络服务器的服务器日志中?此外,值得使用 fw 监视器,以确保检查点正确导航,并双向传递流量,例如

    fw monitor -e 'accept (src=<host address> and dport=80) or (dst=<host address> and sport=80);'
    

    这应该为每个数据包显示 4 行,包括 NAT 前地址和 NAT 后地址。

    • 0
  3. Pentium100
    2013-10-23T21:23:00+08:002013-10-23T21:23:00+08:00

    如果内部服务器与客户端在同一个子网中,则需要进行 SNAT 和 DNAT,因为现在,它是这样工作的。

    iptables -t nat -A PREROUTING -i LAN_IFACE -d A_GOOGLE_IP -j DNAT --to-destination INT_WEB_SRV
    
    • 客户端 PC 发送 TCP SYN 到 A_GOOGLE_IP
    • 路由器 DNAT 将其发送到 INT_WEB_SRV
    • INT_WEB_SRV 看到来自 LAN IP 的请求并直接回复
    • 客户端收到来自 INT_WEB_SRV IP 而非 A_GOOGLE_IP 的回复

    如果你 SNAT,那么它的工作原理是这样的:

    iptables -t nat -A PREROUTING -i LAN_IFACE -d A_GOOGLE_IP -j DNAT --to-destination INT_WEB_SRV
    iptables -t nat -A POSTROUTING -s LAN_RANGE/mask -d INT_WEB_SRV -j SNAT --to-source ROUTER_IP
    
    • 客户端 PC 发送 TCP SYN 到 A_GOOGLE_IP
    • 路由器 DNAT 将其发送到 INT_WEB_SRV 用自己的 IP 替换源 IP
    • INT_WEB_SRV 看到来自路由器的请求并回复它。
    • 路由器将数据包 DNAT 发送到客户端 PC,并将源 IP 替换为 A_GOOGLE_IP
    • 客户端认为它连接到 A_GOOGLE_IP

    但是,如果您只想强制所有人使用代理,只需 DNAT 到代理服务器的所有传出 HTTP 连接(您将获得所谓的透明代理),客户端无需更改其计算机上的设置.

    • 0

相关问题

  • 设置 http 代理以使用 Web 界面?

  • 无法连接到 Ubuntu Desktop 中的端口 80 或 VMWare Workstation 6.52 中的 Server 9.04

  • IIS 7.5 (Windows 7) - HTTP 错误 401.3 - 未经授权

  • 为什么有些网站的网址中没有“www”就无法显示?[关闭]

  • Tomcat 6 HTTP 日志滚动和清除

Sidebar

Stats

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

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve