AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / computer / Perguntas / 1456748
Accepted
Pritzl
Pritzl
Asked: 2019-07-07 00:51:12 +0800 CST2019-07-07 00:51:12 +0800 CST 2019-07-07 00:51:12 +0800 CST

É possível oferecer suporte a SOCKS5 para determinados hosts de forma transparente?

  • 772

Eu tenho acesso SSH a uma caixa de salto no meu trabalho. Esta caixa de salto dá acesso à infra-estrutura de rede completa no trabalho. Isso é ótimo para trabalhar em casa.

Sou capaz de executar um proxy SOCKS5 na caixa de salto (via ssh -D) e consegui configurar meu navegador para usar esse proxy SOCKS5 para hosts de trabalho (via https://getfoxyproxy.org ). Foxyproxy parece encaminhar solicitações de DNS para esse proxy SOCKS5, então tudo está funcionando bem.

Embora tudo isso funcione bem, gostaria de saber se é possível permitir que meu sistema use o SOCKS5 para tráfego relacionado ao trabalho de maneira mais transparente. É muito cansativo descobrir para cada aplicativo que uso se ele suporta SOCKS5 e, em caso afirmativo, como.

Mais concretamente, existe uma maneira de configurar meu sistema de forma que ele roteie automaticamente o tráfego via SOCKS5 para hosts predefinidos?

Eu sei que existem ferramentas como proxychains (consulte https://github.com/haad/proxychains ), mas não é isso que estou procurando. Isso roteia todo o tráfego de um aplicativo para o proxy, enquanto eu quero rotear todo o tráfego de um host para o proxy, se isso fizer sentido.

Isso é possível?

Para sua informação, fiz uma pergunta relacionada a solicitações de DNS aqui: Encaminhar solicitação de DNS para o servidor de salto do meu trabalho . Combinando esta questão com a questão do DNS, espero acabar com uma forma totalmente transparente de interagir com o trabalho.

linux networking
  • 4 4 respostas
  • 800 Views

4 respostas

  • Voted
  1. Best Answer
    user1686
    2019-07-07T01:26:07+08:002019-07-07T01:26:07+08:00

    É tecnicamente possível, embora observe que o SOCKS suporta apenas túneis TCP (e, em casos raros , UDP). Qualquer outra coisa teria que ser descartada.

    Se você usa Linux, pode usar iptables para redirecionar pacotes específicos para um proxy transparente em execução local, dos quais existem vários compatíveis com SOCKS - o Google oferece transocks , redsocks , pr0cks .

    (O sistema operacional "Tails" baseado em Tor faz o mesmo truque, mas a funcionalidade de proxy transparente agora está incorporada ao próprio daemon do Tor - não há camada SOCKS separada envolvida.)

    Para sistemas operacionais que não possuem esse suporte de "proxy transparente", ainda seria possível, mas o software poderia se tornar bastante complexo - ele poderia criar uma interface TUN virtual para a qual os pacotes poderiam ser roteados, mas precisaria lidar com todo o protocolo TCP do lado do cliente por conta própria, sem qualquer ajuda do sistema operacional. (Na verdade, o SOCKS não retransmite pacotes TCP brutos, apenas retransmite os dados contidos nele.)

    • 1
  2. Michael
    2019-07-07T16:15:49+08:002019-07-07T16:15:49+08:00

    Talvez dê uma olhada socksify. Pode funcionar particularmente bem se o proxy do seu escritório usar Dante, mas também deve funcionar bem para outras configurações.

    • 0
  3. Anderson Danilo
    2021-03-21T16:59:40+08:002021-03-21T16:59:40+08:00

    Estou usando transocks, minha configuração de tabelas de ip fica assim:

    https://gist.github.com/andersondanilo/a28e7165fa8a9700d8ead20a224ecf44

    #!/usr/bin/bash
    
    # Transocks: https://github.com/cybozu-go/transocks
    
    set -e
    stty -echoctl
    
    # Point to the transparent socket port (running in an exclusive user)
    TRANSOCKS_PORT=12345
    TRANSOCKS_USER=transocks
    
    # Redirect all the network of your computer (except transocks user)
    REDIRECT_LOCAL_NETWORK=1
    
    # Redirect access point (wifi hotspot)
    AP_SUBNET_ENABLED=1
    AP_SUBNET_IFACE=ap0
    AP_SUBNET_RANGE="192.168.12.0/24"
    
    function action_up()
    {
        echo "-----------------------------"
        echo "# Adding iptables chain rules"
        echo "-----------------------------"
        iptables -v -t nat -N TRANSOCKS
        iptables -v -t nat -A TRANSOCKS -d 0.0.0.0/8 -j RETURN
        iptables -v -t nat -A TRANSOCKS -d 10.0.0.0/8 -j RETURN
        iptables -v -t nat -A TRANSOCKS -d 100.64.0.0/10 -j RETURN
        iptables -v -t nat -A TRANSOCKS -d 127.0.0.0/8 -j RETURN
        iptables -v -t nat -A TRANSOCKS -d 169.254.0.0/16 -j RETURN
        iptables -v -t nat -A TRANSOCKS -d 172.16.0.0/12 -j RETURN
        iptables -v -t nat -A TRANSOCKS -d 192.168.0.0/16 -j RETURN
        iptables -v -t nat -A TRANSOCKS -d 198.18.0.0/15 -j RETURN
        iptables -v -t nat -A TRANSOCKS -d 224.0.0.0/4 -j RETURN
        iptables -v -t nat -A TRANSOCKS -d 240.0.0.0/4 -j RETURN
        iptables -v -t nat -A TRANSOCKS -p tcp -j REDIRECT --to-ports $TRANSOCKS_PORT
    
        if [ "$REDIRECT_LOCAL_NETWORK" = 1 ]; then
            echo "--------------------------------"
            echo "# Redirecting non-transocks user"
            echo "--------------------------------"
            iptables -v -t nat -A OUTPUT -p tcp -m owner ! --uid-owner $TRANSOCKS_USER -j TRANSOCKS
        fi
    
        if [ "$AP_SUBNET_ENABLED" = 1 ]; then
            echo "-----------------------"
            echo "# Redirecting AP subnet"
            echo "-----------------------"
            iptables -v -t nat -I PREROUTING -i $AP_SUBNET_IFACE -s $AP_SUBNET_RANGE -j TRANSOCKS
            iptables -v -I INPUT -i $AP_SUBNET_IFACE -s $AP_SUBNET_RANGE -p tcp -m tcp --dport $TRANSOCKS_PORT -j ACCEPT
        fi
    }
    
    function action_down()
    {
        if [ "$REDIRECT_LOCAL_NETWORK" = 1 ]; then
            echo "------------------------------"
            echo "# Cleaning non-transocks rules"
            echo "------------------------------"
            iptables -v -t nat -D OUTPUT -p tcp -m owner ! --uid-owner $TRANSOCKS_USER -j TRANSOCKS
        fi
    
        if [ "$AP_SUBNET_ENABLED" = 1 ]; then
            echo "--------------------------"
            echo "# Cleaning AP subnet rules"
            echo "--------------------------"
            iptables -v -t nat -D PREROUTING -i $AP_SUBNET_IFACE -s $AP_SUBNET_RANGE -j TRANSOCKS
            iptables -v -D INPUT -i $AP_SUBNET_IFACE -s $AP_SUBNET_RANGE -p tcp -m tcp --dport $TRANSOCKS_PORT -j ACCEPT
        fi
    
        echo "-----------------------------"
        echo "# Cleaning and removing chain"
        echo "-----------------------------"
        iptables -v -F TRANSOCKS -t nat
        iptables -v -X TRANSOCKS -t nat
    }
    
    trap 'action_down' SIGINT
    
    action_up
    
    echo
    echo "Hit Ctrl+C to remove the ip table rules"
    echo
    
    
    while :
    do
        sleep 1
    done
    
    • 0
  4. Mikhail Zakharov
    2022-07-04T04:49:31+08:002022-07-04T04:49:31+08:00

    Você também pode olhar para TS-Warp . Trabalhe em Linux, *BSD, mac.

    • 0

relate perguntas

  • Win10 1803: Como tornar o ponto de acesso móvel uma rede privada?

  • Como o nc identifica nomes de serviço

  • execute o contêiner do docker como root

  • Como ativar o sensor de impressão digital no domínio e no diretório ativo do Linux

  • Como alterar permanentemente Ctrl + C para Ctrl + K no CentOS 7?

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    O visualizador de fotos do Windows não pode ser executado porque não há memória suficiente?

    • 5 respostas
  • Marko Smith

    Como faço para ativar o WindowsXP agora que o suporte acabou?

    • 6 respostas
  • Marko Smith

    Área de trabalho remota congelando intermitentemente

    • 7 respostas
  • Marko Smith

    Serviço do Windows 10 chamado AarSvc_70f961. O que é e como posso desativá-lo?

    • 2 respostas
  • Marko Smith

    O que significa ter uma máscara de sub-rede /32?

    • 6 respostas
  • Marko Smith

    Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows?

    • 1 respostas
  • Marko Smith

    O VirtualBox falha ao iniciar com VERR_NEM_VM_CREATE_FAILED

    • 8 respostas
  • Marko Smith

    Os aplicativos não aparecem nas configurações de privacidade da câmera e do microfone no MacBook

    • 5 respostas
  • Marko Smith

    ssl.SSLCertVerificationError: falha na verificação do certificado [SSL: CERTIFICATE_VERIFY_FAILED]: não foi possível obter o certificado do emissor local (_ssl.c:1056)

    • 4 respostas
  • Marko Smith

    Como posso saber em qual unidade o Windows está instalado?

    • 6 respostas
  • Martin Hope
    Albin Como faço para ativar o WindowsXP agora que o suporte acabou? 2019-11-18 03:50:17 +0800 CST
  • Martin Hope
    fixer1234 O "HTTPS Everywhere" ainda é relevante? 2019-10-27 18:06:25 +0800 CST
  • Martin Hope
    Kagaratsch O Windows 10 exclui muitos arquivos minúsculos muito lentamente. Algo pode ser feito para agilizar? 2019-09-23 06:05:43 +0800 CST
  • Martin Hope
    andre_ss6 Área de trabalho remota congelando intermitentemente 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney Por que colocar um ponto após o URL remove as informações de login? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    Inter Sys Como Ctrl+C e Ctrl+V funcionam? 2019-05-15 02:51:21 +0800 CST
  • Martin Hope
    jonsca Todos os meus complementos do Firefox foram desativados repentinamente, como posso reativá-los? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK É possível criar um código QR usando texto? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 Altere o nome da ramificação padrão do git init 2019-04-01 06:16:56 +0800 CST

Hot tag

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve