Ir para conteúdo

POWERED BY:

Arquivado

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

LaerteDias

Como melhorar meu controle

Recommended Posts

Bom dia, estou conseguindo desenvolver a minha visão e o meu modelo, mas o meu controle acredito não estar otimizado o que devo fazer?

<?php
include_once 'Pegapost.php';
include 'EntidadeEvento.php';
include 'DaoEvento.php';
		// criando uma instância da classe EntidadeEvento.php
		$entidadeevento = new EntidadeEvento($nome_evento,$localizacao);
                $nome_tratado = $entidadeevento.getnome_Evento();
		$localizacao_tratado = $entidadeevento.getLocalizacao();
                //Dao seria aqui em baixo

?>

Compartilhar este post


Link para o post
Compartilhar em outros sites

Porque a Classe de Entidades esta recendo parâmetros pelo construtor?

Outra coisa

$entidadeevento.getLocalizacao

Não é ponto (.) e sim ->

$entidadeevento->getLocalizacao();

para usar o método ou :: para métodos estáticos no PHP

Compartilhar este post


Link para o post
Compartilhar em outros sites

o Construtor recebe paremetros, pois estou "setando" as variaveis pelo mesmo, isso é incorreto?

o segundo "erro", foi meu e que acabei enviando um exemplo que estava errado e que estou acostumado ao Java e acabo me atrapalhando de vez em quanto.

Compartilhar este post


Link para o post
Compartilhar em outros sites

o Construtor recebe paremetros, pois estou "setando" as variaveis pelo mesmo, isso é incorreto?

É uma entidade, geralmente usada para getters e setters

Então no java seria this.getNome() no php $this->getNome()

Compartilhar este post


Link para o post
Compartilhar em outros sites

Acredito que você quebre toda a funcionalidade do teu sistema de mapeamento e dos princípios S.O.L.I.D, dois tenho certeza que estaria violando.

OCP - Open-closed principle

DIP - Dependency Inversion Principle

Saiba mais sobre os Princípios SOLID

http://eduardopires.net.br/2015/01/solid-teoria-e-pratica/


Obs.: Se você quer usar construtores, então use
Fluent Interface

Compartilhar este post


Link para o post
Compartilhar em outros sites

Entendi, agora como poderei otimizar o controle e não consigo criar uma classe controle e trabalhar com os parametros, como devo fazer para receber os post em um classe controle e poder manipulá-lo?

Compartilhar este post


Link para o post
Compartilhar em outros sites

Posta essas classes amigo

include_once 'Pegapost.php';
include 'EntidadeEvento.php';
include 'DaoEvento.php';

Compartilhar este post


Link para o post
Compartilhar em outros sites

Acredito que haja uma confusão ainda com as responsabilidade de cada um participante.

No seu controle, você está instanciando uma entidade. Por mais que seja apenas uma linha, não é de responsabilidade do controle. A responsabilidade das entidades de negócio, é da camada de negócio, que é o Model.

Digamos que, em um exemplo simplista, preciso criar uma entidade vazia e utilizá-la na view. O exemplo mais básico, seria.

A View é totalmente dependente da unidade, por isso está no construtor

Class View
{
    private $entity;

    public function __construct(Entity $entity)
    {
        $this->entity = $entity;
    }

    public function show()
    {
        /** código para exibição da entidade **/
    }
}

O Modelo, será responsável por criar a nossa entidade:

Class Model
{
    public function getEmptyEntity() : Entity
    {
        return new Entity();
    }
}

E o Controle, será o responsável pela interpretação da requisição (request) e que chamará os participantes necessários:

Class Controller
{
    public function index()
    {
        $model = new Model();
        $view = new View($model->getEmptyEntity());
        $view->show();
    }
}

É um exemplo um tanto "tosco", mas é bom para entender o que é, de cada qual, a sua responsabilidade.

Como, no seu exemplo, existem as variáveis $nome_tratado e $localizacao_tratado. Não é de responsabilidade do Controle tratá-los, apenas tratá-los.

Entretanto, se você está enviando valor por valor (o que não estaria errado de todo o modo), ao invés de enviar apenas a entidade, não é um problema de responsabilidades e sim de modelagem.

No link abaixo, eu falo sobre a responsabilidade da View em receber e tratar entidade:
http://forum.imasters.com.br/topic/536201-mvc-paginas-dinamicas/?p=2141430

Entretanto, como era pra ser um exemplo rápido, acabei colocando toda a criação da entidade no controle (ignore essa parte). Eu estarei alterando para evitar futuras "discrepâncias". Post do ink atualizado

Compartilhar este post


Link para o post
Compartilhar em outros sites

Posta essas classes amigo

include_once 'Pegapost.php';
include 'EntidadeEvento.php';
include 'DaoEvento.php';
//Pegapost.php  classe 
<?php

    $nome_evento = $_POST['nome-evento'];
    $localizacao = $_POST['localizacao'];  

?>

<?php
	class EntidadeEvento{
          private $nome_evento;
	  private $localizacao;
            public function __construct(){
			
			}
            public function setnome_Evento($nome){ 	
				$this->nome_evento =  $nome;
			}
	    public function setLocalizacao($localiza){
				$this->localizacao = $localiza;
			}
            public function getnome_Evento(){
				return $this->nome_evento;
			}
	    public function getLocalizacao(){
				return $this->localizacao;
			}			
        }

?>

Compartilhar este post


Link para o post
Compartilhar em outros sites

Em MVC, DAO é uma camada (tier) do Model.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Mas como ficaria a estrutura da Dao[...]

A estrutura da DAO é dependente apenas do seu padrão. Não há porque mudá-la.

[...]e onde a chamaria?

Você a chamaria dentro da Model, apenas nela.

A existência, ou não, de um storage não deve ser de responsabilidade do controlle. Ele apenas tem o conhecimento de qual Model deve ser chamada para cada requisição.

O tipo de gerenciamento/mapeamento de dados do storage (DAO, DataMapper, TDG/RDG, etc..) também não é de responsabilidade do Controller, apenas do Model.

Em um exemplo simplista, para salvar dados:

Class Controller
{
    public function post()
    {
        if ($_SERVER['REQUEST_METHOD'] == 'POST')
        {
            try
            {
                $post = $_POST;
 
                /** validação/sanitização dos dados do $post omitidos **/

                $model = new Model();
                $model->save($post);
            }
            catch (RuntimeException $exception)
            {
                /** tratamento em caso de exceção **/
            }
        }

        /** demais códigos omitidos **/
    }
}
Model:

class Model
{

    private $pdo;

    public function __construct()
    {
        $this->pdo = new PDO(/** configuração para conexão **/);
        $this->pdo->setAttribute(PDO::ATTR_ERRMODE , PDO::ERRMODE_EXCEPTION); 
    }

    public function save(array $post)
    {
        $entity = $this->getEmptyEntity();
        $entity->setField1($post['field1']);
        $entity->setField2($post['field2']);
        $entity->setField3($post['field3']);
        
        $dao = new EntityDAO($this->pdo);
        $dao->save($dao);
    }

    public function getEmptyEntity() : Entity
    {
        return new Entity();
    }

}

EntityDAO:

class EntityDAO
{

    private $pdo;

    public function __construct(PDO $pdo)
    {
        $this->pdo = $pdo;
    }

    public function save(Entity $entity)
    {
        $sql = 'INSERT INTO entity (field1 , field2 , field3) VALUES (? , ? , ?)'
        $statement = $this->pdo->prepare($sql);
        $statement->execute([$entity->getField1() , $entity->getField2() , $entity->getField3()]);
    }
}
Dessa forma, todas as responsabilidades estão separadas em cada uma de suas camadas.

Mas, veja bem que, esse código acima ainda pode ser muito melhorado e, para um projeto de médio e grande porte, ele carrega alguns problemas bem comuns. Como, por exemplo, utilizar algum container para os objetos que podem ser de uso recorrente(PDO, DAO, etc..) ao invés de criar uma instância nova sempre que necessário.

Outro detalhe é o uso direto de PDO, em alguns casos, outras alternativas podem ser válidas. O padrão DAO também é um padrão simplista, ele é um objeto de acesso aos dados para um storage específico. Caso mudar o tipo de storage, provavelmente deves mudar o DAO também.

Cada padrão vai ter suas vantagens e desvantagens. Nenhum vai te entregar uma solução perfeita, apenas a mais próxima da necessidade do seu projeto.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Só mais uma dúvida como no meu form referenciaria o controle para pegar os post, porque no meu projeto estava tentado de uma página inicial com formulário que envia para o controle para poder cadastrar no BD.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Nesse caso, normalmente é utilizado um padrão denominado FrontController.

Compartilhar este post


Link para o post
Compartilhar em outros sites
<form class="form-horinzontal" id="formulario" name="formevento" method="post" action="o que deveria colocar aqui">

No action tem como enviar via post para a classe controle? Essa é minha grande dúvida.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Para alterar o estado de uma entidade durante o tempo execução (RunTime).

Compartilhar este post


Link para o post
Compartilhar em outros sites

Então eu recebo uma valor pelo post e preciso concatenar, anteriormente estava concatenando utilizando os metodos getters e setters, isso pelo que eu entendi está errado.

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.