iptables端口转发,wireshark抓包分析

app发送请求,到安全交互平台访问服务,app发送请求的ip地址是基站随机分配的,ip地址被拉黑了怎么访问?解决办法?

一开始考虑使用nginx作为代理服务器转发请求,后来在服务器用端口转发解决。

  • 修改nginx配置文件,新加Serve,监听端口19000,serve_name为服务器IP地址,proxy_pass为现场安交ip地址:端口(20081)

  • 对应安全交互表中iscpip和port

  • app端根据安交表测试地点填写iscip和port端口号

  • 考虑直接使用端口转发,更加高效,不使用nginx服务器

  • TCP 端口转发,从19000端口接收到的数据请求转发到20081端口(目的端口),通过 iptables 命令实现。

  • 首先,需要启用 IP 转发。在 /etc/sysctl.conf 文件中添加以下行:

    net.ipv4.ip_forward=1

  • 添加 iptables 规则以进行端口转发。将所有发往 19000端口的流量转发到iscpip的20081端口上:

    iptables -t nat -A PREROUTING -p tcp --dport 19000 -j DNAT --to-destination xxx.xxx.xxx.xxx:20081

  • 保存iptabels规则

    iptables-save > /etc/sysconfig/iptables

  • 查看规则

    iptables -t nat -nL ---line //查看当前表的规则

  • 开启网卡放行转发(不开放抓包会发现没有ip.des==iscpip的数据包)

    #eth0改为实际使用网卡(一般是eth0)

    放行Forward的数据包

    iptables -I FORWARD -i eth0 -j ACCEPT

    开启网卡混杂模式(允许任意流向的数据包)

    iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE

  • telnet测试端口是否可以访问(一个网络应用程序一定会占用一个端口)

    telnet 服务器IP地址 19000
    telnet iscpip 20081

  • 配置成功后尝试在服务器,发起一个页面请求,看能否成功,拦截?不从app发请求

    crul 服务器ip地址:端口/接口页面请求

无返回信息,失败,发起请求必须是客户端

  • 使用tcpdump命令抓包
    例子:抓取主机172.0.0.1的eth0网口的8080、8081端口传输的数据包并保存文件1.pcap

    tcpdump -i eth0 -s0 -w 1.pcap

  • 按 crtl+c 停止抓包,当前目录会生成一个20230811-all.pcap文件

  • 使用wireshark软件分析查找ip.des==iscpip的包,目的端口为20081,源头端口为安排的随机端口

  • 源ip为阿里云内网IP,服务器ip为公网ip

  • 顺便利用wireshark来理解三次握手

    • 第一次握手:app应用程序端serve地址:223.104.4.48---->转发请求到服务器172.19.216.81:19000端口---->iscpip地址218.22.14.12:20082端口。SYN=1,Seq=0

    • 第二次握手:iscpip地址218.22.14.12:20082端口---->服务器172.19.216.81:19000端口---->app应用程序端serve地址:223.104.4.48。SYN=1,ACK=1,Seq=0,ack=1

    • 第三次握手:app应用程序端serve地址:223.104.4.48---->服务器172.19.216.81:19000端口---->iscpip地址218.22.14.12:20082端口。ACK=1,Seq=1,ack=1

    • Push标志位指在数据包到达接收端以后,立即传送给应用程序,而不是在缓冲区中排队;

  • 可是如果服务器的ip地址也被拉黑了,怎么办呢?岂不是需要有备用服务器?不停的换新ip?

相关推荐
努力搬砖的咸鱼1 天前
容器之间怎么通信?Docker 网络全解析
网络·docker·云原生·容器
电鱼智能的电小鱼1 天前
基于电鱼 ARM 工控机的井下AI故障诊断方案——让煤矿远程监控更智能、更精准
网络·arm开发·人工智能·算法·边缘计算
安冬的码畜日常1 天前
【JUnit实战3_20】第十一章:用 Gradle 运行 JUnit 测试实战
测试工具·junit·单元测试·gradle·软件构建·groovy·junit5
AC是你的谎言1 天前
HTTP和HTTPS
linux·网络·c++·网络协议·学习·http·https
张永清-老清1 天前
每周读书与学习->JMeter主要元件详细介绍(三)逻辑控制器
测试工具·jmeter·压力测试·性能调优·jmeter性能测试·性能分析·每周读书与学习
刀客Doc1 天前
刀客doc:亚马逊和谷歌的广告战争,开始打到云上了
网络
程序员三藏1 天前
如何使用Selenium做自动化测试?
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
海域云赵从友1 天前
办公室无缝访问海外AWS:中国企业全球化数据协作的组网之道
网络
KKKlucifer1 天前
当UAF漏洞敲响提权警钟:技术剖析与应对之道
网络·安全
-曾牛1 天前
深入理解XXE外部实体注入漏洞:原理、利用与防护
网络·安全·网络安全·渗透测试·xxe·漏洞原理·owaspf