View
111
Download
0
Category
Preview:
Citation preview
PHP5 BÁSICO40 Horas
Instrutor: Antonio Itamar Júnior
PHP5 BÁSICO
• O que é PHP?• Nomenclatura de arquivos• Abertura de escopo PHP• Comentários de código• Variáveis• Nomenclatura de variáveis• Tipos de dados
- Array
- Programação Web
- Orientação a Objetos
- MySQL
- PHP + MySQL
AMBIENTE DE DESENVOLVIMENTO
Links para apache e php5
3
O QUE É PHP?
4
NOMENCLATURA DE ARQUIVOS
Não pode conter caracteres especiais. Nomes válidos:
Arquivo2.php nomeArquivo.php nome_arquivo.php Cliente.php
Nomes inválidos: nome arquivo.php nome-arquivo.php Formulário.php
5
ESTUDO DE CASO
Crie os arquivos para as seguintes necessidades. Cadastrar Pessoa Jurídica; Cadastrar Nome Completo da Mãe; Formulário de inscrição
6
ABERTURA DE ESCOPO PHP
Sintaxe
Sintaxe alternativa (exige alteração no PHP.INI)
7
<?php ...?>
<? ?>
COMENTÁRIOS DE CÓDIGO
Mantém textos dentro do escopo de um código PHP, sem ser interpretado pelo servidor;
Auxilia a equipe a entender um determinado trecho de código;
Sintaxe Pequenos comentários – recomendado para frase unica;
Grandes comentários – recomentado para explicar um algorítimo;
Grandes comentários – recomendado para explicar funcionalidades pelo fato de auxilizar na geração de documentação do código.
8
// Texto em linha única
/* * Texto em * várias linhas */
/** * Texto em * várias linhas */
VARIÁVEIS
Similar a aritmética , as variáveis servem para armazenar algum valor desconhecido, ou que muda com certa facilidade.
Para criar uma variável é necessário colocar o símbolo “$” antes do nome desejado.
Sintaxe
9
$nome_da_varivel
NOMENCLATURA DE VARIÁVEIS Não pode ser iniciada com número; É case-sensitive, $nome é diferente de $NOME;
10
Válidos Inválidos
$Nome $2nome;
$nome $nome completo;
$_nome -
$nomeCompleto *
$nome_completo /
ALIMENTAR VARIÁVEIS
Valor numérico;
Valor alfanumérico
Valor variável
11
$variavel = valor;
Da esquerda pra direita
$variavel = 10;
$variavel = “Hello World”;
$variavel = 10.5;
$variavel = “10”;
$variavel = “10.5”;
$variavel = $variavel_2;
TIPOS DE DADOS
O tipo de variável se refere ao tipo de dado que é armazenado em uma variável.
12
Tipo Descrição
Int Utilizado para números inteiros
Float Também chamado de Double – Utilizado para números reais (números de ponto flutuante)
String Utilizado para coleções de caracteres (textos)
Boolean Utilizado para valores verdadeiros ou falsos.
Array Utilizado para armazenar vários valores
Object
Resource
NULL Atribuído automaticamente quando não é declarado nenhum tipo para uma variável
TIPOS DE DADOS
No PHP não há necessidade de declarar o tipo da variável antes de utilizá-la, como é obrigatório em linguagens como C e JAVA.
13
APRENDA FAZENDO
A variável quantidade agora é entendida como uma variável do tipo Int e a variável preco como Float.
Provando a portabilidade de tipos de variável no PHP, agora à variável preco será entendida como sendo do tipo String.
O PHP altera o tipo de variável de acordo com o que está armazenado na variável. Em qualquer momento essa troca pode ocorrer.
14
<?php $quantidade = 0; $preco = 0.00;?>
<?php $quantidade = 0; $preco = ‘Brasil’;?>
COERÇÃO DE TIPO
Para fazer uma coerção basta colocar o tipo desejado entre parênteses “()” na frente da variável.
Para fazer uma coerção basta colocar o tipo desejado entre parênteses “()” na frente da variável.
15
$variavel = (tipo) $variavel;
Possíveis Tipos
int integer
float long
double real
APRENDA FAZENDO
Aplicando coerção de tipo
A variável $preco, está armazenando a coerção da variável $quantidade para o tipo real.
A variável $quantidade continua sendo do tipo int. A variável $preco fica sendo do tipo float.
16
<?php $quantidade = 10; $preco = (double) $quantidade;?>
VISUALIZANDO VARIÁVEIS NO BROWSER
Echo var_dump();
Aprenda fazendo para visualizar as variaveis.
17
VARIÁVEIS VARIÁVEL
Através das variáveis variável é permitido alterar dinamicamente o nome de uma variável.
18
<?php $nome = ‘hoje’; $$nome = 5;
echo $hoje;
echo ‘<br />’;
//A variável terá o nome inválido, portanto não irá funcionar
$nome = '123'; $$nome = '456'; echo $123;
?>
CONSTANTES Uma constante armazena um valor como uma variável, mas seu
valor é atribuído uma vez e não pode ser alterado em outra parte do script.
Nomenclatura similar as variáveis normais, com algumas pequenas diferenças:
Usar nome em maiúsculo, para distinguir variáveis de constantes. (Não é obrigado, mas facilita a leitura do código)
Obrigatoriamente não colocar o sinal de cifrão “$” na frente do nome. Case sensitive
19
<?php define( "MONITOR" , 700 ); define( "LOCAL" , "Brasil" ); define( "VALIDO" , true ); define( "1CARRO" , 3 ); //Nome inválido
echo MONITOR; echo “<br />"; echo LOCAL; echo “<br />"; echo VALIDO;?>
CONSTANTES MÁGICAS
http://www.php.net/manual/pt_BR/language.constants.predefined.php
20
OPERADORES
Desenvolvimento...
21
OPERADORES ARITMÉTICOS
Similares aos operadores matemáticos.
22
Nome Operador Exemplo
Adição + $a + $b
Subtração - $a - $b
Multiplicação * $a * $b
Divisão / $a / $b
Módulo % $a % $b
OPERADORES ARITMÉTICOS
Similares aos operadores matemáticos.
23
Nome Operador Exemplo
Adição + $a + $b
Subtração - $a - $b
Multiplicação * $a * $b
Divisão / $a / $b
Módulo % $a % $b
APRENDA FAZENDO
Escreva o código abaixo no arquivo operadores_aritmeticos.php
24
<?php
//ALIMENTANDO VARIÁVEIS $a = 1; $b = 2; $c = 3; $d = 4; $e = -1;
//OPERADOR DE ADIÇÃO $adicao = $a + $b; //OPERADOR DE SUBTRAÇÃO $subtracao = $c - $a; //OPERADOR DE MULTIPLICAÇÃO $multiplicacao = $b * $c; //OPERADOR DE DIVISÃO $divisao = $d / $b;
//OPERADOR DE MÓDULO $modulo = $d % $c; ?>
ESTUDO DE CASO
Imprima o nome da operação e a operação com resultado.
…Continue com as outras operações.
25
<?php
//IMPRIMIR RESULTADOS
echo "Adicao : "; echo $a; echo " + "; echo $b; echo " = "; echo $adicao;
echo "<br />";
echo "Subtracao : "; echo $c; echo " - "; echo $a; echo " = "; echo $subtracao;
echo "<br />"; ?>
OPERADOR DE STRING
Conhecido como concatenação, é possível juntar e armazenas uma ou mais strings.
26
<?php
$nome = "Antonio Itamar"; $sobrenome = " Junior";
$nome_completo = $nome . $sobrenome;
echo $nome_completo;
?>
APRENDA FAZENDO
Escreva o código abaixo no arquivo operador_string.php
27
<?php
$nome = "Antonio Itamar"; $sobrenome = " Junior";
$nome_completo = $nome . $sobrenome;
echo $nome_completo; ?>
CONCATENAÇÃO AVANÇADA
28
OPERADORES DE ATRIBUIÇÃO DE COMBINAÇÃO
Cada um dos operadores abaixo, é um modo abreviado de fazer uma operação aritmética.
29
Operador Utilização Equivalente a
+= $a += $b $a = $a + $b
-= $a -= $b $a = $a - $b
*= $a *= $b $a = $a * $b
/= $a /= $b $a = $a / $b
%= $a %= $b $a = $a % $b
.= $a .= $b $a = $a . $b
APRENDA FAZENDO
30
<?php
$a = $a . “Oi"; echo $a . $a = $a . “Brasil"; $a = $a . "Teste";
$a = $a . "Teste"; $sobrenome = " Junior";
$nome_completo = $nome . $sobrenome;
echo $nome_completo;
?>
AULA 2
• Pré e pós incremento e decremento
PRÉ E PÓS INCREMENTO E DECREMENTO
32
Pré-incremento – primeiro incrementa (+1) na variável informada em seguida retorna o valor incrementado.
Pós-incremento – primeiro retorna o valor da variável em seguida é incrementado (+1).
Para decrementar (--) é semelhante, entretanto o valor da variável vai decrementar em vez de incrementar.
++$variavel;
$variavel++;
APRENDA FAZENDO
Escreva o código abaixo no arquivo pre_pos_incremento.php
33
<?php
echo 'Pos-Incremento'; echo '<br />'; echo 'Primeira Chamada = ' . $i++; echo '<br />'; echo 'Segunda Chamada = ' . $i; echo '<br />'; echo '<br />';
echo 'Pre-Incremento'; echo '<br />'; echo 'Primeira Chamada = ' . ++$j; echo '<br />'; echo 'Segunda Chamada = ' . $j;
?>
diferença de = para ==
34
ESTRUTURA DE CONTROLE: INSTRUÇÃO IF
Case sensitive; Sintaxe para única instrução
Sintaxe para várias instruções
Sintaxe alternativa Substitui a chave de abertura ({) por dois-pontos (:) e a chave de
fechamento por uma nova palavra-chave, que será endif
35
if( expressão Boolean ) instruções
if( expressão Boolean ){ instruções}
if( expressão Boolean ): instruçõesendif;
APRENDA FAZENDO
36
TABELA DA VERDADE
E | OU
If com mais de uma condição.
37
ESTRUTURA DE CONTROLE: INSTRUÇÃO ELSE
38
ESTRUTURA DE CONTROLE: INSTRUÇÃO ELSEIF
39
ESTUDO DE CASO
40
ESTRUTURA DE CONTROLE: INSTRUÇÃO SWITCH
Funciona de modo semelhante a instrução if. Sintaxe
A palavra-chave break quer dizer que a instrução irá parar assim que encontrá-la. 41
switch ( $a ){ case 'Brasil': //EXECUTA AÇÃO break;
case 5: //EXECUTA AÇÃO break;
default: //EXECUTA AÇÃO break;}
APRENDA FAZENDO
Escreva o código abaixo no arquivo switch.php
42
<?php
$a = ‘Brasil’; switch ( $a ) { case 'Brasil': echo ‘Sou Brasileiro’; break;
case 'Argentina‘: echo "Sou Argentino"; break;
case 'Estados Unidos': echo 'Sou Norte Americano'; break;
default: echo 'Não possuo nacionalidade'; break; } ?>
ESTRUTURA DE CONTROLE PARA REPETIÇÃO
As instruções while, do-while, for e foreach, são consideradas instruções de controle iterativo (repetição), podendo executar alguma parte do código várias vezes.
43
ESTRUTURA DE CONTROLE: INSTRUÇÃO WHILE
Como em uma instrução if ele conta com uma condição seja ‘true’ ou ‘false’.
No início de cada iteração, a condição será testada, se a condição for true a instrução será executada, caso seja false, o bloco não será executado e o loop terminará.
Sintaxe
Sintaxe alternativa
44
while( expressão Boolean ){ instruções}
while( expressão Boolean ): instruçõesendwhile;
APRENDA FAZENDO
Escreva o código abaixo no arquivo while.php
45
<?php
$a = 0; while ( $a < 10 ) { echo $a . ‘<br />'; $a++; } ?>
ESTRUTURA DE CONTROLE: INSTRUÇÃO DO-WHILE
Loops do-while são bem similares aos loops while, exceto pelo fato de que a condição é verificada no fim de cada iteração em vez de no começo.
A primeira iteração de um loop do-while é garantidamente executada (a condição só é verificada no fim da iteração) .
Não é obrigatório executar o loop (condição diferente de true).
Sintaxe única
46
do{ instruções}while( expressão Boolean );
APRENDA FAZENDO
Escreva o código abaixo no arquivo do_while.php
47
<?php
//EXECUTA A PRIMEIRA ITERAÇÃO, E ENTRA NO LOOP $a = 0; do { echo $a . ‘<br />'; $a++; } while ( $a < 10 );
echo ‘<br />';
//EXECUTA APENAS A PRIMEIRA ITERAÇÃO, MAS NÃO EXECUTA O LOOP $a = 0; do { echo $a . ‘<br />'; $a++; } while ( $a > 10 );
?>
ESTRUTURA DE CONTROLE: INSTRUÇÃO FOR Sintaxe
Expressão 1 – é executada uma vez incondicionalmente no início do loop (normalmente valor inicial de um contador).
Expressão 2 – é avaliada no início de cada iteração, se a expressão for true o loop continua, caso seja false o loop termina (normalmente testará o contador com um limite).
Expressão 3 – é executada no fim de cada iteração (normalmente ajustará o valor do contador).
Sintaxe alternativa 48
for( expressão 1 ; expressão 2 ; expressão 3 ){ instruções}
for( expressão 1 ; expressão 2 ; expressão 3 ): instruçõesendfor;
APRENDA FAZENDO
Escreva o código abaixo no arquivo for.php
49
<?php
//SINTAXE 1 for ( $a = 1; $a <= 10; $a++ ) { echo $a . ‘ ‘; }
?>
ESTRUTURA DE CONTROLE: INSTRUÇÃO FOR
Cada uma das expressões pode ser vazia ou conter múltiplas expressões separadas por vírgulas.
Em expr2, todas as expressões separadas por vírgula são avaliadas mas o resultado é obtido pela última parte.
expr2 vazia significa que o loop pode rodar indefinidamente (PHP considera-a implicitamente como TRUE, como em C).
50
APRENDA FAZENDO
Escreva o código abaixo no arquivo for.php
51
<?php
//SINTAXE 1 for ( $a = 1; $a <= 10; $a++ ) { echo $a . ‘ ‘; }
echo ‘<br />‘;
//SINTAXE 2 for ( $a = 1; ; $a++ ) { if ( $a > 10 ) { break; } echo $a . ‘ ‘; }
?>
ESTRUTURA DE CONTROLE: BREAK E CONTINUE
break cancela a execução do comando for, foreach, while, do-while ou switch atual.
break aceita um argumento numérico opcional que diz a ele quantas estruturas aninhadas englobadas devem ser quebradas.
http://www.php.net/manual/pt_BR/control-structures.break.php
52
ESTRUTURA DE CONTROLE: INSTRUÇÃO DECLARE
O construtor declare é utilizado para configurar diretivas de execução para blocos de código. A sintaxe do declare é similar a sintaxe de outros construtores de controle.
http://br2.php.net/manual/pt_BR/control-structures.declare.php
53
AULA 3
• Array
FUNÇÕES DO PHP
Conheça algumas forma de visualizar o conteúdo de um array.
55
Função Descrição
var_damp() Utilizado para representação estruturada sobre uma ou mais expressões, incluindo o tipo, a chave e o valor
print_r() Utilizado para imprimir a estrutura de um array, contendo a chave e o valor
<pre></pre> Tag HTML para formatar uma saída (texto).
APRENDA FAZENDO
Escreva o código abaixo no arquivo array.php
56
<?php $a = array( 10 , 20 , 30 );
//IMPRIMINDO ARRAY - VAR_DUMP var_dump( $a );
echo '<br />‘;
//IMPRIMINDO ARRAY - PRINT_R print_r( $a );
echo '<br />';
//FORMATANDO IMPRESSÃO - VAR_DUMP echo '<pre>'; var_dump( $a ); echo '</pre>'; echo '<br />';
//FORMATANDO IMPRESSÃO - PRINT_R echo '<pre>'; print_r( $a ); echo '</pre>';
?>
ARRAY – ACESSANDO CONTEÚDO
Arquivo: acessando_array.php
Observação: Echo $a[] // vai dar erro.
57
<?php $a = array( 10 , 20 , 30 , ‘Brasil’ , true , 30.7 );
echo $a[0] . '<br />‘; echo $a[1] . '<br />‘; echo $a[2] . '<br />‘; echo $a[3] . '<br />‘; echo $a[4] . '<br />‘; echo $a[5] . '<br />‘;
Manipular valor echo $a[0] = ‘Alterando valor da posição 0.‘; echo $a[0] . '<br />‘;
?>
ESTUDO DE CASO – ACESSANDO ARRAY
Arquivo: estudo_caso_acessando_array.php
58
<?php $a = array( 10 , 20 , 30 , ‘Brasil’ , true , 30.7 );
For( $i = 0 ; $i <= 5 ; $i++ ) { echo $a[$i] . '<br />‘; }
?>
ARRAYS COM ÍNDICES (CHAVES)
O função array por padrão já cria automaticamente suas chaves, iniciando com 0 e indo até N;
A chave pode ser string ou integer; Arrays com chaves Float, serão transformados em Int; Utilizar True como chave será interpretado como Integer 1. Utilizando False como chave será avaliado como Integer 0. Utilizando Null como chave será avaliada como uma String vazia. O valor pode ser qualquer tipo PHP;
Sintaxe
59
array( chave => valor , ... )
ACESSANDO CONTEÚDO DE ARRAY COM CHAVES
Declara o array com todas as chaves e valores necessários
Declara o array com apena uma chave e um valor, implementando o resto depois da declaração inicial do array
Não foi iniciado nenhum array
60
$a = array( 'mouse' => 30 , 'monitor' => 400 , 'teclado' => 45 );
$a = array( 'mouse’ => 30 ); $a['monitor'] = 400; $a['teclado'] = 45;
$a[‘mouse'] = 30; $a['monitor'] = 400; $a['teclado'] = 45;
APRENDA FAZENDO
Escreva o código abaixo no arquivo array_chave.php (1/2)
61
<?php //SINTAXE 1 $a = array( 'mouse' => 30 , 'monitor' => 400 , 'teclado' => 45 );
//SINTAXE 2 $b = array( 'mouse' => 30 ); $b['monitor'] = 400; $b['teclado'] = 45;
//SINTAXE 3 $c['mouse'] = 30; $c['monitor'] = 400; $c['teclado'] = 45;
//EXIBIR CONTEÚDO echo $a['mouse'] . '<br />'; echo $b['teclado'] . '<br />'; echo $c['monitor'] . '<br />';
...CONTINUAÇÃO
Escreva o código abaixo no arquivo array_chave.php (2/2)
62
$d = array( 'a' => true , 3 => 20 , 5.3 => 30 , true => 'Texto 1' , false => 'Texto 2' , null => 'Texto3‘ ); //IMPRIMIR ARRAY - VAR_DUMP echo '<pre>'; var_dump( $d ); echo '</pre>'; echo '<br />';
//FORMATANDO IMPRESSÃO - PRINT_R echo '<pre>'; print_r( $d ); echo '</pre>';
?>
FUNÇÕES DO PHP
Conheça algumas forma de visualizar o conteúdo de um array utilizando funções de iteração.
63
Função Descrição
foreach Estrutura de controle similar a while e for, oferecendo uma maneira fácil de iterar sobre arrays ( matrizes)
ESTRUTURA DE CONTROLE: INSTRUÇÃO FOREACH
O foreach funciona somente com variáveis do tipo arrays, qualquer variável diferente de array a função retornará um erro “Warning: Invalid argument supplied for foreach()”
Sintaxe
Varre uma matriz dada por variavel_array. Em cada 'loop', o valor do elemento corrente é atribuído a $valor .
Sintaxe alternativa
Atribui a chave do elemento atual à variável $chave em cada iteração.
64
foreach ( variavel_array as $valor ){ instrucoes}
foreach ( variavel_array as $chave => $valor ){ instrucoes}
APRENDA FAZENDO
Escreva o código abaixo no arquivo foreach.php
65
<?php $a = array( ‘mouse’ => 30 , 'monitor' => 400 , 'teclado' => 45 );
//SINTAXE 1 foreach ( $a as $valor ) { echo $valor . ' '; }
echo '<br />'; echo '<br />';
//SINTAXE 2 foreach ( $a as $chave => $valor ) { echo 'Chave: ' . $chave . ', valor: ' . $valor . '<br />'; }?>
OPERADORES DE ARRAY
66
Nome Operador Exemplo Resultado
União + $a + $b O array $b é anexado a $a, mas os conflitos de chaves não são adicionados, prevalecendo $a
Igualdade == $a == $b Verdadeiro se $a e $b contêm os mesmos valores com as mesmas chaves.
Identidade === $a === $b Verdadeiro se $a e $b contêm os mesmos valores do mesmo tipo na mesma ordem com as mesmas chaves.
Desigualdade != $a != $b Verdadeiro se $a e $b não contêm os mesmos valores.
Desigualdade <> $a <> $b O mesmo que !=.
Não-identidade !== $a !== $b Verdadeiro se $a e $b não contêm os mesmos valores do mesmo tipo na mesma ordem.
APRENDA FAZENDO
Escreva o código abaixo no arquivo array_operadores.php
67
<pre> <?php
$a = array( 1 , 2 , 3 ); $b = array( 'a' => 1 , 2 , 3 ); $c = array( 1 => 2 , 2 => 3 , 0 => 1 ); $d = array( '1' , '2' , '3' ); $e = array( 5 => 'Brasil' , 6 => 'Argentina' , 7 => 'Chile' ); //UNIÃO DE ARRAYS print_r( $a + $b );
//UNIÃO DE ARRAYS print_r( $a + $e );
//IGUALDADE DE ARRAYS var_dump( $a == $c );
//IDENTIDADE DE ARRAYS var_dump( $a === $c );
//IDENTIDADE DE ARRAYS var_dump( $a === $d ); ?></pre>
AULA 4
• Função
FUNÇÕES
São utilizadas para encapsular um pedaço de código que realiza uma tarefa única e bem definida.
Não é possível cancelar ou alterar a definição de funções previamente declaradas.
Qualquer código PHP válido pode aparecer dentro de uma função, mesmo outras funções.
É iniciada com a palavra-chave function. Sintaxe declaração
Sintaxe chamada69
function nome(){ instruções da função}
nome();
FUNÇÕES – NOMENCLATURA
É importante considerar que o nome da função deve ser descritivo – descrever o que a função faz.
Não é possível sobrepor uma função – não é possível ter mais de uma função com o mesmo nome.
Não é permitido cria uma função com o mesmo nome de uma função predefinida pelo PHP.
Somente é permitido: letras , número e sublinhados. Não pode iniciar com número. Não é case-sensitive – nome() é igual a NOME().
70
Válido Inválido
nome() 5nome()
nome2() somar-numeros()
_nome_tres() $exibir()
nomeQuatro() count()
APRENDA FAZENDO
Escreva o código abaixo no arquivo funcao.php
Chamando funções
71
<?php function hello() { echo 'Hello World'; }?>
<?php $nome = ‘hello’; function hello() { echo 'Hello World‘ . ‘<br />’; }
hello(); $nome(); ?>
nome_da_função();$nome_da_variável();
FUNÇÕES – ESCOPO
Conclusão O que esta dentro da função só funciona dentro; O que esta fora só funciona fora da função;
Todas as funções no PHP tem escopo global - elas podem ser chamadas fora de uma função mesmo que tenham sido definidas dentro e vice-versa.
72
$a = 1; echo $a; //Exibe 1 function hello() { echo $a; //Não exibe nada } echo $a; //Exibe 1
$a = 1; echo $a; //Exibe 1 function hello() { $a = 3; $b = 5; echo $a; //Exibe 3 echo $b; //Exibe 5 } echo $a; //Exibe 1 echo $b; //Não exibe nada
FUNÇÕES – RETORNO
Funciona como um exit na função. Diferença: echo X return
73
<?php function hello() { echo 'Hello World'; }
hello();?>
<?php function hello() { return ( 'Hello World' ); }
echo hello();?>
APRENDA FAZENDO
Escreva o código abaixo no arquivo funcao_retorno.php
74
<?php function hello() { return ( 'Hello World' ); }
echo hello(); $a = hello();?>
ESTUDO DE CASO – FUNÇÃO
75
FUNÇÕES – PARÂMETRO
Os parâmetros permitem introduzir vários valores em uma função para influenciar seu comportamento.
Todos os parâmetros serão obrigatórios excerto quando for definido como opcional (atribuído um valor padrão).
É permitido informar mais parâmetros do que foi declarado na função.
Não é permitido informar menos parâmetros do que foi declarado.
Sintaxe
76
function nome( $par1 , $par2 , .... ){}
function nome( $par1 , $par2 , $par3 = 1 , .... ){}
APRENDA FAZENDO
Escreva o código abaixo no arquivo funcao_parametro.php
77
<?php function hello( $par1 ) { echo 'Hello ' . $par1; }
hello( 'World' );
echo '<br />';
//FUNÇÃO COM VALOR OPCIONAL
function hello2( $par1 , $par2 = 'Blue' ) { echo 'Hello ' . $par1 . ' ' . $par2; }
hello2( 'World' );
echo '<br />';
hello2( 'World' , 'red' );
?>
ESCOPO DE VARIÁVEIS
Escopo refere-se ao local onde a variável é visível.
78
Superglobal Visíveis por toda parte dentro de um script
Constantes Uma vez declarada, são sempre visíveis globalmente, podem ser usadas dentro e fora das funções
Variáveis Declaradas em um script são visíveis por todo esse script, mas não dentro de funções
79
<?php function calculadora( $num1 , $num2 , $operacao ) { if ( $operacao == "adicao" ) { $resultado = $num1 + $num2; } elseif ( $operacao == "subtracao" ) { $resultado = $num1 - $num2; } elseif ( $operacao == "multiplicacao" ) { $resultado = $num1 * $num2; } elseif ( $operacao == "divisao" ) { $resultado = $num1 / $num2; } else { $resultado = "Informe uma operacao valida”; }
return ( $resultado ); }
echo calculadora( 1 , 2 , “adicao" );
?>
80
<?php function imprimirArray( $par1 ) { foreach ( $par1 as $valor ) { $b = $b . $valor; } return ( $b ); }
$a = array( 1 , 2 , 3 , 4 , 5 );
echo imprimirArray( $a );
?>
FUNÇÕES – PARÂMETRO POR REFERÊNCIA
Veja aprenda fazendo.
81
APRENDA FAZENDO Escreva o código abaixo no arquivo funcao_parametro_por_referencia.php
82
<?php function incrementar( &$par1 , $incremento = 1 ) { $par1 = $par1 + $incremento; }
$valor = 10; echo $valor . '<br />'; incrementar( $valor ); echo $valor . '<br />';
echo '<br />';
$valor2 = 20; echo $valor2 . '<br />'; incrementar( $valor2 , 5 ); echo $valor2 . '<br />';
?>
AULA 5
• Orientação a Objetos
ORIENTAÇÃO A OBJETOS – 10 HORAS
- Declaração de classe
- Nomenclatura
- Instanciar classe
- Utilizar atributos e métodos de classe
OOP – PROGRAMAÇÃO ORIENTADA A OBJETOS
85
DECLARAÇÃO DE CLASSE
A classe é formada por: Atributos ( variáveis ) utilizando a palavra-chave var; Métodos ( funções ) utilizando a palavra-chave function;
Sintaxe
86
class NomeDaClasse{ var $atributo;
function metodo() { }}
APRENDA FAZENDO
Escreva o código abaixo no arquivo classe.php
87
<?php class NomeDaClasse { var $atributo1; var $atributo2;
function metodo1() { }
function metodo2( $par1 , $par2 ) {
}
}
?>
NOMENCLATURA
Não é possível declarar mais de um atributo ou método com o mesmo nome.
Classe Atributo Método
88
INSTANCIAR CLASSE
Após declarar uma classe, é possível criar um ou vários objetos que seja membro dela.
A criação de objetos é conhecida também como criar uma instância ou instanciar uma classe.
Para informar ao servidor que queremos instanciar uma classe iremos utilizar a palavra-chave new.
Neste momento, a variável $a possui um objeto da classe NomeDaClasse. 89
class NomeDaClasse{ var $atributo;
function metodo() { }}
$a = new NomeDaClasse();
UTILIZAR ATRIBUTOS E MÉTODOS DE CLASSE
Todos os atributos e métodos de uma classe pertencem apenas ao escopo da classe e de seus objetos,
Não é possível utilizar um atributo ou chamar um método sem referenciar sua classe.
Sintaxe para utilização fora da classe.
90
class NomeDaClasse{ var $atributo;
function metodo() { }}
$a = new NomeDaClasse();$a->atributo;$a->atributo = 1;$a->metodo();
APRENDA FAZENDO
Escreva o código abaixo no arquivo instanciar_classe.php
91
<?php class Carro { var $ano; var $cor;
function andar() { return('Método que faz o carro andar!'); } }
//CRIAR UMA INSTÂNCIA DA CLASSE CARRO. $carro1 = new Carro();
//ATRIBUIR VALORES AO OBJETO. $carro1->ano = 2009; $carro1->cor = 'Prata';
//IMPRIMIR VALORES DO OBJETO. echo $carro1->ano; echo '<br />'; echo $carro1->cor; echo '<br />';
//CHAMAR FUNCIONALIDADES DO OBJETO. echo $carro1->andar(); ?>
ESTUDO DE CASO – PROCURAR EXEMPLOS QUE EXEMPLIFIQUE A USO DE HERANÇA, POIS SERA UTIL PARA APROVEITAR NESSE ESTUDO DE CASO
Arquivo: estudo_caso_instanciar_classe.php
Impressão:
Ano: 2009
Cor: Preto
Velocidade: 300
Moto andando…
Moto Parada
92
Transporte
+ ano+ cor+ velocidade
+ andar()+ parar()
UTILIZAR ATRIBUTO E MÉTODO INTERNO
Para ter acesso a atributos ou métodos dentro de uma classe, deverá ser utilizado a palavra-chave $this ( variável nativa ).
$this é uma usada para referenciar o objeto corrente (objeto utilizado no momento).
Sintaxe para utilização dentro da classe.
93
class NomeDaClasse{ var $atributo;
function metodo() { $this->atributo; $this->metodo2(); }
function metodo2() { }}
$a = new NomeDaClasse();$a->atributo = 3;$a->metodo();
94
95
<?php class Carro { var $ano; var $cor; function andar() { return( 'Método que faz o carro andar!<br />‘ . $this->obterInformacao() ); }
function obterInformacao() { return('Informações obtidas - Ano: ' . $this->ano . ' , Cor: ' . $this->cor); } }
//CRIAR UMA INSTÂNCIA DA CLASSE CARRO. $carro1 = new Carro();
//ATRIBUIR VALORES AO OBJETO. $carro1->ano = 2009; $carro1->cor = 'Prata';
//IMPRIMIR VALORES DO OBJETO. echo $carro1->ano; echo '<br />'; echo $carro1->cor;
//CHAMAR FUNCIONALIDADES DO OBJETO. echo $carro1->andar(); echo '<br />'; echo $carro1->obterInformacao();
?>
UTILIZAR ATRIBUTO E MÉTODO DE OUTRA CLASSE
96
HERANÇA
É ser capaz incorporar os atributos e métodos de uma classe previamente definida.
Para uma classe herdar atributos e métodos de outra classe usa-se a palavra-chave extends.
97
class A{ var $atributo1; function metodo1() { }
}class B extends A{ var $atributo2; function metodo2() { }}
$b = new B();$b->atributo2;$b->metodo2();$b->atributo1;$b->metodo1();
APRENDA FAZENDO Arquivo: usuario.php
98
<?php class Usuario { var $nome; var $email; var $senha;
function inserir() { return ('Chamando método para inserir usuário.'); } function obterInformacao() { return ('Obter Informações de Usuário.'); } }?>
APRENDA FAZENDO Arquivo: cliente.php
Arquivo: funcionario.php
99
<?php class Cliente extends Usuario {
}?>
<?php class Funcionario extends Usuario { var $cargo; var $salario; }?>
APRENDA FAZENDO Arquivo: cliente.php
100
<?php class Cliente extends Usuario {
}
$objeto = new Cliente(); $objeto->nome = 'Junior'; $objeto->email = 'junior@agenciatrack.com.br'; $objeto->senha = '123'; echo $objeto->inserir(); echo $objeto->obterInformacao();
?>
APRENDA FAZENDO Arquivo: funcionario.php
101
<?php class Funcionario extends Usuario { var $cargo; var $salario; }
$objeto = new Funcionario(); $objeto->nome = 'Júnior'; $objeto->email = 'junior@agenciatrack.com.br'; $objeto->senha = '123'; $objeto->cargo = 'Programador'; $objeto->salario = 3000; echo $objeto->inserir(); echo $objeto->obterInformacao();
?>
FUNÇÕES DO PHP
Conheça algumas forma de importar arquivos .
102
Função Descrição
require Importar o arquivo informado para o arquivo que esta chamando a função, caso não seja encontrado o arquivo informado será exibido um Warning seguido de um Fatal error.
include Semelhante ao require porém, caso não seja encontrado o arquivo informado será exibido apenas um Warning.
require_once Identico ao require porém importa o arquivo apenas uma unica vez.
include_once Identico ao include porém importa o arquivo apenas uma unica vez.
APRENDA FAZENDO - REQUIRE Arquivo: cliente.php
Arquivo: funcionario.php
103
<?php require_once('usuario.php'); class Cliente extends Usuario { ... }?>
<?php require_once('usuario.php'); class Funcionario extends Usuario { ... }?>
POLIMORFISMO
104
APRENDA FAZENDO Arquivo: funcionario.php
105
<?php require_once('usuario.php'); class Funcionario extends Usuario { var $cargo; var $salario;
function obterInformacao() { return ('Obter Informações de Funcionário.'); } } $objeto = new Funcionario(); $objeto->nome = 'Junior'; $objeto->email = 'junior@agenciatrack.com.br'; $objeto->senha = '123'; $objeto->cargo = 'Programador'; $objeto->salario = 3000; echo $objeto->inserir(); echo $objeto->obterInformacao();?>
APRENDA FAZENDO Arquivo: funcionario.php
106
<?php require_once('usuario.php'); class Funcionario extends Usuario { var $cargo; var $salario;
function obterInformacao() { return ('Obter Informações de Funcionário.<br />' . 'Nome: ' . $this->nome . '<br />' . 'E-mail: ' . $this->email . '<br />' . 'Senha: ' . $this->senha . '<br />' . 'Cargo: ' . $this->cargo . '<br />' . 'Salário: ' . $this->salario . '<br />'); } }
$objeto = new Funcionario(); ... ALIMENTAÇÃO DO OBJETO ...?>
ESTUDO DE CASO Saída do arquivo: funcionario.php
Chamando método para inserir usuário.
Obter Informações de Funcionário.
Nome: Júnior
E-mail: junior@agenciatrack.com.br
Senha: 123
Cargo: Programador
Salário: 3000
Saída do arquivo: cliente.php
Chamando método para inserir usuário.
Obter Informações de Usuário.
Nome: Júnior
E-mail: junior@agenciatrack.com.br
Senha: 123
107
VISIBILIDADE
Conheça as quatro formas de especificar atributos e métodos de classe.
108
Acesso Descrição
public (default) Os recursos podem ser acessados de dentro ou de fora da classe.
private Os recursos podem ser acessados apenas dentro da classe onde foi definido e não serão herdados.
protected Os recursos podem ser acessados apenas dentro da classe onde foi definido e em seus descendentes.
final Os recursos podem ser acessados de dentro ou de fora da classe, mas não podem ser sobreposto em seus descendentes.
APRENDA FAZENDO
Escreva o código abaixo no arquivo visibilidade.php
109
<?php class A { public $atributo1; protected $atributo2; private $atributo3;
public function metodo1() { echo 'Chamando o método 1! <br />'; } protected function metodo2() { echo 'Chamando o método 2! <br />'; } private function metodo3() { echo 'Chamando o método 3! <br />'; } public function metodo4() { $this->atributo3; $this->metodo3(); echo 'Chamando o método 4! <br />'; } }
CONTINUAÇÃO...
110
class B extends A { public function metodo5() { $this->atributo1; $this->atributo2; //$this->atributo3; //Ocorre erro porque o $atributo3 é private. $this->metodo1(); $this->metodo2(); //$this->metodo3(); //Ocorre erro porque o metodo3() é private. } }
$a = new A(); $a->atributo1; //$a->atributo2; //Ocorre erro porque o $atributo2 é protected. //$a->atributo3; //Ocorre erro porque o $atributo3 é private. $a->metodo1(); //$a->metodo2; //Ocorre erro porque o metodo2() é protected. //$a->metodo3; //Ocorre erro porque o metodo3() é private. $a->metodo4();
$b = new B(); $b->atributo1; $b->metodo1(); $b->metodo5();
?>
VISIBILIDADE FINAL
Não permite sobrepor um método.
111
APRENDA FAZENDO
Escreva o código abaixo no arquivo visibilidade_final.php
112
<?php class A { public $atributo1; public function metodo1() { echo 'Chamando o método 1! <br />'; } final function metodo2() { echo 'Chamando o método 2! <br />'; } }
class B extends A { //O MÉTODO metodo2 FOI DEFINIDO COMO final NA CLASSE A. public function metodo2() { echo 'Chamando o método 2! <br />'; } }
?>
CONSTRUTOR
É chamado automaticamente quando um objeto é criado. Deve ser definido como público, para poder instanciar objetos
de fora da classe. Para definir métodos como construtor de uma classe, deverá
ser utilizado a palavra-chave __construct.
113
class NomeDaClasse{ public $atributo;
public function __construct() { }
}
$a = new NomeDaClasse();
APRENDA FAZENDO Arquivo: construtor.php
114
<?php class A { var $cargo; var $salario;
public function __construct() { return ('Chamando o método construtor.'); } } $objeto = new Funcionario(); $objeto->nome = 'Junior'; $objeto->email = 'junior@agenciatrack.com.br'; $objeto->senha = '123'; $objeto->cargo = 'Programador'; $objeto->salario = 3000; echo $objeto->inserir(); echo $objeto->obterInformacao();?>
class A { public function __construct() { return 'Chamando o método construtor! <br />'; } public function metodo1() { return 'Chamando metodo1! <br />'; } }
$a = new A(); $a->metodo1();
APRENDA FAZENDO
Escreva o código abaixo no arquivo construtor.php
115
<?php class A { public function __construct() { echo 'Chamando o método construtor! <br />'; } public function metodo1() { return 'Chamando metodo1! <br />'; } }
class B { public function __construct( $mensagem ) { return 'Chamando o método construtor com a mensagem ' . $mensagem . '! <br />'; } }
$a = new A(); $a->metodo1();
$b = new B( 'Hello Construct Class' );?>
ATRIBUTOS E MÉTODOS ESTÁTICOS
Um método estático não pode chamar atributos não-estáticos.
116
APRENDA FAZENDO
Escreva o código abaixo no arquivo static.php
117
<?php class A { public static $atributo1 = '123 <br />'; public static function metodo1() { echo 'Chamando metodo1! <br />'; } }
//CHAMAR ESTATICAMENTE. A::metodo1(); //O método pode ou não ser static. echo A::$atributo1; //O atibuto deve ser static. echo '<br />'; //CHAMAR POR OBJETO. $a = new A(); $a->metodo1(); //O método pode ou não ser static. echo $a->atributo1; //Não é possível chamar atributo estático pelo objeto;
?>
ATRIBUTOS E MÉTODOS ESTÁTICOS
Para ter acesso a atributos ou métodos estáticos dentro de uma classe, devemos utilizar a palavra-chave self::
118
COMPARANDO STATIC COM NÃO-STATIC
119
Desabilite (comentando) todo o script do static.php Escreva o código abaixo no arquivo static.php
120
<?php class A { public static $atributo1 = '123 <br />';
public static function metodo1() { echo self::$atributo1; echo 'Chamando metodo1! <br />'; self::metodo2(); } public static function metodo2() { echo 'Chamando metodo2! <br />'; } }
//CHAMAR ESTATICAMENTE. A::metodo1(); //O método pode ou não ser static. echo A::$atributo1; //O atibuto deve ser static.
echo '<br />'; //CHAMAR POR OBJETO. $a = new A(); $a->metodo1(); //O método pode ou não ser static. echo $a->atributo1; //Não é possível chamar atributo estático pelo objeto;
?>
PADRÃO GET E SET
Utilizar os atributos da classe sempre private, excerto quando a regra de negócio não permitir.
121
class NomeDaClasse{ private $atributo;
public function getAtributo() { return ( $this->atributo ); }
public function setAtributo( $valor ) { $this->atributo = $valor; }
}
$a = new NomeDaClasse();$a->setAtributo( 'Brasil' );$a->getAtributo();
APRENDA FAZENDO Escreva o código abaixo no arquivo get_set.php
122
<?php class Carro { private $ano; private $cor;
public function getAno() { return $this->ano; } public function setAno( $valor ) { $this->ano = $valor; } public function getCor() { return $this->cor; } public function setCor( $valor ) { $this->cor = $valor; } }
$a = new Carro(); //$a->ano; //Atributo privado é acessado somente dentro da classe. $a->setAno( 2009 ); echo $a->getAno() . '<br />'; $a->setCor( 'Branco' ); echo $a->getCor();
?>
ESTUDO DE CASO
Implementar o Padrão Get Set nas classes: Usuario Funcionario Cliente
123
ESTUDO DE CASO
Arquivo: estudo_caso_calculadora_get_set.php
124
Calculadora
- num1- num 2
+ getNum1()+ setNum1( $value )+ getNum2()+ setNum2( $value )+ somar()+ subtrair()+ multiplicar()+ dividir()
ESTUDO DE CASO – ACESSAR ATRIBÚTO PRIVADO
Class Funcionario Ladrao 6% Mulher 50% Receita 100% Pretendente 2x Se nao informar ninguem pede para informar quem
que ver.
125
APRENDA FAZENDO Arquivo: funcionario.php
126
<?php class Funcionario extends Usuario { private $cargo; private $salario;
public function getSalario( $interessado == 'receita' ) { if( $interessado == 'receita' ) { return( $this->salario ); } elseif( $interessado == 'ladrão' ) { return( $this->salario * 0.06 ); } ... }
} $objeto = new Funcionario(); $objeto->getSalario( ‘ladrão’ ); $objeto->email = 'junior@agenciatrack.com.br'; $objeto->senha = '123'; echo $objeto->inserir(); echo $objeto->obterInformacao();
?>
PROGRAMAÇÃO WEB
- Métodos GET, POST, REQUEST
MÉTODO GET, POST E REQUEST
128
Explicar como passar variaveis pela url
129
Fazer um form_funcionario.html e enviar para class Funcionario e exibir os dados da mesma.
130
ESTUDO DE CASO
131
form_calculadora.html
Número 1:
Número 2:
Operação:
Calcular
processar_form_calculadora.php
POST
PHP + MYSQL – 5 HORAS
- Abrir conexão
- Executar comandos SQL
FUNÇÕES DO PHP
Conheça mais algumas funções necessárias.
133
Função Descrição
mysql_connect() Abre ou reutiliza uma conexão com um servidor MySQL.
die() Construtor da linguagem equivalente a exit().
mysql_error() Retorna o texto do erro da ultima função MySQL.
mysql_select_db Seleciona um banco de dados MySQL.
ABRIR CONEXÃO
134
APRENDA FAZENDO
Escreva o código abaixo no arquivo conexao.php
135
<?php
//TENTAR ABRIR UMA CONEXÃO COM BANCO DE DADOS. $linkConexao = mysql_connect( 'localhost' , 'root', '‘ ) or die( 'Não foi possível se conectar ao servidor MySQL: ' . mysql_error() );
//SELECIONAR BANCO DE DADOS mysql_select_db( 'banco_1' , $linkConexao ) or die( 'Não foi possível selecionar o banco da dados.' );?>
FUNÇÕES DO PHP
Conheça mais algumas funções necessárias.
136
Função Descrição
require() A instrução inclui e avalia o arquivo informado.
mysql_query() Envia uma consulta MySQL.
mysql_num_rows() Obtém o número de linhas em um resultado
EXECUTAR COMANDOS SQL
137
APRENDA FAZENDO
Escreva o código abaixo no arquivo executar_comandos_sql.php
138
<?php //IMPORTAR O ARQUIVO DE CONEXÃO COM O BANCO DE DADOS. require( 'conexao.php' );
//Executando a consulta SQL $comandoSQL = “INSERT INTO carro (modelo,ano,cor) VALUES (‘monza’,1993,’Preto’)”; $resultado = mysql_query( $comandoSQL );
?>
$linha_afetada1 = mysql_fetch_assoc($resultado);
echo $linha_afetada1[‘modelo’] . ‘<br />’;
echo $linha_afetada1[‘cor’] . ‘<br />’;
echo $linha_afetada1[‘ano’] . ‘<br />’;
Echo ‘<br />’;
$linha_afetada2 = mysql_fetch_assoc($resultado);
echo $linha_afetada2[‘modelo’] . ‘<br />’;
echo $linha_afetada2[‘cor’] . ‘<br />’;
echo $linha_afetada2[‘ano’] . ‘<br />’;139
while ( $linha_afetada = mysql_fetch_assoc($resultado) )
{
echo $linha_afetada[‘modelo’] . ‘<br />’;
echo $linha_afetada[‘cor’] . ‘<br />’;
echo $linha_afetada[‘ano’] . ‘<br />’;
echo ‘<br />’;
}
140
ESTUDO DE CASO
141
form_inserir_usuario.html
Nome:
E-mail:
Senha:
Salvar
sql_inserir_usuario.php
POST
ESTUDO DE CASO
Complete os get’s e set’s para todos os atributos.
142
<?php
//1. IMPORTAR CONEXÃO DO BANCO DE DADOS. require 'conexao.php'; //2. ESCREVER COMANDO SQL. $comandoSQL = "INSERT INTO usuario( nome , email , senha ) VALUES ( '" . $_POST['nome'] . "' , '" . $_POST['email'] . "' , '" . $_POST['senha'] . "' )"; //3. EXECUTAR COMANDO SQL. $resultado = mysql_query( $comandoSQL ); //4. EXIBIR MENSAGEM DE RETORNO. if ($resultado == true) { echo 'Usuário inserido com sucesso .'; } else { echo'Falha ao inserir usuário.'; }?>
sql_inserir_usuario.php
LISTAR_USUARIOS.PHP
<table border=”1”>
<tr bgcolor=“#F7F7F7”>
<td width=“100”>Código</td>
<td width=“200”>Nome</td>
<td width=“60”>Editar</td>
<td width=“60”>Excluir</td>
</tr>
<tr>
<td width=“100”>1</td>
<td width=“200”>Junior</td>
<td width=“60”>Ed</td>
<td width=“60”>Ex</td>
</tr>
</table>
143
<?php
require ‘conexao.php’;
$comando_sql = “SELECT * FROM usuario”;
$resultado = mysql_query( $comando_sql );
if ($resultado == false)
{
exit( ‘Falha ao recuperar usuário.’ );
}
$numLinhas = mysql_num_rows($resultado);
if ( $numLinhas == 0 )
{
exit( ‘Nenhum usuário encontrado.’ )
}
?>
144
<?php while( $linha_afetada = mysql_fetch_assoc($resultado) ){ ?>
<tr>
<td width=“100”><?php echo $linha_afetada[‘id_usuario’]?></td>
<td width=“200”><?php echo $linha_afetada[‘nome’]?></td>
<td width=“60”><a href=“form_alterar_usuario.php? id=<?php echo $linha_afetada[‘id_usuario’]?>”>Ed</a></td>
<td width=“60”>
<a href=“confirmar_exclusao_usuario.php?id=<?php echo $linha_afetada[‘id_usuario’]?>”>
Ex</a></td>
</tr>
<?php } ?>
145
Cria os dois arquivos de alterar e de confirmar exclusao
146
Arquivo: form_alterar_usuario.php
<form action=“sql_alterar_usuario.php” method=“POST”>
Nome: <input type=“text” name=“nome” value=“123” />
<br />
E-mail: <input type=“text” name=“email” value=“123” />
<br />
Senha: <input type=“password” name=“senha” value=“123” />
<br />
<input type=“submit” value=“salvar”>
</form>
<br />
<br />
<a href=“listar_usuarios.php”>Voltar para lista</a>
147
Arquivo: confirmar_exclusao_usuario.php
Deseja realmente excluir o usuario?
<br />
<br />
<a href=“sql_excluir_usuario.php?id=<?php echo $_GET[‘id’]?>”>Sim</a>
<br />
<a href=“listar_usuarios.php”>Nao</a>
148
Arquivo: sql_excluir_usuario.php
<?php
require ‘conexao’;
$comandoSQL = “DELETE FROM usuario WHERE id_usuario =“ . $_GET[‘id’];
$resultado = mysql_query( $resultado );
If( $resultado == true)
{
echo ‘Usuário excluido com sucesso.’;
}
else
{
echo ‘Falha ao excluir o usuário.’;
}
?>
<br />
<a href=“listar_usuarios.php”>Voltar para lista de usuários.</a>
149
Arquivo: form_alterar_usuario.php
<?php
require ‘conexao.php’;
$comandoSQL = “SELECT * FROM usuario WHERE id_usuario = ” . $_GET[‘id’];
$resultado = mysql_query( $comandoSQL );
if ($resultado == false)
{
exit(‘Falha ao executar comando SQL’);
}
$num_linhas = mysql_num_rows( $resultado );
if ( $num_linhas == 0 )
{
exit(‘’Nenhum usuário encontrado com o código informado);
}
… continua no proximo slide
150
Arquivo: form_alterar_usuario.php
…continuacao…
$linha_afetada = mysql_fetch_assoc( $resultado );
?>
<form action=“sql_alterar_usuario.php” method=“POST”>
Nome: <input type=“text” name=“nome” value=“<?php echo $linha_afetada [‘nome’]?>” />
<br />
E-mail: <input type=“text” name=“email” value=“123” />
<br />
Senha: <input type=“password” name=“senha” value=“123” />
<br />
<input type=“text” name=“id” value=“<?php echo $_GET[‘id’]?>”>
<input type=“submit” value=“salvar”>
</form>
<br />
<br />
<a href=“listar_usuarios.php”>Voltar para lista</a>
151
ALTERAR
152
<?php require 'conexao';
//2. ESCREVER COMANDO SQL. $comandoSQL = "UPDATE usuario SET nome = '" . $_POST['nome'] . "' , email = '" . $_POST['email'] . "' , senha = '" . $_POST['senha'] . "' WHERE id_usuario = " . $_POST['id'];
//3. EXECUTAR COMANDO SQL. $resultado = mysql_query( $comandoSQL );
//4. EXIBIR MENSAGEM DE RETORNO. if ( $resultado == true ) { echo 'Usuário alterado com sucesso.'; } else { echo 'Falha ao alterar usuário.'; }?><a href=“listar_usuarios.php”>Voltar para lista</a>
sql_alterar_usuario.php
Mudar campo id para hidden
153
154
form_alterar_usuario.php
listar_usuario.php
sql_alterar_usuario.php sql_excluir_usuario.php
PO
ST
sql_inserir_usuario.php
form_inserir_usuario.html
ARQUITETURA PRIMÁRIAARQUITETURA PRIMÁRIA
PO
ST
confirmar_exclusao_usuario.php
GE
T
155
POST
form_alterar_usuario.html
ARQUITETURA PRIMÁRIA - OOARQUITETURA PRIMÁRIA - OO
POST
form_inserir_usuario.html
GET
listar.html
GET
confirmar_exclusao_usuario.html
Usuario.php
Qual método?
156
POST
ARQUITETURA PRIMÁRIA CENTRALIZADA – OO ARQUITETURA PRIMÁRIA CENTRALIZADA – OO
POST
GET
GET
Index.php
Usuario.php
form_alterar_usuario.html
form_inserir_usuario.html
listar.html
confirmar_exclusao_usuario.html
Qual class ?Qual método?
PRIMEIRO PASSO.
Criar tabela no banco de dados.
157
CREATE TABLE usuario(id_usuario int not null auto_increment,nome varchar(100),email varchar(50),senha varchar(15),primary key (id_usuario))
SEGUNDO PASSO
Criar o formulário de inserção.
158
<form action="index.php?classe=Usuario&metodo=inserir" method="POST"> Nome: <input name="nome"> <br /> E-mail: <input name="email"> <br /> Senha: <input name="senha"> <br /> <input type="submit" value="Salvar"></form>
form_inserir_usuario.html
TERCEIRO PASSO
Criar método na classe, para exibir o formulário de inserção
159
<?php class Usuario { public function exibirFormInserir() { require( 'form_inserir_usuario.html' ); } }?>
Usuario.php
160
index.php?classe=Usuario&metodo=exibirFormInserir
QUARTO PASSO
Criar e encapsular os atributos da classe.
Complete os get’s e set’s para todos os atributos. 161
<?php class Usuario { private $idUsuario; private $nome; private $email; private $senha;
public function setId( $valor ) { $this->idUsuario = $valor; } public function getId() { return( $this->idUsuario ); }
}?>
Usuario.php
QUINTO PASSO Criar o método inserir.
Complete os get’s e set’s para todos os atributos.
162
<?php class Usuario { public function inserir() { //1. CRIAR UM OBJETO E ALIMENTAR COM OS DADOS DO FOMULÁRIO. $objeto = new Usuario(); $objeto->setNome( $_POST['nome' ] ); $objeto->setEmail( $_POST[ 'email' ] ); $objeto->setSenha( $_POST[ 'senha' ] );
//2. ESCREVER COMANDO SQL. $comandoSQL = "INSERT INTO carro ( nome , email , senha ) VALUES ( '" . $objeto->getNome() . "' , '" . $objeto->getEmail() . "' , '" . $objeto->getSenha() . "' )";
//3. EXECUTAR COMANDO SQL. $resultado = mysql_query( $comandoSQL );
//4. EXIBIR MENSAGEM DE RETORNO. }?>
Usuario.php
PÁGINA CONTROLADORA
1 – Recuperar classe e método; 2 – Importar (require) arquivo da classe informada. 3 – Cria um objeto da classe informada. 4 – Chamar o método informado pela url, na classe importada
163
Index.php
<?php
//RECUPERAR A CLASSE E O MÉTODO INFORMADO PELO USUÁRIO ATRAVÉZ DA URL. $classe = $_GET[ 'classe' ]; $metodo = $_GET[ 'metodo' ];
//DEFINIR UMA CLASSE E UM MÉTODO PADRÃO if ( $classe == false ) $classe = 'Usuario'; if ( $metodo == false ) $metodo = 'listar';
//IMPORTAR A CLASSE INFORMADA PELA URL. require( $classe . '.php' );
//CRIAR OBJETO DA CLASSE INFORMADA. $objClasse = new $classe();
//ACESSAR O MÉTODO INFORMADO PELA URL. $objClasse->$metodo(); ?>
<?php
$resultadoCategoria = Categoria::buscarTodos();
?>
<form action=“index.php?classe=produto&metodo=inserir”>
<?php if ($resultadoCategoria == true) :?>
<select name=“categoria”>
<?php while( $linha_afetada = mysql_fetch_assoc( $resultadoCategoria ) ):?>
<option value=“<?php echo $linha_afetada[‘id_categoria’]?>”><?php echo $linha_afetada[‘nome’]?></option>
<?php endwhile;?>
</select>
<?php endif;?>
164
APRENDA FAZENDO
Escreva o código abaixo no arquivo executar_comandos_sql.php
165
<?php //IMPORTAR O ARQUIVO DE CONEXÃO COM O BANCO DE DADOS. require( 'conexao.php' );
//Executando a consulta SQL $comandoSQL = 'SELECT * FROM carro'; $resultado = mysql_query( $comandoSQL , $linkConexao ); //RECUPERAR QUANTIDADE DE REGISTROS ENCONTRADOS. $numeroLinhas = mysql_num_rows( $resultado ); if ( $numeroLinhas == 0 ) { exit( 'Nenhum registro encontrado.' ); } //EXIBIR NÚMERO DE REGISTROS ENCONTRADOS. echo 'Foram encontrados: ' . $numeroLinhas . ' registros.<br /><br />'; //RECUPERAR CADA LINHA OBTIDA NO RESULTADO. while ( $linhaAfetada = mysql_fetch_assoc( $resultado ) ) { echo 'Código: ' . $linhaAfetada['id_carro'] . '<br />'; echo 'Modelo: ' . $linhaAfetada['modelo'] . '<br />'; echo 'Cor: ' . $linhaAfetada['cor'] . '<br />'; echo 'Ano: ' . $linhaAfetada[‘ano'] . '<br />'; echo '<br />'; }?>
REFERÊNCIA BIBLIOGRÁFICAS PHP
http://www.php.net Zend.PHP.5.Certification.Study.Guide.2006
MySQL http://www.mysql.com [acessado em 1 de maio de 2009 as 21Hrs] http://dev.mysql.com [acessado em 1 de maio de 2009 as 20Hrs] http://www.w3schools.com/sql [acessado em 1 de maio de 2009 as 21Hrs]
166
APRENDA FAZENDO
Escreva o código abaixo no arquivo heranca.php Fazer um exemplo mas simples para exemplificar a herança
porque esse do transporte sera usando para exeplificar require.
167
<?php class Transporte { var $velocidade; function andar() { echo 'Transporte andando! <br /> '; } }
class Carro extends Transporte { var $cor; var $rodas; function ligar() { echo 'Carro ligado! <br /> '; }
function obterInfo() { echo 'Cor: ' . $this->cor . ' Quantidade de rodas: ' . $this->rodas . ' Velocidade Máxima: ' . $this->velocidade . '<br />‘; } }
APRENDA FAZENDO
Arquivo: class_transporte.php
168
<?php class Transporte { var $velocidade; function andar() { echo 'Transporte andando! <br /> '; } }
?>
APRENDA FAZENDO
Arquivo: class_carro.php
169
<?php class Carro extends Transporte { var $cor; var $rodas; function ligar() { echo 'Carro ligado! <br /> '; }
function obterInfo() { echo 'Cor: ' . $this->cor . ' Quantidade de rodas: ' . $this->rodas . ' Velocidade Máxima: ' . $this->velocidade . '<br />‘; } }
?>
170
<?php class Transporte { var $velocidade; function andar() { echo 'Transporte andando! <br /> '; } }
class Carro extends Transporte { var $cor; var $rodas; function ligar() { echo 'Carro ligado! <br /> '; }
function obterInfo() { echo 'Cor: ' . $this->cor . ' Quantidade de rodas: ' . $this->rodas . ' Velocidade Máxima: ' . $this->velocidade . '<br />‘; } }
$carro1 = new Carro(); $carro1->cor = 'Vermelho'; $carro1->rodas = 4; $carro1->velocidade = 130;
$carro1->ligar(); $carro1->obterInfo(); $carro1->andar();
?>
171
<?php require ( ‘class_transporte.php’ );
class Carro extends Transporte { var $cor; var $rodas; function ligar() { echo 'Carro ligado! <br /> '; }
function obterInfo() { echo 'Cor: ' . $this->cor . ' Quantidade de rodas: ' . $this->rodas . ' Velocidade Máxima: ' . $this->velocidade . '<br />‘; } }
Recommended