Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

icarof

Passagem de Parametros e Reescrita de URL

Recommended Posts

Olá amigos

Estou em vias de desenvolvimento de uma sistema web e também pretendo apresenta-lo na dissertação da Pós-graduação, pois bem um problema vem incomodando bastante.

sempre usei uma padrão nas urls,(talvez até gamby) mas sem funcionava.

portal.php?link=pagina&parametr=

ai de boa, via get recebo a requisição e funciona tudo as mil maravilhas.

mas ai comecei a ver essa URL de forma feia, e depois de vencer a preguiça fui atras de URLs amigaveis, para que o padrão ficasse

portal/pagina/1

Todos os tutoriais que achei, ensinam a modificaras URL, mas quando parte para a passagem dos parâmetros não funciona nada, e visto que há telas onde se passa mais de 2 parâmetros pela URL.

nessa aulas, vi alguns htaccess que me deixaram mais confuso que entedido.

RewriteEngine on
RewriteCond %{SCRIPT_FILENAME} !-f
RewriteCond %{SCRIPT_FILENAME} !-d
RewriteRule ^(.*)$ index.php?url=$1

esse primeiro ai, que valida pela index.php

<html>
	<head>
		<title>Home</title>
		<meta charset="utf-8">
	</head>
	<body>
		<?php
		
			$url = (isset($_GET['url'])) ? $_GET['url']:'home.php';
			$url = array_filter(explode('/',$url));
			
			$file = $url[0].'.php';
			var_dump($url);
			if(is_file($file)){
				include $file;
			}else{
				include '404.php';
			}			
		?>
	</body>
</html>

com esse código passa a URL modificada, mas não passa os parametros, tanto que mesmo com o codigo funcionando ele joga pra pagina 404, pos entende que a variavel esta vazia.

ja este aqui, que na aula passa os parametros

RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^index2-([0-9]+)-(.*)$ index2.php?id=$1&amp;titulo=$2

não funciona de forma alguma.

 

Ai me fica esse circo, não consigo modificar as URLS e nem encontar uma boa solução, alguem tem alguma dica, tutorial ou semelhante?

Compartilhar este post


Link para o post
Compartilhar em outros sites

Acredito que o que procuras seja o código abaixo:

<IfModule mod_rewrite.c>
    RewriteEngine On
    RewriteBase /
    RewriteCond %{REQUEST_FILENAME} !-f
    RewriteCond %{REQUEST_FILENAME} !-d
    RewriteRule ^(.*)$ index.php/$1 [L]
</IfModule>

Options -Indexes

Entretanto, antes de qualquer coisa, é necessário entender o que ele faz, para entender qual é a "mágica" por trás da reescrita de URL

 

Condicional para o código ser executado apenas se o módulo mod_rewrite.c estiver habilitado/instalado.

<IfModule mod_rewrite.c> /** ... **/</IfModule>

O código abaixo habilita a reescrita

RewriteEngine On

 

Aqui, você deve definir qual é o base path do diretório para reescrita:

RewriteBase /

Ou seja, se a sua URL é http://www.site.com/, o RewriteBase será apenas "/" ou pode ser omitido (pois, é o root). Entretanto, se for  http://www.site.com/pasta/subpasta/ o RewriteBase será "/pasta/subpasta/" e não pode ser omitido. É importante entender a base, pois, ela será base da regra de reescrita (RewriteRule).

 

Ambos abaixo são condicionais, ou seja, são if's. Se algum deles não for verdadeiro, a regra seguinte é ignorada.

RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d

Basicamente, as condições são as seguintes:

- O arquivo de requisição (%{REQUEST_FILENAME}) não pode (sendo a exclação a negação) ser um arquivo no servidor (-f);

- O arquivo de requisição (%{REQUEST_FILENAME}) não pode (sendo a exclação a negação) ser um diretório no servidor (-d).

 

Após satisfazer todas as regras, vem a condição: 

RewriteRule ^(.*)$ index.php/$1 [L]

A regra, basicamente, é uma expressão regular de reescrita. Antes de entender como a regra de reescrita funciona, é preciso entender o que ele está reescrevendo.

 

Se lembra, lá em cima, sobre o RewriteBase. Aqui é onde ele se torna parâmetro de reescrita. Vamos supor o seguinte, utilizando a seguinte URL: https://forum.imasters.com.br/topic/566119-passagem-de-parametros-e-reescrita-de-url/

 

Esta URL é a própria deste tópico. Sendo o RewriteBase o root (apenas "/"), tudo que vier depois, é o que será reescrito, ou seja: topic/566119-passagem-de-parametros-e-reescrita-de-url/

 

Depois de entender isso, fica fácil entender a RewriteRule.

 

- ^(.*)$ -> expressão regular. Indica que deve "casar" (match) toda a string, ou seja, tudo que vier após o RewriteBase.

- index.php/$1 -> Indica que deverá ser enviado para index.php/(tudo que casou na expressão regular anterior).

 

Ou seja, você entrará com a seguinte URL:

https://forum.imasters.com.br/topic/566119-passagem-de-parametros-e-reescrita-de-url/

E o APACHE reescreverá e interpretará como:

https://forum.imasters.com.br/index.php/topic/566119-passagem-de-parametros-e-reescrita-de-url/

 

Já, no index.php, você precisará do seguinte código para receber a interpretar as variáveis:

$urlParameters = isset($_SERVER['PATH_INFO']) ? $_SERVER['PATH_INFO'] : (isset($_SERVER['ORIG_PATH_INFO']) ? $_SERVER['ORIG_PATH_INFO'] : '');
$urlParameters = preg_replace('@^/@' , '' , $urlParameters);
$urlParameters = preg_replace('@/$@' , '' , $urlParameters);

Usando o mesmo exemplo de URL, o código acima interpretará a URL da seguinte forma:

array(2) {
    [0]=> string(5) "topic"
    [1]=> string(48) "566119-passagem-de-parametros-e-reescrita-de-url"
}

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Gabriel, seguindo sua explicação e uns tutoriais consegui fazer roda uma pouco, parecido com o que você desmontrou

	$url = (isset($_GET['url'])) ? $_GET['url'] : 'home';
	$url = array_filter( explode('/', $url) );

	$file = $url[0].'.php';

	if (is_file($file)) {
		include $file;
	}
	else{
		include '404.php';
	}

funciona parecido como o seu, agora me fala, como posso trabalhar com os outros índices do Array, para poder passar os valores?

meu htaccess ficou assim:

RewriteEngine on
RewriteCond %{SCRIPT_FILENAME} !-f
RewriteCond %{SCRIPT_FILENAME} !-d
RewriteRule ^(.*)$ index.php?url=$1 [QSA]

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

@icarof

Achei a explicação do @Gabriel Heming muito boa, mas eu utilizo de outra forma já a muito tempo e funciona perfeitamente pra mim, não sei se te ajudará ou não.

 

### URLs Amigaveis ###
RewriteEngine on

RewriteRule ^URL_DESEJADA$ /URL_DESEJADA/ [R]
RewriteRule ^URL_DESEJADA/$ /URL_DESEJADA.php [PT]
RewriteRule ^URL_DESEJADA/([A-Za-z0-9_-]+)$ /URL_DESEJADA/$1/ [R]
RewriteRule ^URL_DESEJADA/([A-Za-z0-9_-]+)/$ /URL_DESEJADA.php?destino=$1 [PT]

No caso, sempre que necessito passar mais de um parâmetro em alguma URL específica, eu altero as linhas 3 e 4 colocando  mais quantas variáveis vou precisar.

Sei que não chega aos pés da aula do acima, mas espero que ajude de alguma forma.

 

Abraço!

Compartilhar este post


Link para o post
Compartilhar em outros sites

Rasp, ja tentei dessa forma, mas o quando faço a navegação os endereços se misturam, tipo to em

site/blog

ai vou em contato

deveria ficar site/contato

mas fica sempre

site/blog/contato

Compartilhar este post


Link para o post
Compartilhar em outros sites
13 horas atrás, icarof disse:

Rasp, ja tentei dessa forma, mas o quando faço a navegação os endereços se misturam, tipo to em

site/blog

ai vou em contato

deveria ficar site/contato

mas fica sempre

site/blog/contato

 

 @icarof isso acontece pois seus links não estão utilizando a tag base, todos os seus links devem ser /endereço_do_link/, com isso, eles irão retornar sempre a base www.dominio.com.br/, sacou?

Compartilhar este post


Link para o post
Compartilhar em outros sites
12 horas atrás, Rasp disse:

 

 @icarof isso acontece pois seus links não estão utilizando a tag base, todos os seus links devem ser /endereço_do_link/, com isso, eles irão retornar sempre a base www.dominio.com.br/, sacou?

acho que estou etendo um pouco, no caso, a barra antes do link, passa a utilizar o endereço base?

Compartilhar este post


Link para o post
Compartilhar em outros sites

Existem algumas formas, como, utilizar uma variável base (leia sobre canonical path):

 

Ou utilizar a meta tag base:

https://developer.mozilla.org/en-US/docs/Web/HTML/Element/base

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por Rafael_Ferreira
      Não consigo carregar a imagem do captcha do meu formulário. Foi testado com o xampp e easyphp. Também não carregou a imagem de outros captcha. 
       
       
    • Por luiz monteiro
      Olá, tudo bem?
       
      Estou melhorando meu conhecimento em php e mysql e, me deparei com o seguinte. A tabela da base de dados tem um campo do tipo varchar(8) o qual armazena números. Eu não posso alterar o tipo desse campo. O que preciso é fazer um select para retornar o números que contenham zeros a direita ou a esquerda.
      O que tentei até agora
       
      Ex1
      $busca = $conexao->prepare("select campo form tabela where (campo = :campo) ");
      $busca->bindParam('campo', $_REQUEST['campo_form']);
       
      Se a direita da string $_REQUEST['campo_form'] termina ou inicia com zero ou zeros, a busca retorna vazio.
      Inseri dados numéricos, da seguinte maneira para testar: 01234567;  12345670: 12345678: 12340000... entre outros nessa coluna. Todos os valores que não terminam ou não iniciam com zero ou zeros, o select funciona.
       
       
      Ex2
      $busca = $conexao->prepare("select campo form tabela where (campo = 0340000) ");
      Esse número está cadastrado, mas não retorna.
       
      Ex3
      $busca = $conexao->prepare("select campo form tabela where (campo = '02340001' ) ");
      Esse número está cadastrado, mas não retorna.
       
       
      Ex4
      $busca = $conexao->prepare("select campo form tabela where (campo like 2340000) ");
      Esse número está cadastrado, mas não retorna.
       
      Ex5
      $busca = $conexao->prepare("select campo form tabela where (campo like '12340000') ");
      Esse número está cadastrado, mas não retorna.
       
      Ex6
      $busca = $conexao->prepare("select campo form tabela where (campo like '"12340000"' ) ");
      Esse número está cadastrado, mas não retorna.
       
       
      Ex7
      $busca = $conexao->prepare("select campo form tabela where (campo like :campo) ");
      $busca->bindParam('campo', $_REQUEST['campo_form'])
      Não retorna dados.
       
      O  $_REQUEST['campo_form'] é envio via AJAX de um formulário. 
      Usei o gettype para verificar o post, e ele retorna string.
      Fiz uma busca com número 12345678 para verificar o que o select retorna, e também retrona como string.
       
      Esse tipo de varchar foi usado porque os números que serão gravados nesse campo,  terão zeros a direita ou na esquerda. Os tipos number do mysql não gravam zeros, então estou usando esse. O problema é a busca.
      Agradeço desde já.
       
       
    • Por daemon
      Boa tarde,
       
      Eu tenho uma rotina que faz uma leitura do arquivo .xml de vários sites.

      Eu consigo pegar o tópico e a descrição, e mostrar a imagem que esta na pagina do link.
      Para isso utilizo esta função:
      function getPreviewImage($url) { // Obter o conteúdo da página $html = file_get_contents($url); // Criar um novo objeto DOMDocument $doc = new DOMDocument(); @$doc->loadHTML($html); // Procurar pela tag meta og:image $tags = $doc->getElementsByTagName('meta'); foreach ($tags as $tag) { if ($tag->getAttribute('property') == 'og:image') { return $tag->getAttribute('content'); } } // Se não encontrar og:image, procurar pela primeira imagem na página $tags = $doc->getElementsByTagName('img'); if ($tags->length > 0) { return $tags->item(0)->getAttribute('src'); } // Se não encontrar nenhuma imagem, retornar null return null; } // Uso: $url = "https://example.com/article"; $imageUrl = getPreviewImage($url); if ($imageUrl) { echo "<img src='$imageUrl' alt='Preview'>"; } else { echo "Nenhuma imagem encontrada"; }  
      Mas estou com um problema, esta funcão funciona quando coloco em uma pagina de teste.php. Preciso mostrar em uma página inicial diversas fotos de todos os links. (No caso acima só funciona 1).
    • Por violin101
      Caros amigos, saudações.
       
      Por favor, me permita tirar uma dúvida com os amigos.

      Tenho um Formulário onde o Usuário digita todos os Dados necessários.

      Minha dúvida:
      --> como faço após o usuário digitar os dados e salvar, o Sistema chamar uma Modal ou mensagem perguntando se deseja imprimir agora ?

      Grato,
       
      Cesar
    • Por Carcleo
      Tenho uma abela de usuarios e uma tabela de administradores e clientes.
      Gostaria de uma ajuda para implementar um cadastro
       
      users -> name, login, passord (pronta) admins -> user_id, registratiom, etc.. client -> user_id, registratiom, etc...
      Queria ajuda para extender de user as classes Admin e Client
      Olhem como estáAdmin
      <?php namespace App\Models; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Model; class Admin extends User {     use HasFactory;            protected $fillable = [         'name',         'email',         'password',         'registration'     ];      private string $registration;     public function create(         string $name,          string $email,          string $password,         string $registration     )     {         //parent::create(['name'=>$name, 'email'=>$email, 'password'=>$password]);         parent::$name = $name;         parent::$email = $email;         parent::$password = $password;         $this->registration = $registration;     } } User
      <?php namespace App\Models; // use Illuminate\Contracts\Auth\MustVerifyEmail; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Foundation\Auth\User as Authenticatable; use Illuminate\Notifications\Notifiable; use Illuminate\Database\Eloquent\Relations\BelongsToMany; class User extends Authenticatable {     /** @use HasFactory<\Database\Factories\UserFactory> */     use HasFactory, Notifiable;     static string $name;     static string $email;     static string $password;     /**      * The attributes that are mass assignable.      *      * @var list<string>      */     protected $fillable = [         'name',         'email',         'password',     ];          /**      * The attributes that should be hidden for serialization.      *      * @var list<string>      */     protected $hidden = [         'remember_token',     ];     /**      * Get the attributes that should be cast.      *      * @return array<string, string>      */     protected function casts(): array     {         return [             'email_verified_at' => 'datetime',             'password' => 'hashed',         ];     }          public function roles() : BelongsToMany {         return $this->belongsToMany(Role::class);     }       public function hasHole(Array $roleName): bool     {                 foreach ($this->roles as $role) {             if ($role->name === $roleName) {                 return true;             }         }         return false;     }         public function hasHoles(Array $rolesName): bool     {                 foreach ($this->roles as $role) {             foreach ($rolesName as $rolee) {             if ($role->name === $rolee) {                 return true;             }          }         }         return false;     }         public function hasAbility(string $ability): bool     {         foreach ($this->roles as $role) {             if ($role->abilities->contains('name', $ability)) {                 return true;             }         }         return false;     }     } Como gravar um Admin na tabela admins sendo que ele é um User por extensão?
      Tentei assim mas é claro que está errado...
      public function store(Request $request, Admin $adminModel) {         $dados = $request->validate([             "name" => "required",             "email" => "required|email",             "password" => "required",             "registration" => "required"         ]);         $dados["password"] =  Hash::make($dados["password"]);                  $admin = Admin::where("registration",  $dados["registration"])->first();                  if ($admin)              return                    redirect()->route("admin.new")                             ->withErrors([                                 'fail' => 'Administrador já cadastrados<br>, favor verificar!'                   ]);                            $newAdmin = $adminModel->create(                                    $dados['name'],                                    $dados['email'],                                    $dados['password'],                                    $dados['registration']                                 );         dd($newAdmin);         $adminModel->save();         //$adminModel::create($admin);                  return redirect()->route("admin.new")->with("success",'Cadastrado com sucesso');     }  
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.