Ir para conteúdo

POWERED BY:

Arquivado

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

guzulino

Framework para html

Recommended Posts

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.

Compartilhar este post


Link para o post
Compartilhar em outros sites

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.

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
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.

Compartilhar este post


Link para o post
Compartilhar em outros sites

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:
allow_url_include = Off

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.

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • 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');     }  
    • Por violin101
      Caros amigos, saudações.
       
      Gostaria de tirar uma dúvida com os amigos, referente a PDV.
       
      Estou escrevendo um Sistema com Ponto de Vendas, a minha dúvida é o seguinte, referente ao procedimento mais correto.

      Conforme o caixa vai efetuando a venda, o Sistema de PDV já realiza:
      a baixa direto dos produtos no estoque
      ou
      somente após concretizar a venda o sistema baixa os produtos do estoque ?
       
      Grato,
       
      Cesar
       
    • Por violin101
      Caros amigos do grupo, saudações e um feliz 2025.
       
      Estou com uma pequena dúvida referente a Teclas de Atalho.

      Quando o Caps Lock está ativado o Comando da Tecla de Atalho não funciona.
      ou seja:
      se estiver para letra minúscula ====> funciona
      se estiver para letra maiúscula ====> não funciona
       
      Como consigo evitar essa falha, tanto para Letra Maiúscula quanto Minúscula ?

      o Código está assim:
      document.addEventListener( 'keydown', evt => { if (!evt.ctrlKey || evt.key !== 'r' ) return;// Não é Ctrl+r, portanto interrompemos o script evt.preventDefault(); });  
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Por favor, poderiam me ajudar.

      Estou com a seguinte dúvida:
      --> como faço para para implementar o input código do produto, para quando o usuário digitar o ID o sistema espera de 1s a 2s, sem ter que pressionar a tecla ENTER.

      exemplo:
      código   ----   descrição
           1       -----   produto_A
       
      Grato,
       
      Cesar
×

Informação importante

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