Usamos cookies para medir audiência e melhorar sua experiência. Você pode aceitar ou recusar a qualquer momento. Veja sobre o iMasters.
Olá, estou desenvolvendo um sistema de publicidade para meu site, e quando entra em uma página, vamos chama-la de "Publicidade" ele mostra uma publicidade e depois de 10 segundos ele redireciona (OBS.: Essa página já está funcionando 100%), e temos outra página que vamos chama-la de "Início", bom... Quando você entrar na página "Início" ele irá na verdade, redirecionar o usuário para a página de Publicidade, porém, como faço para a pessoa não poder pular essa publicidade, como se fosse um camuflador de página, ou seja, se o usuário acessar a página ele irá para a página "imasters.com.br/publicidade", porém se ele alterar o link para "imasters.com.br/inicio" ele irá obrigar o usuário a ver a publicidade primeiro para depois leva-lo a página de "Inicio", caso isso seja complexo de fazer, teria alguma forma de esconder o nome da página (a parte do "/inicio" por exemplo), e deixar apenas o link, por exemplo, se eu ir para a página de publicidade irá aparecer apenas o link, neste caso "imasters.com.br", e não "imasters.com.br/publicidade", caso tenha alguma dúvida sobre o meu pedido pode perguntar, não mordo rs.
Deis de já agradeço!
>
3 horas atrás, Gabriel Heming disse:
Procure por $_SESSION['HTTP_REFERER']. [http://php.net/manual/en/reserved.variables.server.php](http://php.net/manual/en/reserved.variables.server.php)
O valor será setado informando de qual página o usuário estava antes de acessar o seu endereço.
Adicionar o endereço diretamente no browser, fará com que o valor venha vazio.
Não consegui encontrar nada...>
Citar
'HTTP_REFERER'
The address of the page (if any) which referred the user agent to the current page. This is set by the user agent. Not all user agents will set this, and some provide the ability to modify HTTP_REFERER as a feature. In short, it cannot really be trusted.
>
27 minutos atrás, Gabriel Heming disse:
Infelizmente não me ajuda :d
Segundo sua descrição, no primeiro post, atende perfeitamente. O que há que não te atende?
>
2 horas atrás, Gabriel Heming disse:
Segundo sua descrição, no primeiro post, atende perfeitamente. O que há que não te atende?
Não entendi essa documentação... Sou iniciante... Ai fica complexo...
Então, não é que não te atende...
Vamos lá. A superglobal $_SERVER, possui informações do servidor. Uma delas, denominada HTTP_REFERER, indica qual é o endereço HTTP, que o usuário estava, antes de ir para o seu site.
HTTP_REFERER é preenchido pelo browser quando o usuário mudar de página através de elementos da página que esteva navegando. Ou seja, utilizar um link, um formulário e/ou um redirecionador.
Vamos ao exemplos:
Cenário 1:
- O usuário entrará na página **/publicidade**;
- A página publicidade redirecionará o usuário, via javascript, para a página **/inicio**;
- Ao acessar a página **/inicio**, a superglobal **$_SERVER['HTTP_REFERER']** estará com o valor **/publicidade**;
- Acesso normal ao site.
Cenário 2:
- O usuário acessa diretamente a página **/inicio**;
- **$_SERVER['HTTP_REFERER']** estará vazia;
- Redirecione para a página **/publicidade **e será respeitado o cenário 1.
Cenário 3
- O usuário localiza e acessa a página **/inicio** através de um motor de busca (Google, Bing, etc...);
- **$_SERVER['HTTP_REFERER']** não estará vazia, mas o valor será diferente de **/publicidade**;
- Redirecione para a página **/publicidade **e será respeitado o cenário 1.
Basicamente, é só validar se **$_SERVER['HTTP_REFERER'] ** possui o valor da URL da página de publicidade.>
56 minutos atrás, Gabriel Heming disse:
Então, não é que não te atende...
Vamos lá. A superglobal $_SERVER, possui informações do servidor. Uma delas, denominada HTTP_REFERER, indica qual é o endereço HTTP, que o usuário estava, antes de ir para o seu site.
HTTP_REFERER é preenchido pelo browser quando o usuário mudar de página através de elementos da página que esteva navegando. Ou seja, utilizar um link, um formulário e/ou um redirecionador.
Vamos ao exemplos:
Cenário 1:
- O usuário entrará na página **/publicidade**;
- A página publicidade redirecionará o usuário, via javascript, para a página **/inicio**;
- Ao acessar a página **/inicio**, a superglobal **$_SERVER['HTTP_REFERER']** estará com o valor **/publicidade**;
- Acesso normal ao site.
Cenário 2:
- O usuário acessa diretamente a página **/inicio**;
- **$_SERVER['HTTP_REFERER']** estará vazia;
- Redirecione para a página **/publicidade **e será respeitado o cenário 1.
Cenário 3
- O usuário localiza e acessa a página **/inicio** através de um motor de busca (Google, Bing, etc...);
- **$_SERVER['HTTP_REFERER']** não estará vazia, mas o valor será diferente de **/publicidade**;
- Redirecione para a página **/publicidade **e será respeitado o cenário 1.
Basicamente, é só validar se **$_SERVER['HTTP_REFERER'] ** possui o valor da URL da página de publicidade.
Seria isso?:
<?php
$site = $_SERVER['HTTP_REFERER'];
$endereco = explode("/", $site);
echo $endereco[0];
?>Em suma, sim.
Isso funciona em site com certificado SSL?
Sim, o PHP funciona indiferentemente do protocolo, essa é uma questão do servidor. A única coisa que muda é que recebera a string HTTPS ao invés de HTTP.
Vish, fui testar e não escondeu o /publicidade :d
Você também quer que não apareça o endereço /publicidade?
Aí tem que ser via .htaccess
>
6 horas atrás, Gabriel Heming disse:
Você também quer que não apareça o endereço /publicidade?
Aí tem que ser via .htaccess
Pois é.. acho que vou deixar queto.. Vai ser meio complicado pra alguém que é iniciante rs
Porque não crias uma classe? e chamas o objecto em todas as paginas e validas isso com um cookie com tempo de X. E quando o tempo vai acabar vai ser mostrada a propaganda de novo. Tem de criar algo tmb para detectar se os cookies são activados no browser do utilizador.
Comprimentos, Dimitry.
>
4 horas atrás, Dimitry disse:
Porque não crias uma classe? e chamas o objecto em todas as paginas e validas isso com um cookie com tempo de X. E quando o tempo vai acabar vai ser mostrada a propaganda de novo. Tem de criar algo tmb para detectar se os cookies são activados no browser do utilizador.
Comprimentos, Dimitry.
Vai ser complicado... :d