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 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.