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 / unix / Perguntas / 777070
Accepted
jnemecz
jnemecz
Asked: 2024-05-24 21:40:45 +0800 CST2024-05-24 21:40:45 +0800 CST 2024-05-24 21:40:45 +0800 CST

Não funciona a tag `<Location/>` no host Apache Virtual

  • 772

Estou tentando criar um host virtual Apache fechado para todos os endereços IP, com exceção de um endereço IP e dois URLs que devem ser acessíveis publicamente.

<IfModule mod_ssl.c>
<VirtualHost *:443>
    ServerName example.com
    ServerAdmin [email protected]
    DocumentRoot "/var/www/example.com/app/webroot"

    <Directory "/var/www/example.com/app/webroot">
        Options FollowSymLinks Includes ExecCGI
        AllowOverride All
        ErrorDocument 403 "https://example.com/403.php"
        DirectoryIndex index.php
    </Directory>

    <Location "/foo/bar/">
          Require all granted
    </Location>

    <Location "/.well-known/">
        Require all granted
    </Location>

    <Location "/">
          Require ip 1.2.3.4
    </Location>

    SSLProxyEngine on   
    ProxyPreserveHost On
    ProxyRequests Off
    ProxyPass           /api/ https://host.docker.internal:8443/api/ connectiontimeout=5 timeout=300
    ProxyPassReverse    /api/ https://host.docker.internal:8443/api/

    SSLCertificateFile /etc/letsencrypt/live/example.com/fullchain.pem
    SSLCertificateKeyFile /etc/letsencrypt/live/example.com/privkey.pem
    Include /etc/letsencrypt/options-ssl-apache.conf
</VirtualHost>
</IfModule>

Tentei alterar a ordem das Locationtags, mas todas as solicitações são redirecionadas para ErrorDocumento valor da diretiva.

O URL /foo/bar/é reescrito por .htaccesslocalizado em DocumentRoot(para fins de teste, tentei remover .htaccesssem efeito).

Versão Apache:

  • Versão do servidor: Apache/2.4.59 (Debian)
  • Servidor construído: 2024-04-05T12:02:26

O Apache é executado em um contêiner Docker, mas provavelmente não tem significado para o problema.

P: O que há de errado com a configuração?

apache-httpd
  • 2 2 respostas
  • 39 Views

2 respostas

  • Voted
  1. sotirov
    2024-05-26T21:09:41+08:002024-05-26T21:09:41+08:00

    Ordem errada das Locationseções

    De acordo com a documentação oficial do Apache 2.4 , <Location>as seções são processadas na ordem em que aparecem no arquivo de configuração, após a leitura das <Directory>seções e arquivos e após a leitura das seções..htaccess<Files>

    O Require ip 1.2.3.4na <Location "/">seção restringe o acesso apenas a esse IP, mas as outras <Location>seções devem substituir isso para os caminhos específicos. A ordem correta deve ser:

    <Location "/">
        Require ip 1.2.3.4
    </Location>
    
    <Location "/foo/bar/">
        Require all granted
    </Location>
    
    <Location "/.well-known/">
        Require all granted
    </Location>
    

    Locationcom barra final/

    Outro problema pode ser a barra /que você tem no final do local especificado. De acordo com a documentação oficial do Apache 2.4 , as diretivas anexas serão aplicadas à solicitação se o componente do caminho da URL atender a qualquer um dos seguintes critérios:

    • O local especificado corresponde exatamente ao componente de caminho do URL.
    • O local especificado, que termina com uma barra, é um prefixo do componente de caminho da URL (tratado como uma raiz de contexto).
    • O local especificado, com a adição de uma barra final, é um prefixo do componente de caminho da URL (também tratado como raiz de contexto).

    No exemplo abaixo, onde nenhuma barra final é usada, as solicitações para e /private1terão as diretivas incluídas aplicadas, mas não o fariam./private1//private1/file.txt/private1other

    <Location "/private1">
        #  ...
    </Location>
    

    No exemplo abaixo, onde uma barra final é usada, as solicitações para /private2/e /private2/file.txtterão as diretivas incluídas aplicadas, mas /private2e /private2othernão.

    <Location "/private2/">
        # ...
    </Location>
    
    • 2
  2. Best Answer
    jnemecz
    2024-05-27T22:03:13+08:002024-05-27T22:03:13+08:00

    Houve dois problemas na minha configuração:

    1. Como @sotirov mencionou , <Location>as tags são processadas por ordem de presença - a ordem correta deve ser: restringir todo o acesso a determinados endereços IP e, seguindo <Location>as tags, permitir o acesso a locais especificados.

    2. URLS reescritos - meu URL /foo/bar/foi reescrito em .htaccesse index.php, nesta situação, o URL não corresponde ao <Location "/foo/bar/">local. Quando uso <Location "/foo.bar">a tag de localização de arquivo físico real, funciona conforme o esperado.

    • 2

relate perguntas

  • servidor httpd não compatível devido a cifras

  • Apache Logs - X-Forwarded-for juntamente com Virtualhost não registrando

  • Apache Common Document root , Diferentes hosts virtuais, Diferentes arquivos acessíveis

  • apache httpd especifica CipherSuite

  • SVN com erros de caminho de configuração do apache2

Sidebar

Stats

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

    Possível firmware ausente /lib/firmware/i915/* para o módulo i915

    • 3 respostas
  • Marko Smith

    Falha ao buscar o repositório de backports jessie

    • 4 respostas
  • Marko Smith

    Como exportar uma chave privada GPG e uma chave pública para um arquivo

    • 4 respostas
  • Marko Smith

    Como podemos executar um comando armazenado em uma variável?

    • 5 respostas
  • Marko Smith

    Como configurar o systemd-resolved e o systemd-networkd para usar o servidor DNS local para resolver domínios locais e o servidor DNS remoto para domínios remotos?

    • 3 respostas
  • Marko Smith

    apt-get update error no Kali Linux após a atualização do dist [duplicado]

    • 2 respostas
  • Marko Smith

    Como ver as últimas linhas x do log de serviço systemctl

    • 5 respostas
  • Marko Smith

    Nano - pule para o final do arquivo

    • 8 respostas
  • Marko Smith

    erro grub: você precisa carregar o kernel primeiro

    • 4 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Martin Hope
    user12345 Falha ao buscar o repositório de backports jessie 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl Por que a maioria dos exemplos do systemd contém WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky Como exportar uma chave privada GPG e uma chave pública para um arquivo 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll status systemctl mostra: "Estado: degradado" 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim Como podemos executar um comando armazenado em uma variável? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S Por que /dev/null é um arquivo? Por que sua função não é implementada como um programa simples? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 Como ver as últimas linhas x do log de serviço systemctl 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - pule para o final do arquivo 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla Por que verdadeiro e falso são tão grandes? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

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