Wie kann ich alle Clients zwingen, den Squid-Proxy-Server am Hotspot zu verwenden?

Wie kann ich alle Clients zwingen, den Squid-Proxy-Server am Hotspot zu verwenden?

Ich habe zwei WLAN-Schnittstellen, eine ist eingebaut und die andere ist ein USB-Adapter. Zu Forschungszwecken möchte ich hostapd verwenden, um einen Hotspot zu starten und Benutzern IP-Adressen über dnsmasq zuzuweisen. Ich habe nftables gemäß dieser Anleitung verwendethttps://wiki.archlinux.org/title/Internet_sharingum das Internet mit den Kunden zu teilen.

Hier sind meine Squid-Konfigurationseinträge

http_access deny blockedsites

acl localnet src 0.0.0.1-0.255.255.255  # RFC 1122 "this" network (LAN)
acl localnet src 10.0.0.0/8     # RFC 1918 local private network (LAN)
acl localnet src 100.64.0.0/10      # RFC 6598 shared address space (CGN)
acl localnet src 169.254.0.0/16     # RFC 3927 link-local (directly plugged) machines
acl localnet src 172.16.0.0/12      # RFC 1918 local private network (LAN)
acl localnet src 192.168.0.0/16     # RFC 1918 local private network (LAN)
acl localnet src fc00::/7           # RFC 4193 local private network range
acl localnet src fe80::/10          # RFC 4291 link-local (directly plugged) machines
acl SSL_ports port 443
acl Safe_ports port 80      # http
acl Safe_ports port 21      # ftp
acl Safe_ports port 443     # https
acl Safe_ports port 70      # gopher
acl Safe_ports port 210     # wais
acl Safe_ports port 1025-65535  # unregistered ports
acl Safe_ports port 280     # http-mgmt
acl Safe_ports port 488     # gss-http
acl Safe_ports port 591     # filemaker
acl Safe_ports port 777     # multiling http
http_access deny !Safe_ports
http_access deny CONNECT !SSL_ports
http_access allow localhost manager
http_access deny manager
include /etc/squid/conf.d/*.conf
http_access allow localhost
http_access allow all
http_port 3128
coredump_dir /var/spool/squid
refresh_pattern ^ftp:       1440    20% 10080
refresh_pattern ^gopher:    1440    0%  1440
refresh_pattern -i (/cgi-bin/|\?) 0 0%  0
refresh_pattern \/(Packages|Sources)(|\.bz2|\.gz|\.xz)$ 0 0% 0 refresh-ims
refresh_pattern \/Release(|\.gpg)$ 0 0% 0 refresh-ims
refresh_pattern \/InRelease$ 0 0% 0 refresh-ims
refresh_pattern \/(Translation-.*)(|\.bz2|\.gz|\.xz)$ 0 0% 0 refresh-ims
refresh_pattern .       0   20% 4320
shutdown_lifetime 10 seconds

Alle Clients verbinden sich mit demwlan1Schnittstelle für eine Internetverbindung. Wie kann man alle Client-Anfragen über den Squid-Proxy-Server leiten? Ich bin mit der Verwendung von iptables oder anderen ähnlichen Paketen vertraut.

Antwort1

Wenn Sie mit der Verwendung von iptables vertraut sind, können Sie Ihre Frage selbst beantworten. Verwenden Sie beispielsweise DNAT für einen einfachen Port.

iptables -t nat -A PREROUTING -p tcp --dport 80 -j DNAT --to-destination <proxy IP>

(für alle Ports erforderlich)

Haftungsausschluss:

  1. Das ist, was Sie tun möchten, nämlich einen transparenten Proxy. Der gesamte Datenverkehr muss über einen (Ubuntu-)Server laufen, der die iptables-Umleitung durchführt.
  2. Das funktioniert sehr gut für http, aber nicht für https - da Sie eine Art Man-in-the-Middle-Angriff implementieren. Aber das ist leider etwas anderes und nicht Teil Ihrer Frage :-)

verwandte Informationen