Usamos cookies para medir audiência e melhorar sua experiência. Você pode aceitar ou recusar a qualquer momento. Veja sobre o iMasters.
Boa noite, é o seguinte, estou no processo de criação de um site notei que várias partes do site serão replicadas em todas as páginas, como verificação de permissão de usuários e menus, entre outras, mas por enquanto estou tentando fazer no menu, eu tentei fazer com o include_once, e deu certo porém eu usei os caminhos locais como se estivesse navegando no servidor local, porém quero utilizar os caminhos da hospedagem, poupando milhares de revisões e caquinhas que certamente farei, mas quando coloquei
include_once 'http://www.site.com.br/frameworks/cabecalho.php'. apareceu o erro, Warning: include_once(): http:// wrapper is disabled in the server configuration by allow_url_include=0 in C:\wamp64\www\site\index.php on line 17, pesquisei e vi que pessoal alterou alguns arquivos do servidor apache, mas acho que não seria o correto, até pq eu nem consigo acessar isso na hospedagem, porém deve haver alguma forma de colocar um pedaço do site vindo de outro arquivo, pois localmente funcionou, por isso pensei em um framework, mas aceito sugestões.>
22 horas atrás, Omar~ disse:
Basta que informe o caminho para o arquivo, exemplo:
include ('pasta/pasta/arquivo.php');
Vale lembrar que uma boa técnica para prever perca de diretório com inclusão basta informar onde está o arquivo a partir de onde está o arquivo atual.
Digamos então que estamos na pastaA que está dentro da pastaB que se encontra no mesmo diretório que está a pastaC ao qual lá dentro existe o arquivo para incluir.
Então a inclusão sem risco de erro seria:
include (__DIR__ . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . 'pastaC' . DIRECTORY_SEPARATOR . 'arquivo.php');
Uma outra forma mais prática e mais eficaz de trazer repetições de estruturas é criar uma ou mais classes as quais seus métodos criam o html.
Já tentei assim, mas no mas caso o arquivo vem de uma URL, eu consegui utilizando o iframe, mas daí um negócio bizarro aconteceu, dentro desse iframe, vai haver links normais até então, mas dái quando volto para a página inicial do site, onde contém o iframe e clicando na parte justamente que contém o iframe ele cria sozinho um iframe dentro de outro, mas quando recarrego a página ele some.Convenhamos, para que pegar algo que não é sua estrutura para compor parte de sua estrutura html?
Porque pelo que dar para entender é que você quer pegar parte do html alheio e anexar ao seu.
De fato não sei exatamente o que pretende, se o arquivo está em qualquer diretório de sua aplicação o include como mencionei irá funcionar sim, se for algo externo deve ficar atento pois isso irá abrir um falha de segurança ao qual o XSS pode rodar sem problemas (por isso include externo já vem bloqueado por segurança).
Em todo caso utilizar-se de classes para compor o html quando repetições forem corriqueiras é a melhor alternativa.
<?php
/ Isso seria um arquivo de classe /
class exemplo {
public function digaOla() {
$html = '<div class="ola_mundo">';
$html .= '<p>Olá mundo</p>';
$html .= '</div>';
return ($html);
}
}
/ Isso seria um arquivo separado ao qual quero um divisor e um parágrafo com o texto olá mundo assim como a classe mostra /
$html = new exemplo();
echo ($html->digaOla());
echo ($html->digaOla());
echo ($html->digaOla());
Para permitir include externo vá no arquivo PHP.INI e altere essa configuração:Porém como disse você estará metendo os pés pelas mãos abrindo breja de ataque XSS.
Será necessário permissão do servidor ao qual está tentando puxar o arquivo.
Basta que informe o caminho para o arquivo, exemplo:
include ('pasta/pasta/arquivo.php');
Vale lembrar que uma boa técnica para prever perca de diretório com inclusão basta informar onde está o arquivo a partir de onde está o arquivo atual.
Digamos então que estamos na pastaA que está dentro da pastaB que se encontra no mesmo diretório que está a pastaC ao qual lá dentro existe o arquivo para incluir.
Então a inclusão sem risco de erro seria: