Ir para conteúdo

POWERED BY:

Jack Oliveira

[RESOLVIDO] Url Amigavél

Recommended Posts

Ola pessoal boa noite a todos...

Estou tendo uma dificuldade em passar a url que esta sendo digitada no nagevador

Ou seja uma das url ate que passa, porem as demais url não mostra sempre a mesma pagina que foi aberta

Creio que seria um tipo de conflitos
por exemplo: se eu acessar a seguinte url

Ex1: meusite.com/sao-paulo/list/minha-empresa-aqui/

e se eu acessar outra url com o mesmo no da empresa da seguinte forma

Ex2: meusite.com/sao-paulo/catalogo/minha-empresa-aqui/
ela teria que mostrar o que esta no EX2 mais porem fica na pagina do EX1 mais com a url no navegador do Ex2

Bom e tbm preciso passar os paramentros da pagina de pesquisa 

ou fazer uma busca a url me retorna a seguinte forma

EX3: meusite.com/buscar/?search_string=mercados&cidade=sao-paulo
e quero que seja mostrar desta forma, 
EX4: meusite.com/sao-paulo/buscar/mercados/
caso tenha paginação ela ficar assim ao pegar paginação meusite.com/sao-paulo/buscar/mercados/12/

Ou seja o que preciso é que não importar quanto paramentros seja queria que mostrasse conforme mostra no comentario do PHP

segue o código logo a baixo com htaccess

Talvez seja até coisa simples de se resolver ou pode ser eu fazendo da forma incorreta aqui...

 

HTACCESS

 

RewriteEngine On    
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^(.*)$ index.php?url=$1 [NC,L]

INDEX.PHP

 

<?php
ob_start();
session_cache_expire(60);
//session_start();
  if (!file_exists('CPANELUSER/database/config.php')) {
    header("Location: CPANELUSER/setup.php");
  } else {
    require_once ('CPANELUSER/database/config.php');
  }
  require_once ('CPANELUSER/database/config.painel.php');
  require_once ('CPANELUSER/database/config.database..php');
  require_once ('CPANELUSER/database/config.session.php');
  require_once ('CPANELUSER/includes/funcoes.php');

// Obtendo o URL dos arquivos atual
//$page = substr($_SERVER["SCRIPT_NAME"],strrpos($_SERVER["SCRIPT_NAME"],"/")+1);

function UrlAmigavelPHP(){
	if(isset($_GET['url'])) {
	
	$url = $_GET['url'] ? $_GET['url'] : "home";
	//$search_string = $_GET['search_string'] ? $_GET['search_string'] : "home";
	//$cidade = $_GET['cidade'] ? $_GET['cidade'] : "home";
	
	//var_dump($url);
	//var_dump($search_string);
	//var_dump($cidade);

     $UrlFormatada = explode('/', $_SERVER['REQUEST_URI']);

if(empty($UrlFormatada[1])) { $URL1 = ''; }else{ $URL1 = ''.$UrlFormatada[1].'/'; } 
if(empty($UrlFormatada[2])) { $URL2 = ''; }else{ $URL2 = ''.$UrlFormatada[2].'/'; }  
if(empty($UrlFormatada[3])) { $URL3 = ''; }else{ $URL3 = ''.$UrlFormatada[3].'/'; } 
if(empty($UrlFormatada[4])) { $URL4 = ''; }else{ $URL4 = ''.$UrlFormatada[4].'/'; } 
if(empty($UrlFormatada[5])) { $URL5 = ''; }else{ $URL5 = ''.$UrlFormatada[5].'/'; }
if(empty($UrlFormatada[6])) { $URL6 = ''; }else{ $URL6 = ''.$UrlFormatada[6].'/'; }


	//Passando a url completa
	$Paramentros = ''.$URL1.''.$URL2.''.$URL3.''.$URL4.''.$URL5.''.$URL6.'';
	
	

}else{
	$url = 'home';
}
switch($url) {
//HOME
	case 'home';
	     include_once('directory-home.php'); //meusite.com/cidade-principal/ que vai aparecer no index.php
	break;
//LISTAGEM		
	case $Paramentros;
	    include_once('directory-listagem.php'); //meusite.com/cidade-principal/list/nome-de-uma-empresa/
	break;
//CATALOGO
	case $Paramentros;

$Query = DBRead('directory_cidades','*',"WHERE status='1'  AND slug='".GetUrlBasecidade."'")[0];	

$TblEmpresa = DBRead("directory_listing","*","WHERE slug='".GetUrlBase."' AND cidade='{$Query['titulo']}'"); if (is_array($TblEmpresa)) { foreach ($TblEmpresa as $Empresa) { extract($Empresa);	
$titles = ''.trim(mb_convert_case($titulo, MB_CASE_TITLE, "UTF-8")).' | '.trim(mb_convert_case(ConfigPainel("site_nome"), MB_CASE_TITLE, "UTF-8")).'';
$getId = $id;	
$getu = $id_user;

//Url Menu Lateral das Empresas
$CidadeUrl = ''.ConfigPainel("site_url").''.GetUrlBasecidade.'/';
$UrlEmpresa = ''.$CidadeUrl.'list/'.GetUrlBase.'/';
$UrlCatalogo = ''.$CidadeUrl.'catalogo/'.GetUrlBase.'/';
$UrlPortfolio = ''.$CidadeUrl.'portfolio/'.GetUrlBase.'/';
$UrlEventos = ''.$CidadeUrl.'agenda/'.GetUrlBase.'/';
$UrlClassificados = ''.$CidadeUrl.'vagas/'.GetUrlBase.'/';
$UrlContato = ''.UrlAmigavel($menu5).'';
//Pegando os ids 

switch ($Empresa['id_destaque']) {
case '5': $index_seo = ''; break;
case '4': $index_seo = 4;  break;
case '3': $index_seo = 3;  break;
case '2': $index_seo = 2;  break;
case '1': $index_seo = 1;  break;
case '0': $index_seo = 0;  break;	
}	

$Query = DBRead('directory_itens','*',"WHERE  status='1' AND user_id='{$getu}'  ORDER BY nome_item ASC LIMIT 100");
 $NomeCity =''.$cidade.'';  
define("METAKEYWORD", $palavra_chave);	
define("METADESCRIPTION", $frase);
define("METATITLE", ''.(!empty($definir) ? 'Cardápio | '.LetraMaiuscula($titulo) : 'Catálogo | '.LetraMaiuscula($titulo).'').' | '.ConfigPainel("site_nome").'');
//1 Cardápio > 2 Catálogo > 3 Imóveis > 4 Produtos
//Configuração
$QueryEmpresa = DBRead('directory_listing','*',"WHERE  id_user='{$getu}'  ORDER BY id LIMIT 1")[0];		
//company-product
$QueryItemCount = DBRead('directory_itens','*', "WHERE status= '1' AND user_id='{$getu}' ORDER BY nome_item")[0];
if($definir == 1) {
$Menu1 = $QueryEmpresa['menu1'];
if($QueryItemCount['user_id'] == $getu) {
$Status1 = 1; //1 Ativo
}else{
$Status1 = 0; //0 Inativo
}
$Icone = 'fa-cutlery';	
}elseif($definir == 2) {
$Menu1 = $QueryEmpresa['menu1'];
if($QueryItemCount['user_id'] == $getu) {
$Status1 = 1; //1 Ativo
}else{
$Status1 = 0; //0 Inativo
}
$Icone = 'fa-shopping-bag';
}elseif($definir == 3) {
$Menu1 = $QueryEmpresa['menu1'];
if($QueryItemCount['user_id'] == $getu) {
$Status1 = 1; //1 Ativo
}else{
$Status1 = 0; //0 Inativo
}
$Icone = 'fa-home';	
}elseif($definir == 4) {
$Menu1 = $QueryEmpresa['menu1'];
if($QueryItemCount['user_id'] == $getu) {
$Status1 = 1; //1 Ativo
}else{
$Status1 = 0; //0 Inativo
}
$Icone = 'fa-product-hunt';	
}
//company-portfolio
$QueryPorCount = DBRead('directory_portifolio','*', "WHERE status= '1' AND id_user = '{$getu}' ORDER BY id")[0];
$Menu2 = $QueryEmpresa['menu2'];
if($QueryPorCount['id_user'] == $getu) {
$Status2 = 1; //1 Ativo
}else{
$Status2 = 0; //0 Inativo
}
//company-events
$Menu3 = $QueryEmpresa['menu3'];
$QueryAgCount = DBRead('directory_agenda','*', "WHERE status= '1' AND idempresa = '{$getId}'")[0];
if($QueryAgCount['idempresa'] == $getId) {
$Status3 = 1; //1 Ativo
}else{
$Status3 = 0; //0 Inativo
}
//company-blog
$QueryNumBlog = DBRead('directory_emprego','*',"WHERE status='1' AND id_empresa = '{$getId}'")[0];
$Menu4 = $QueryEmpresa['menu4'];
if($QueryNumBlog['id_empresa'] == $getId) {
$Status4 = 1; //1 Ativo
}else{
$Status4 = 0; //0 Inativo
}	
//company-contact
$Menu5 = $QueryEmpresa['menu5'];		
define("METAURL", "".ConfigPainel("site_url")."".$UrlCatalogo."");
define("METAIMAGEM", "".ConfigPainel("site_url")."assets/".GetUrlBase."/".$logo."");
if (empty($index_seo)) {
define("METAINDEXAR", "noall, noindex, nofollow"); //noall, noindex, nofollow
//Redireciona(ConfigPainel("site_url"));
}else{
define("METAINDEXAR", "all, index, follow"); //all, index, follow
}
} }
else{
//Redireciona(''.ConfigPainel("site_url").''.UrlAmigavel($cidade).'/');	   
	}
require_once('Inc/hora.php');

$diasemana = array('Domingo', 'Segunda', 'Terça', 'Quarta', 'Quinta', 'Sexta', 'Sabado');
$data = date('Y-m-d');
$diasemana_numero = date('w', strtotime($data));
$diadehoje   = $diasemana[$diasemana_numero];
	//$todososdias = 'null';


	     include_once('directory-catalogo.php');//meusite.com/cidade-principal/catalogo/nome-de-uma-empresa/
	break;
//PORTFOLIO
	case $Paramentros;
	     include_once('directory-portfolio.php');//meusite.com/cidade-principal/portfolio/nome-de-uma-empresa/
	break;
//AGENDA
	case $Paramentros;
	     include_once('directory-agenda.php');//meusite.com/cidade-principal/agenda/nome-de-uma-empresa/
	break;
//BLOG
	case $Paramentros;
	     include_once('directory-blog.php');//meusite.com/cidade-principal/vagas/nome-de-uma-empresa/
	break;
//PESQUISAR
	case $Paramentros;
	     include_once('directory-buscar.php');//meusite.com/cidade-principal/buscar/loja/
	break;
//SOBRE
	case $Paramentros;
	     include_once('directory-sobre.php');//meusite.com/cidade-principal/sobre/
	break;
//PLANO
	case $Paramentros;
	     include_once('directory-plano.php');//meusite.com/cidade-principal/plano/
	break;
//CONTATO
	case $Paramentros;
	     include_once('directory-contato.php');//meusite.com/cidade-principal/contato/
	break;

	
  default;
    include_once('directory-404.php');
  break;	
}



}
UrlAmigavelPHP();
?>

Perdoa se ficou muito grande os codigo ai na parte do catalogo coloquei para poder ver como estou recendo os paramentros

 

Desde já fico no guardo se alguém puder dar uma idiea ai

Compartilhar este post


Link para o post
Compartilhar em outros sites

Rapaz!
Acredito que desta forma, vai ser bem difícil manutenir / dar continuidade a esse sistema.
Sugiro que comece pelo menos separando em camadas de controller/view/action/?queryParams

Existem parâmetros que o ideal é que sejam pathParams: /controller/view/action
já outros são mais adequados como queryParams: ?limit=10&offset=10&search=palavra ou ?page=3&search=palavra

Se não quiser seguir o mínimo de padrões consagrados que existem e são usados desde os anos 70
image.png.19c508e49e0d969d245a745a2d5293c8.png
Tem toda liberdade de inventar seu estilo próprio.

Comece então, definindo um padrão para os pathParams:
/primeiro/segundo/terceiro/quarto/quinto/sexto

Tendo bem claro o que cada um desses parâmetros vai ser/significar
vai ficar bem mais prático, lógico e metódico para lidar com qualquer rota que precisares

Compartilhar este post


Link para o post
Compartilhar em outros sites

O problema é relativamente simples, pois é um padrão de arquitetura que uso a anos, então poderíamos simplificar as coisas.

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

Pós produção se for conveniente você poderá remover as entradas RewriteCond, porque com isso alguém pode acessar acessar meusite.com/diretorio/arquivo.php.

 

Enfim qualquer caractere inserido pós a primeira barra depois do endereço será uma entrada "url" armazenada na super global INPUT_GET e seu valor será uma string.

Então simplificando sua situação vamos separar cada qual.

<?php
function ObterURL () {
    $filtro = filter_input(INPUT_GET, 'url', FILTER_DEFAULT);
    $definir = empty($filtro) ? 'inicio' : $filtro;
    $explode = explode('/', $definir);
    $array = array_filter($explode);
    return ($array);
}

Perceba que a função irá retornar pelo menos um índice "inicio" mesmo que INPUT_GET['url'] esteja vazio ou nulo

Então no index.php começamos o processo:

<?php
require('ObterURL.php')
$url = ObterURL();
/*
// site.com/a/b/c será $url['a', 'b', 'c']
echo ($url[0] . '<br />');
var_dump($url);
*/

Até agora tudo bem seguimos seu conceito apenas simplificando. E é agora que começamos a estrutura da coisa toda e é nesse momento que acho que você está se perdendo.

 

Como valor $url[0] carrego os arquivos que vão dar seguimento ao que quero aderir.

Por exemplo o padrão "inicio" é porque ninguém acessou nada, se for "sao-paulo" carrego tudo referente a isso e por aí vai.

Podemos etão criar uma função para anexar os arquivos conforme o valor de url[0]

<?php
function CarregarArquivo($valor) {
    switch ($valor) {
        case 'inicio': $arquivo = 'inicio'; break;
        case 'vitoria':
        case 'rio-de-janeiro':
        case 'sao-paulo':
        case 'salvador':
        case 'distrito-federal':
            $arquivo = 'cidades';
        break;
        case 'catalogo': $arquivo = 'catalogo'; break;
        case 'buscar': $arquivo = 'pesquisa'; break;
        case 'contato': $arquivo = 'contato'; break;
        default: $arquivo = false; break;
    }
    if ($arquivo) {
        return ('paginas' . DIRECTORY_SEPARATOR . $arquivo . '.php');
    } else {
        return ('paginas' . DIRECTORY_SEPARATOR . '404.php');
    }
}

Adicionamos no index.php um require para o arquivo que contém a função e pedimos para incluir o arquivo conforma a string que essa função retornar.

include (CarregarArquivo($url[0]));

 

Então dessa forma conseguimos carregar os arquivos que vão fazer o que tem de fazer isoladamente sem nenhuma complicação. E se precisamos de mais alguma coisa é só consutar os valores de $url

Exemplo:

site.com/contado/outra_coisa

$url[0] é contado e $url[1] é outra_coisa

 

 

 

Por fim a nosso htaccess anula quaisquer demais entradas GET pois ele diz que só existe uma entrada a "url" então podemos  contornar isso buscando essa informação do servidor ao invés da aplicação em sí.

<?php

function EntradaNoServidor() { // Função meramente para exemplificar
    $filtro = filter_input_array(INPUT_SERVER, FILTER_DEFAULT);
    $retorno = isset($filtro) ? $filtro : false;
    return ($retorno);
}

$uri = EntradaNoServidor();
$chave = explode('?chave=', $uri['REQUEST_URI']);

if (isset($chave[1])) {
    echo (
        'Existe ?chave=' . $chave[1]
        . ' então podemos usar essa informação'
        . (empty($chave[1]) ? ' mas ela está vazia' : null)
    );
} else {
    echo ('Não existe uma entrada GET nesse arquivo');
}

 

Lógico que dependendo da forma da estrutura de diretórios e arquivos seus as funções ou mesmo os arquivos devem ser adaptados para a lógica aqui apresentada.

 

Se for o caso coloquei no g.drive o exemplo funcional disso que apresentei.

https://drive.google.com/file/d/1O-jq3luqLybShUtltbIjgKdGSrTVd1zc/view?usp=sharing

 

Compartilhar este post


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

Rapaz!
Acredito que desta forma, vai ser bem difícil manutenir / dar continuidade a esse sistema.
Sugiro que comece pelo menos separando em camadas de controller/view/action/?queryParams

Existem parâmetros que o ideal é que sejam pathParams: /controller/view/action
já outros são mais adequados como queryParams: ?limit=10&offset=10&search=palavra ou ?page=3&search=palavra

Se não quiser seguir o mínimo de padrões consagrados que existem e são usados desde os anos 70
image.png.19c508e49e0d969d245a745a2d5293c8.png
Tem toda liberdade de inventar seu estilo próprio.

Comece então, definindo um padrão para os pathParams:
/primeiro/segundo/terceiro/quarto/quinto/sexto

Tendo bem claro o que cada um desses parâmetros vai ser/significar
vai ficar bem mais prático, lógico e metódico para lidar com qualquer rota que precisares

Ola boa tarde 

 

Obrigado pela resposta fico grato, vou melhorar a minha estrutura para MVC 

 

Sobre url

 

Eu tentei usar o

<?php
$url = parse_url($_SERVER['REQUEST_URI'], PHP_URL_PATH);

Para pegar somente /catalogo/

Mais nao deu certo

 

 

Mais vou melhorar mais 

Compartilhar este post


Link para o post
Compartilhar em outros sites
5 horas atrás, Omar~ disse:

O problema é relativamente simples, pois é um padrão de arquitetura que uso a anos, então poderíamos simplificar as coisas.


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

Pós produção se for conveniente você poderá remover as entradas RewriteCond, porque com isso alguém pode acessar acessar meusite.com/diretorio/arquivo.php.

 

Enfim qualquer caractere inserido pós a primeira barra depois do endereço será uma entrada "url" armazenada na super global INPUT_GET e seu valor será uma string.

Então simplificando sua situação vamos separar cada qual.


<?php
function ObterURL () {
    $filtro = filter_input(INPUT_GET, 'url', FILTER_DEFAULT);
    $definir = empty($filtro) ? 'inicio' : $filtro;
    $explode = explode('/', $definir);
    $array = array_filter($explode);
    return ($array);
}

Perceba que a função irá retornar pelo menos um índice "inicio" mesmo que INPUT_GET['url'] esteja vazio ou nulo

Então no index.php começamos o processo:


<?php
require('ObterURL.php')
$url = ObterURL();
/*
// site.com/a/b/c será $url['a', 'b', 'c']
echo ($url[0] . '<br />');
var_dump($url);
*/

Até agora tudo bem seguimos seu conceito apenas simplificando. E é agora que começamos a estrutura da coisa toda e é nesse momento que acho que você está se perdendo.

 

Como valor $url[0] carrego os arquivos que vão dar seguimento ao que quero aderir.

Por exemplo o padrão "inicio" é porque ninguém acessou nada, se for "sao-paulo" carrego tudo referente a isso e por aí vai.

Podemos etão criar uma função para anexar os arquivos conforme o valor de url[0]


<?php
function CarregarArquivo($valor) {
    switch ($valor) {
        case 'inicio': $arquivo = 'inicio'; break;
        case 'vitoria':
        case 'rio-de-janeiro':
        case 'sao-paulo':
        case 'salvador':
        case 'distrito-federal':
            $arquivo = 'cidades';
        break;
        case 'catalogo': $arquivo = 'catalogo'; break;
        case 'buscar': $arquivo = 'pesquisa'; break;
        case 'contato': $arquivo = 'contato'; break;
        default: $arquivo = false; break;
    }
    if ($arquivo) {
        return ('paginas' . DIRECTORY_SEPARATOR . $arquivo . '.php');
    } else {
        return ('paginas' . DIRECTORY_SEPARATOR . '404.php');
    }
}

Adicionamos no index.php um require para o arquivo que contém a função e pedimos para incluir o arquivo conforma a string que essa função retornar.

include (CarregarArquivo($url[0]));

 

Então dessa forma conseguimos carregar os arquivos que vão fazer o que tem de fazer isoladamente sem nenhuma complicação. E se precisamos de mais alguma coisa é só consutar os valores de $url

Exemplo:

site.com/contado/outra_coisa

$url[0] é contado e $url[1] é outra_coisa

 

 

 

Por fim a nosso htaccess anula quaisquer demais entradas GET pois ele diz que só existe uma entrada a "url" então podemos  contornar isso buscando essa informação do servidor ao invés da aplicação em sí.


<?php

function EntradaNoServidor() { // Função meramente para exemplificar
    $filtro = filter_input_array(INPUT_SERVER, FILTER_DEFAULT);
    $retorno = isset($filtro) ? $filtro : false;
    return ($retorno);
}

$uri = EntradaNoServidor();
$chave = explode('?chave=', $uri['REQUEST_URI']);

if (isset($chave[1])) {
    echo (
        'Existe ?chave=' . $chave[1]
        . ' então podemos usar essa informação'
        . (empty($chave[1]) ? ' mas ela está vazia' : null)
    );
} else {
    echo ('Não existe uma entrada GET nesse arquivo');
}

 

Lógico que dependendo da forma da estrutura de diretórios e arquivos seus as funções ou mesmo os arquivos devem ser adaptados para a lógica aqui apresentada.

 

Se for o caso coloquei no g.drive o exemplo funcional disso que apresentei.

https://drive.google.com/file/d/1O-jq3luqLybShUtltbIjgKdGSrTVd1zc/view?usp=sharing

 

Boa tarde @Omar~ obrigado pela resposta e pela aula tbm ajudou bastante vou implementar o que passou ai..

 

 

Quero tirar uma dúvida aqui..

 

Eu tenho um arquivo Inc/codigoPHP.php

 

Dentro dele contem quase toda a estrutura di php para cada pagina entende?

 

Estaria mais o menos isso aqui

<?php
//Obtendo o URL dos arquivos atual
$page = substr($_SERVER["SCRIPT_NAME"], strrpos($_SERVER["SCRIPT_NAME"], "/")+1);

//OS ARQUIVOS URL ATUAL
if($page == 'directory-404.php') {
//aqui vai código php da pagina 404

}

if($page == 'directory-sobre.php') {
//aqui vai código php da pagina sobre

}

if($page == 'directory-buscar.php') {
//aqui vai código php da pagina pesquisar

}

if($page == 'directory-catalogo.php') {
//aqui vai código php da pagina catalogo

}

/*
E assim vai para as outras paginas 

*/

Dentro do outro arquivo Inc/header.php

Recebe este arquivo Inc/codigoPHP.php

 

Mais quando passa pelo index conforme o primeiro post que fiz ele na erro ao receber este arquivo

 

Para nao fica com erro tive q colocar tudo em cada arquivo

 

E queria fazer separado pelo menos um pouco do PHP entende..

 

Quero fazer igual o amigo disse na resposta de cima la MvC

So que ainda nao fiz igual mvc...

 

Mais acreio que desta forma ja ajudaria separa um pouco ate para poder esta fazendo alguns reajuste caso precisar...

Compartilhar este post


Link para o post
Compartilhar em outros sites

@Omar~

 

Fiz o teste deu certo

 

Mais deixa pergunta como consigo passar as paginas por exemplo 

Sobre | Plano | Blog | Contato

 

Por cada cidade 

Meusite.com/sao-paulo/sobre/

<h1> Sobre</h1>

 

 

O que quero dizer que algumas destas paginas vai esta ligada a um cidade

 

Pois as paginas ela abre apenas 

 

Meusite.com/sobre/

 

Se seria possível elas abrir tanto como 

 

Meusite.com/sao-paulo/sobre/ ou não 

Se nao ouver cidade sera considerada como a pagina principal 

 

Ou seja ao abrir o index vou definir como uma cidade principal entende?

 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
Em 16/05/2022 at 15:15, Jack Oliveira disse:

Mais deixa pergunta como consigo passar as paginas por exemplo 

Sobre | Plano | Blog | Contato

Sim $url[0] é a cidade e $url[1] será uma dessas opções. basta apenas programar o arquivo que será carregado por $url[0] para trabalhar com a informação correta conforme for o valor de $url[1]

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar Agora

  • Conteúdo Similar

    • Por violin101
      Caros amigos, saudações.
       
      Humildemente peço desculpa por postar uma dúvida que tenho.

      Preciso salvar no MySql, os seguinte Registro:

      1 - Principal
      ====> minha dúvida começa aqui
      ==========> como faço para o Sistema Contar Automaticamente o que estiver despois do 1.____?
      1.01 - Matriz
      1.01.0001 - Estoque
      1.01.0002 - Oficina
      etc

      2 - Secundário
      2.01 - Loja_1
      2.01.0001 - Caixa
      2.01.0002 - Recepção
      etc
       
      Resumindo seria como se fosse um Cadastro de PLANO de CONTAS CONTÁBEIL.

      Grato,


      Cesar









       
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer a orientação dos amigos.

      Preciso fazer um Relatório onde o usuário pode Gerar uma Lista com prazo para vencimento de: 15 / 20/ 30 dias da data atual.

      Tem como montar uma SQL para o sistema fazer uma busca no MySql por período ou dias próximo ao vencimento ?

      Tentei fazer assim, mas o SQL me traz tudo:
      $query = "SELECT faturamento.*, DATE_ADD(faturamento.dataVencimento, INTERVAL 30 DAY), fornecedor.* FROM faturamento INNER JOIN fornecedor ON fornecedor.idfornecedor = faturamento.id_fornecedor WHERE faturamento.statusFatur = 1 ORDER BY faturamento.idFaturamento $ordenar ";  
      Grato,
       
      Cesar
       
       
       
       
    • Por violin101
      Caros amigos, saudações
       
      Por favor, me perdoa em recorrer a orientação dos amigos, tenho uma dúvida.
       
      Gostaria de uma rotina onde o Sistema possa acusar para o usuário antes dos 30 dias, grifar na Tabela o aviso de vencimento próximo, por exemplo:
       
      Data Atual: 15/11/2024
                                           Vencimento
      Fornecedor.....................Data.....................Valor
      Fornecedor_1...........01/12/2024..........R$ 120,00 <== grifar a linha de Laranja
      Fornecedor_1...........01/01/2025..........R$ 130,00
      Fornecedor_2...........15/12/2024..........R$ 200,00 <== grifar a linha de Amarelo
      Fornecedor_2...........15/01/2025..........R$ 230,00
      Fornecedor_3...........20/12/2024..........R$ 150,00
       
      Alguém tem alguma dica ou leitura sobre este assunto ?

      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer a ajuda dos amigos, mas preciso entender uma processo que não estou conseguindo sucesso.

      Como mencionado no Título estou escrevendo um Sistema Web para Gerenciamento de Empresa.
       
      Minha dúvida, que preciso muito entender:
      - preciso agora escrever a Rotina para Emissão de NFe e essa parte não estou conseguindo.
       
      tenho assistido alguns vídeos e leituras, mas não estou conseguindo sucesso, já fiz toda as importações das LIB da NFePhp conforme orientação.

      Preciso de ajuda.

      Algum dos amigos tem conhecimento de algum passo-a-passo explicando a criação dessa rotina ?

      tenho visto alguns vídeos com LARAVEL, mas quando tento utilizar e converter para PHP+Codeiginter, dá uma fila de erros que não entendo, mesmo informando as lib necessárias.

      Alguns do amigo tem algum vídeo, leitura explicando essa parte ?

      Grato,

      Cesar.
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer ao auxílio dos amigos, mas preciso entender e resolver um problema.
       
      Tenho uma Rotina que o usuário seleciona os produtos que deseja para requerer ao setor responsável.
       
      O usuário escolhe um produto qualquer e Clicla em um button para incluir a lista.

      O problema que estou enfrentando é que após escolher o produto e teclar ENTER o Sistema já salva no BD.
       
      Gostaria de criar uma Tecla de Atalho, para quando incluir/escolher o produto na lista, o usuário tecla como exemplo:
      ALT+A  para agregar a lista
      ALT+S para salvar a lista de itens desejados.

      Assim, quando teclar enter, o sistema não dispara o GRAVAR na Base de Dados.

      Grato,

      Cesar
       
       
       
×

Informação importante

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