ÐÏࡱá > þÿ ä æ þÿÿÿ Ø Ù Ú Û Ü Ý Þ ß à á â ã ÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿÿì¥Á 5@ ø¿ 1 bjbjÏ2Ï2 %6 X X /# ÿÿ ÿÿ ÿÿ ˆ º º º º º º º Î î î î î ü õ Î ˜° : 6þ .9 d7 d7 d7 d7 ?8 t/ ³g œ Ov P ó¯ õ¯ õ¯ õ¯ õ¯ õ¯ õ¯ $ Ò± R $´ f ° 9 º Î~ ?8 ?8 Î~ Î~ ° º º d7 d7 Û R° ‡ ‡ ‡ Î~ Ö º d7 º d7 ó¯ ‡ Î~ ó¯ ‡ . ‡ Fˆ ª x‘ ¯ º º Û’ d7 *þ ð¿á$‰ÓÂ î ¤ ˆ '’ ÿ’ ô h° 0 ˜° 9’ ¢ Š´ d ,€ Ö îµ $ Û’ Î Î º º º º îµ º Û’ $ Ÿ} > Ý} , ‡ ~ $ -~ ¡ Ÿ} Ÿ} Ÿ} ° ° Î Î Dè î ‡ Î Î î
www.imasters.com.br
Curso: PHP
Autor: Bruno Rodrigues Siqueira (bruno@netfly.com.br)
Índice
TOC \o "1-5" \h \z HYPERLINK \l "_Toc14444611" Índice PAGEREF _Toc14444611 \h 1
HYPERLINK \l "_Toc14444612" 1.Introdução PAGEREF _Toc14444612 \h 10
HYPERLINK \l "_Toc14444613" O que é PHP? PAGEREF _Toc14444613 \h 10
HYPERLINK \l "_Toc14444614" História do PHP PAGEREF _Toc14444614 \h 11
HYPERLINK \l "_Toc14444615" O que pode ser feito com PHP? PAGEREF _Toc14444615 \h 12
HYPERLINK \l "_Toc14444616" Tabela comparativa PAGEREF _Toc14444616 \h 12
HYPERLINK \l "_Toc14444617" 2. Sintaxe Básica PAGEREF _Toc14444617 \h 13
HYPERLINK \l "_Toc14444618" Delimitando o código PHP PAGEREF _Toc14444618 \h 13
HYPERLINK \l "_Toc14444619" Separador de instruções PAGEREF _Toc14444619 \h 13
HYPERLINK \l "_Toc14444620" Nomes de variáveis PAGEREF _Toc14444620 \h 14
HYPERLINK \l "_Toc14444621" Comentários PAGEREF _Toc14444621 \h 14
HYPERLINK \l "_Toc14444622" 3. Tipos PAGEREF _Toc14444622 \h 16
HYPERLINK \l "_Toc14444623" Tipos Suportados PAGEREF _Toc14444623 \h 16
HYPERLINK \l "_Toc14444624" Inteiros (integer ou long) PAGEREF _Toc14444624 \h 16
HYPERLINK \l "_Toc14444625" Números em Ponto Flutuante (double ou float) PAGEREF _Toc14444625 \h 16
HYPERLINK \l "_Toc14444626" Strings PAGEREF _Toc14444626 \h 17
HYPERLINK \l "_Toc14444627" Arrays PAGEREF _Toc14444627 \h 18
HYPERLINK \l "_Toc14444628" Listas PAGEREF _Toc14444628 \h 18
HYPERLINK \l "_Toc14444629" Objetos PAGEREF _Toc14444629 \h 19
HYPERLINK \l "_Toc14444630" Booleanos PAGEREF _Toc14444630 \h 19
HYPERLINK \l "_Toc14444631" Transformação de tipos PAGEREF _Toc14444631 \h 19
HYPERLINK \l "_Toc14444632" Coerções PAGEREF _Toc14444632 \h 20
HYPERLINK \l "_Toc14444633" Transformação explícita de tipos PAGEREF _Toc14444633 \h 20
HYPERLINK \l "_Toc14444634" Com a função settype PAGEREF _Toc14444634 \h 21
HYPERLINK \l "_Toc14444635" 4. Constantes PAGEREF _Toc14444635 \h 22
HYPERLINK \l "_Toc14444636" Constantes pré-definidas PAGEREF _Toc14444636 \h 22
HYPERLINK \l "_Toc14444637" Definindo constantes PAGEREF _Toc14444637 \h 22
HYPERLINK \l "_Toc14444638" 5. Operadores PAGEREF _Toc14444638 \h 23
HYPERLINK \l "_Toc14444639" Aritméticos PAGEREF _Toc14444639 \h 23
HYPERLINK \l "_Toc14444640" de strings PAGEREF _Toc14444640 \h 23
HYPERLINK \l "_Toc14444641" de atribuição PAGEREF _Toc14444641 \h 23
HYPERLINK \l "_Toc14444642" bit a bit PAGEREF _Toc14444642 \h 24
HYPERLINK \l "_Toc14444643" Lógicos PAGEREF _Toc14444643 \h 24
HYPERLINK \l "_Toc14444644" Comparação PAGEREF _Toc14444644 \h 24
HYPERLINK \l "_Toc14444645" Expressão condicional PAGEREF _Toc14444645 \h 25
HYPERLINK \l "_Toc14444646" de incremento e decremento PAGEREF _Toc14444646 \h 25
HYPERLINK \l "_Toc14444647" Ordem de precedência dos operadores PAGEREF _Toc14444647 \h 25
HYPERLINK \l "_Toc14444648" 6. Estruturas de Controle PAGEREF _Toc14444648 \h 27
HYPERLINK \l "_Toc14444649" Blocos PAGEREF _Toc14444649 \h 27
HYPERLINK \l "_Toc14444650" Comandos de seleção PAGEREF _Toc14444650 \h 27
HYPERLINK \l "_Toc14444651" if PAGEREF _Toc14444651 \h 27
HYPERLINK \l "_Toc14444652" switch PAGEREF _Toc14444652 \h 30
HYPERLINK \l "_Toc14444653" comandos de repetição PAGEREF _Toc14444653 \h 31
HYPERLINK \l "_Toc14444654" while PAGEREF _Toc14444654 \h 31
HYPERLINK \l "_Toc14444655" do... while PAGEREF _Toc14444655 \h 32
HYPERLINK \l "_Toc14444656" for PAGEREF _Toc14444656 \h 33
HYPERLINK \l "_Toc14444657" Quebra de fluxo PAGEREF _Toc14444657 \h 34
HYPERLINK \l "_Toc14444658" Break PAGEREF _Toc14444658 \h 34
HYPERLINK \l "_Toc14444659" Continue PAGEREF _Toc14444659 \h 34
HYPERLINK \l "_Toc14444660" 7. Funções PAGEREF _Toc14444660 \h 36
HYPERLINK \l "_Toc14444661" Definindo funções PAGEREF _Toc14444661 \h 36
HYPERLINK \l "_Toc14444662" Valor de retorno PAGEREF _Toc14444662 \h 36
HYPERLINK \l "_Toc14444663" Argumentos PAGEREF _Toc14444663 \h 36
HYPERLINK \l "_Toc14444664" Passagem de parâmetros por referência PAGEREF _Toc14444664 \h 37
HYPERLINK \l "_Toc14444665" Argumentos com valores pré-definidos (default) PAGEREF _Toc14444665 \h 38
HYPERLINK \l "_Toc14444666" Escopo PAGEREF _Toc14444666 \h 39
HYPERLINK \l "_Toc14444667" 8. Variáveis PAGEREF _Toc14444667 \h 41
HYPERLINK \l "_Toc14444668" O modificador static PAGEREF _Toc14444668 \h 41
HYPERLINK \l "_Toc14444669" Variáveis Variáveis PAGEREF _Toc14444669 \h 42
HYPERLINK \l "_Toc14444670" Variáveis enviadas pelo navegador PAGEREF _Toc14444670 \h 42
HYPERLINK \l "_Toc14444671" URLencode PAGEREF _Toc14444671 \h 42
HYPERLINK \l "_Toc14444672" Variáveis de ambiente PAGEREF _Toc14444672 \h 43
HYPERLINK \l "_Toc14444673" Verificando o tipo de uma variável PAGEREF _Toc14444673 \h 43
HYPERLINK \l "_Toc14444674" Função que retorna o tipo da variável PAGEREF _Toc14444674 \h 43
HYPERLINK \l "_Toc14444675" Funções que testam o tipo da variável PAGEREF _Toc14444675 \h 43
HYPERLINK \l "_Toc14444676" Destruindo uma variável PAGEREF _Toc14444676 \h 44
HYPERLINK \l "_Toc14444677" Verificando se uma variável possui um valor PAGEREF _Toc14444677 \h 44
HYPERLINK \l "_Toc14444678" Arrays Multidimensionais PAGEREF _Toc14444678 \h 45
HYPERLINK \l "_Toc14444679" 9. Classes e Objetos PAGEREF _Toc14444679 \h 46
HYPERLINK \l "_Toc14444680" Classe PAGEREF _Toc14444680 \h 46
HYPERLINK \l "_Toc14444681" Objeto PAGEREF _Toc14444681 \h 46
HYPERLINK \l "_Toc14444682" A variável $this PAGEREF _Toc14444682 \h 46
HYPERLINK \l "_Toc14444683" SubClasses PAGEREF _Toc14444683 \h 47
HYPERLINK \l "_Toc14444684" Construtores PAGEREF _Toc14444684 \h 47
HYPERLINK \l "_Toc14444685" 10. PHP avançado PAGEREF _Toc14444685 \h 49
HYPERLINK \l "_Toc14444686" Interagindo com o browser PAGEREF _Toc14444686 \h 49
HYPERLINK \l "_Toc14444687" Utilizando formulários HTML PAGEREF _Toc14444687 \h 49
HYPERLINK \l "_Toc14444688" Cookies PAGEREF _Toc14444688 \h 51
HYPERLINK \l "_Toc14444689" Sessão PAGEREF _Toc14444689 \h 51
HYPERLINK \l "_Toc14444690" Require PAGEREF _Toc14444690 \h 52
HYPERLINK \l "_Toc14444691" Include PAGEREF _Toc14444691 \h 52
HYPERLINK \l "_Toc14444692" Formulários Avançados PAGEREF _Toc14444692 \h 52
HYPERLINK \l "_Toc14444693" Arquivos Remotos PAGEREF _Toc14444693 \h 53
HYPERLINK \l "_Toc14444694" Lendo PAGEREF _Toc14444694 \h 53
HYPERLINK \l "_Toc14444695" Escrevendo PAGEREF _Toc14444695 \h 53
HYPERLINK \l "_Toc14444696" Tratamento de erros PAGEREF _Toc14444696 \h 54
HYPERLINK \l "_Toc14444697" 11.SQL PAGEREF _Toc14444697 \h 55
HYPERLINK \l "_Toc14444698" O que é? PAGEREF _Toc14444698 \h 55
HYPERLINK \l "_Toc14444699" SELECT PAGEREF _Toc14444699 \h 55
HYPERLINK \l "_Toc14444700" Subseleções PAGEREF _Toc14444700 \h 56
HYPERLINK \l "_Toc14444701" INSERT PAGEREF _Toc14444701 \h 56
HYPERLINK \l "_Toc14444702" UPDATE PAGEREF _Toc14444702 \h 56
HYPERLINK \l "_Toc14444703" DELETE PAGEREF _Toc14444703 \h 57
HYPERLINK \l "_Toc14444704" O que em comum entre: DELETE x UPDATE PAGEREF _Toc14444704 \h 57
HYPERLINK \l "_Toc14444705" CREATE PAGEREF _Toc14444705 \h 57
HYPERLINK \l "_Toc14444706" DROP PAGEREF _Toc14444706 \h 58
HYPERLINK \l "_Toc14444707" ALTER PAGEREF _Toc14444707 \h 58
HYPERLINK \l "_Toc14444708" 12. Bancos de dados compatíveis com o PHP: PAGEREF _Toc14444708 \h 58
HYPERLINK \l "_Toc14444709" 13. Biblioteca de Funções PAGEREF _Toc14444709 \h 59
HYPERLINK \l "_Toc14444710" Bibliotecas requeridas PAGEREF _Toc14444710 \h 59
HYPERLINK \l "_Toc14444711" Array PAGEREF _Toc14444711 \h 59
HYPERLINK \l "_Toc14444712" Array PAGEREF _Toc14444712 \h 59
HYPERLINK \l "_Toc14444713" array_keys [PHP4] PAGEREF _Toc14444713 \h 59
HYPERLINK \l "_Toc14444714" Array_merge [PHP4] PAGEREF _Toc14444714 \h 60
HYPERLINK \l "_Toc14444715" Array_pop[PHP4] PAGEREF _Toc14444715 \h 60
HYPERLINK \l "_Toc14444716" Array_push[PHP4] PAGEREF _Toc14444716 \h 60
HYPERLINK \l "_Toc14444717" Array_shift[PHP4] PAGEREF _Toc14444717 \h 60
HYPERLINK \l "_Toc14444718" Array_slice[PHP4] PAGEREF _Toc14444718 \h 60
HYPERLINK \l "_Toc14444719" Array_splice[PHP4] PAGEREF _Toc14444719 \h 60
HYPERLINK \l "_Toc14444720" Array_unshift[PHP4] PAGEREF _Toc14444720 \h 61
HYPERLINK \l "_Toc14444721" Array_values[PHP4] PAGEREF _Toc14444721 \h 61
HYPERLINK \l "_Toc14444722" Array_walk PAGEREF _Toc14444722 \h 61
HYPERLINK \l "_Toc14444723" Arsort PAGEREF _Toc14444723 \h 61
HYPERLINK \l "_Toc14444724" Asort PAGEREF _Toc14444724 \h 61
HYPERLINK \l "_Toc14444725" Compact[PHP4] PAGEREF _Toc14444725 \h 61
HYPERLINK \l "_Toc14444726" Count PAGEREF _Toc14444726 \h 62
HYPERLINK \l "_Toc14444727" Current PAGEREF _Toc14444727 \h 62
HYPERLINK \l "_Toc14444728" Each PAGEREF _Toc14444728 \h 62
HYPERLINK \l "_Toc14444729" End PAGEREF _Toc14444729 \h 62
HYPERLINK \l "_Toc14444730" Extract PAGEREF _Toc14444730 \h 62
HYPERLINK \l "_Toc14444731" In_array[PHP4] PAGEREF _Toc14444731 \h 63
HYPERLINK \l "_Toc14444732" Key PAGEREF _Toc14444732 \h 63
HYPERLINK \l "_Toc14444733" Ksort PAGEREF _Toc14444733 \h 63
HYPERLINK \l "_Toc14444734" List PAGEREF _Toc14444734 \h 63
HYPERLINK \l "_Toc14444735" Next PAGEREF _Toc14444735 \h 63
HYPERLINK \l "_Toc14444736" Pos PAGEREF _Toc14444736 \h 63
HYPERLINK \l "_Toc14444737" Prev PAGEREF _Toc14444737 \h 63
HYPERLINK \l "_Toc14444738" Range PAGEREF _Toc14444738 \h 63
HYPERLINK \l "_Toc14444739" Reset PAGEREF _Toc14444739 \h 64
HYPERLINK \l "_Toc14444740" Rsort PAGEREF _Toc14444740 \h 64
HYPERLINK \l "_Toc14444741" Shuffle PAGEREF _Toc14444741 \h 64
HYPERLINK \l "_Toc14444742" Sizeof PAGEREF _Toc14444742 \h 64
HYPERLINK \l "_Toc14444743" Sort PAGEREF _Toc14444743 \h 64
HYPERLINK \l "_Toc14444744" Uasort PAGEREF _Toc14444744 \h 64
HYPERLINK \l "_Toc14444745" Uksort PAGEREF _Toc14444745 \h 64
HYPERLINK \l "_Toc14444746" Usort PAGEREF _Toc14444746 \h 65
HYPERLINK \l "_Toc14444747" Matemática para números inteiros PAGEREF _Toc14444747 \h 65
HYPERLINK \l "_Toc14444748" Bcpow PAGEREF _Toc14444748 \h 65
HYPERLINK \l "_Toc14444749" Bcscale PAGEREF _Toc14444749 \h 65
HYPERLINK \l "_Toc14444750" Datas PAGEREF _Toc14444750 \h 65
HYPERLINK \l "_Toc14444751" Checkdate PAGEREF _Toc14444751 \h 65
HYPERLINK \l "_Toc14444752" Date PAGEREF _Toc14444752 \h 65
HYPERLINK \l "_Toc14444753" Getdate PAGEREF _Toc14444753 \h 66
HYPERLINK \l "_Toc14444754" Gettimeofday PAGEREF _Toc14444754 \h 66
HYPERLINK \l "_Toc14444755" Gmdate PAGEREF _Toc14444755 \h 67
HYPERLINK \l "_Toc14444756" Gmmktime PAGEREF _Toc14444756 \h 67
HYPERLINK \l "_Toc14444757" Gmstrftime PAGEREF _Toc14444757 \h 67
HYPERLINK \l "_Toc14444758" Microtime PAGEREF _Toc14444758 \h 67
HYPERLINK \l "_Toc14444759" Mktime PAGEREF _Toc14444759 \h 67
HYPERLINK \l "_Toc14444760" Strftime PAGEREF _Toc14444760 \h 67
HYPERLINK \l "_Toc14444761" Time PAGEREF _Toc14444761 \h 68
HYPERLINK \l "_Toc14444762" Diretório PAGEREF _Toc14444762 \h 68
HYPERLINK \l "_Toc14444763" Chdir PAGEREF _Toc14444763 \h 68
HYPERLINK \l "_Toc14444764" Classe dir PAGEREF _Toc14444764 \h 69
HYPERLINK \l "_Toc14444765" Closedir PAGEREF _Toc14444765 \h 69
HYPERLINK \l "_Toc14444766" Opendir PAGEREF _Toc14444766 \h 69
HYPERLINK \l "_Toc14444767" Readdir PAGEREF _Toc14444767 \h 69
HYPERLINK \l "_Toc14444768" Rewinddir PAGEREF _Toc14444768 \h 69
HYPERLINK \l "_Toc14444769" Execução de Programas PAGEREF _Toc14444769 \h 69
HYPERLINK \l "_Toc14444770" Escapeshellcmd PAGEREF _Toc14444770 \h 69
HYPERLINK \l "_Toc14444771" Exec PAGEREF _Toc14444771 \h 69
HYPERLINK \l "_Toc14444772" Passthru PAGEREF _Toc14444772 \h 70
HYPERLINK \l "_Toc14444773" System PAGEREF _Toc14444773 \h 70
HYPERLINK \l "_Toc14444774" Sistema de arquivos do servidor PAGEREF _Toc14444774 \h 70
HYPERLINK \l "_Toc14444775" Basename PAGEREF _Toc14444775 \h 70
HYPERLINK \l "_Toc14444776" Chgrp PAGEREF _Toc14444776 \h 70
HYPERLINK \l "_Toc14444777" Chmod PAGEREF _Toc14444777 \h 70
HYPERLINK \l "_Toc14444778" Chown PAGEREF _Toc14444778 \h 71
HYPERLINK \l "_Toc14444779" Clearstatcache PAGEREF _Toc14444779 \h 71
HYPERLINK \l "_Toc14444780" Copy PAGEREF _Toc14444780 \h 71
HYPERLINK \l "_Toc14444781" Delete PAGEREF _Toc14444781 \h 71
HYPERLINK \l "_Toc14444782" Dirname PAGEREF _Toc14444782 \h 71
HYPERLINK \l "_Toc14444783" Diskfreespace PAGEREF _Toc14444783 \h 71
HYPERLINK \l "_Toc14444784" Fclose PAGEREF _Toc14444784 \h 71
HYPERLINK \l "_Toc14444785" Feof PAGEREF _Toc14444785 \h 71
HYPERLINK \l "_Toc14444786" Fgetc PAGEREF _Toc14444786 \h 72
HYPERLINK \l "_Toc14444787" Fgetcsv PAGEREF _Toc14444787 \h 72
HYPERLINK \l "_Toc14444788" Fgets PAGEREF _Toc14444788 \h 72
HYPERLINK \l "_Toc14444789" Fgetss PAGEREF _Toc14444789 \h 72
HYPERLINK \l "_Toc14444790" File PAGEREF _Toc14444790 \h 72
HYPERLINK \l "_Toc14444791" File_exists PAGEREF _Toc14444791 \h 72
HYPERLINK \l "_Toc14444792" Fileatime PAGEREF _Toc14444792 \h 72
HYPERLINK \l "_Toc14444793" Filectime PAGEREF _Toc14444793 \h 73
HYPERLINK \l "_Toc14444794" Filegroup PAGEREF _Toc14444794 \h 73
HYPERLINK \l "_Toc14444795" Fileinode PAGEREF _Toc14444795 \h 73
HYPERLINK \l "_Toc14444796" Filemtime PAGEREF _Toc14444796 \h 73
HYPERLINK \l "_Toc14444797" Fileowner PAGEREF _Toc14444797 \h 73
HYPERLINK \l "_Toc14444798" Fileperms PAGEREF _Toc14444798 \h 73
HYPERLINK \l "_Toc14444799" Filesize PAGEREF _Toc14444799 \h 73
HYPERLINK \l "_Toc14444800" Filetype PAGEREF _Toc14444800 \h 74
HYPERLINK \l "_Toc14444801" Flock PAGEREF _Toc14444801 \h 74
HYPERLINK \l "_Toc14444802" Fopen PAGEREF _Toc14444802 \h 74
HYPERLINK \l "_Toc14444803" Fpassthru PAGEREF _Toc14444803 \h 75
HYPERLINK \l "_Toc14444804" Fputs PAGEREF _Toc14444804 \h 75
HYPERLINK \l "_Toc14444805" Fread PAGEREF _Toc14444805 \h 75
HYPERLINK \l "_Toc14444806" Fseek PAGEREF _Toc14444806 \h 75
HYPERLINK \l "_Toc14444807" Ftell PAGEREF _Toc14444807 \h 75
HYPERLINK \l "_Toc14444808" Fwrite PAGEREF _Toc14444808 \h 75
HYPERLINK \l "_Toc14444809" Is_dir PAGEREF _Toc14444809 \h 76
HYPERLINK \l "_Toc14444810" Is_executable PAGEREF _Toc14444810 \h 76
HYPERLINK \l "_Toc14444811" Is_file PAGEREF _Toc14444811 \h 76
HYPERLINK \l "_Toc14444812" Is_link PAGEREF _Toc14444812 \h 76
HYPERLINK \l "_Toc14444813" Is_readable PAGEREF _Toc14444813 \h 76
HYPERLINK \l "_Toc14444814" Is writeable PAGEREF _Toc14444814 \h 76
HYPERLINK \l "_Toc14444815" Link PAGEREF _Toc14444815 \h 76
HYPERLINK \l "_Toc14444816" Linkinfo PAGEREF _Toc14444816 \h 77
HYPERLINK \l "_Toc14444817" Mkdir PAGEREF _Toc14444817 \h 77
HYPERLINK \l "_Toc14444818" Pclose PAGEREF _Toc14444818 \h 77
HYPERLINK \l "_Toc14444819" Popen PAGEREF _Toc14444819 \h 77
HYPERLINK \l "_Toc14444820" Readfile PAGEREF _Toc14444820 \h 77
HYPERLINK \l "_Toc14444821" Readlink PAGEREF _Toc14444821 \h 77
HYPERLINK \l "_Toc14444822" Rename PAGEREF _Toc14444822 \h 77
HYPERLINK \l "_Toc14444823" Rewind PAGEREF _Toc14444823 \h 77
HYPERLINK \l "_Toc14444824" Rmdir PAGEREF _Toc14444824 \h 78
HYPERLINK \l "_Toc14444825" Set_file_buffer PAGEREF _Toc14444825 \h 78
HYPERLINK \l "_Toc14444826" Stat PAGEREF _Toc14444826 \h 78
HYPERLINK \l "_Toc14444827" Symlink PAGEREF _Toc14444827 \h 78
HYPERLINK \l "_Toc14444828" Tempnam PAGEREF _Toc14444828 \h 78
HYPERLINK \l "_Toc14444829" Touch PAGEREF _Toc14444829 \h 78
HYPERLINK \l "_Toc14444830" Umask PAGEREF _Toc14444830 \h 79
HYPERLINK \l "_Toc14444831" Unlink PAGEREF _Toc14444831 \h 79
HYPERLINK \l "_Toc14444832" Opções e informações do PHP PAGEREF _Toc14444832 \h 79
HYPERLINK \l "_Toc14444833" Error_log PAGEREF _Toc14444833 \h 79
HYPERLINK \l "_Toc14444834" Error_reporting PAGEREF _Toc14444834 \h 79
HYPERLINK \l "_Toc14444835" Extension_loaded PAGEREF _Toc14444835 \h 80
HYPERLINK \l "_Toc14444836" Get_cfg_var PAGEREF _Toc14444836 \h 80
HYPERLINK \l "_Toc14444837" Get_current_user PAGEREF _Toc14444837 \h 80
HYPERLINK \l "_Toc14444838" Get_magic_quotes_gpc PAGEREF _Toc14444838 \h 80
HYPERLINK \l "_Toc14444839" Get_magic_quotes_runtime PAGEREF _Toc14444839 \h 80
HYPERLINK \l "_Toc14444840" Getenv PAGEREF _Toc14444840 \h 80
HYPERLINK \l "_Toc14444841" Getlastmod PAGEREF _Toc14444841 \h 80
HYPERLINK \l "_Toc14444842" Getmyinode PAGEREF _Toc14444842 \h 81
HYPERLINK \l "_Toc14444843" Getmypid PAGEREF _Toc14444843 \h 81
HYPERLINK \l "_Toc14444844" Getmyuid PAGEREF _Toc14444844 \h 81
HYPERLINK \l "_Toc14444845" Getrusage PAGEREF _Toc14444845 \h 81
HYPERLINK \l "_Toc14444846" Phpinfo PAGEREF _Toc14444846 \h 81
HYPERLINK \l "_Toc14444847" Phpversion PAGEREF _Toc14444847 \h 81
HYPERLINK \l "_Toc14444848" Putenv PAGEREF _Toc14444848 \h 81
HYPERLINK \l "_Toc14444849" Set_magic_quotes_runtime PAGEREF _Toc14444849 \h 81
HYPERLINK \l "_Toc14444850" Set_time_limit PAGEREF _Toc14444850 \h 81
HYPERLINK \l "_Toc14444851" Matemática PAGEREF _Toc14444851 \h 82
HYPERLINK \l "_Toc14444852" Abs PAGEREF _Toc14444852 \h 82
HYPERLINK \l "_Toc14444853" Acos PAGEREF _Toc14444853 \h 82
HYPERLINK \l "_Toc14444854" Asin PAGEREF _Toc14444854 \h 82
HYPERLINK \l "_Toc14444855" Atan PAGEREF _Toc14444855 \h 82
HYPERLINK \l "_Toc14444856" Atan2 PAGEREF _Toc14444856 \h 82
HYPERLINK \l "_Toc14444857" Base_convert PAGEREF _Toc14444857 \h 82
HYPERLINK \l "_Toc14444858" Bindec PAGEREF _Toc14444858 \h 82
HYPERLINK \l "_Toc14444859" Ceil PAGEREF _Toc14444859 \h 82
HYPERLINK \l "_Toc14444860" Cos PAGEREF _Toc14444860 \h 83
HYPERLINK \l "_Toc14444861" Decbin PAGEREF _Toc14444861 \h 83
HYPERLINK \l "_Toc14444862" Dechex PAGEREF _Toc14444862 \h 83
HYPERLINK \l "_Toc14444863" Decoct PAGEREF _Toc14444863 \h 83
HYPERLINK \l "_Toc14444864" Exp PAGEREF _Toc14444864 \h 83
HYPERLINK \l "_Toc14444865" Floor PAGEREF _Toc14444865 \h 83
HYPERLINK \l "_Toc14444866" Getrandmax PAGEREF _Toc14444866 \h 83
HYPERLINK \l "_Toc14444867" Hexdec PAGEREF _Toc14444867 \h 83
HYPERLINK \l "_Toc14444868" Log PAGEREF _Toc14444868 \h 83
HYPERLINK \l "_Toc14444869" Log10 PAGEREF _Toc14444869 \h 83
HYPERLINK \l "_Toc14444870" Max PAGEREF _Toc14444870 \h 84
HYPERLINK \l "_Toc14444871" Min PAGEREF _Toc14444871 \h 84
HYPERLINK \l "_Toc14444872" Mt_rand PAGEREF _Toc14444872 \h 84
HYPERLINK \l "_Toc14444873" Mt_srand PAGEREF _Toc14444873 \h 84
HYPERLINK \l "_Toc14444874" Mt_getrandmax PAGEREF _Toc14444874 \h 84
HYPERLINK \l "_Toc14444875" Number_format PAGEREF _Toc14444875 \h 84
HYPERLINK \l "_Toc14444876" Octdec PAGEREF _Toc14444876 \h 84
HYPERLINK \l "_Toc14444877" Pi PAGEREF _Toc14444877 \h 84
HYPERLINK \l "_Toc14444878" Pow PAGEREF _Toc14444878 \h 84
HYPERLINK \l "_Toc14444879" Rand PAGEREF _Toc14444879 \h 85
HYPERLINK \l "_Toc14444880" Round PAGEREF _Toc14444880 \h 85
HYPERLINK \l "_Toc14444881" Sin PAGEREF _Toc14444881 \h 85
HYPERLINK \l "_Toc14444882" Sqrt PAGEREF _Toc14444882 \h 85
HYPERLINK \l "_Toc14444883" Srand PAGEREF _Toc14444883 \h 85
HYPERLINK \l "_Toc14444884" Tan PAGEREF _Toc14444884 \h 85
HYPERLINK \l "_Toc14444885" Criptografia PAGEREF _Toc14444885 \h 85
HYPERLINK \l "_Toc14444886" Mcrypt_cbc PAGEREF _Toc14444886 \h 85
HYPERLINK \l "_Toc14444887" Mcrypt_cfb PAGEREF _Toc14444887 \h 85
HYPERLINK \l "_Toc14444888" Mcrypt_create_iv PAGEREF _Toc14444888 \h 86
HYPERLINK \l "_Toc14444889" Mcrypt_ecb PAGEREF _Toc14444889 \h 86
HYPERLINK \l "_Toc14444890" Mcrypt_get_cipher_name PAGEREF _Toc14444890 \h 86
HYPERLINK \l "_Toc14444891" Mcrypt_get_block_size PAGEREF _Toc14444891 \h 86
HYPERLINK \l "_Toc14444892" Mcrypt_get_key_size PAGEREF _Toc14444892 \h 86
HYPERLINK \l "_Toc14444893" Mcrypt_ofb PAGEREF _Toc14444893 \h 86
HYPERLINK \l "_Toc14444894" Funções diversas PAGEREF _Toc14444894 \h 86
HYPERLINK \l "_Toc14444895" Connection_aborted PAGEREF _Toc14444895 \h 86
HYPERLINK \l "_Toc14444896" Connection_status PAGEREF _Toc14444896 \h 86
HYPERLINK \l "_Toc14444897" Connection_timeout PAGEREF _Toc14444897 \h 86
HYPERLINK \l "_Toc14444898" Dl PAGEREF _Toc14444898 \h 87
HYPERLINK \l "_Toc14444899" Eval PAGEREF _Toc14444899 \h 87
HYPERLINK \l "_Toc14444900" Die PAGEREF _Toc14444900 \h 87
HYPERLINK \l "_Toc14444901" Exit PAGEREF _Toc14444901 \h 87
HYPERLINK \l "_Toc14444902" Function_exists PAGEREF _Toc14444902 \h 87
HYPERLINK \l "_Toc14444903" Ignore_user_abort PAGEREF _Toc14444903 \h 87
HYPERLINK \l "_Toc14444904" Iptcparse PAGEREF _Toc14444904 \h 87
HYPERLINK \l "_Toc14444905" Leak PAGEREF _Toc14444905 \h 87
HYPERLINK \l "_Toc14444906" Mail PAGEREF _Toc14444906 \h 88
HYPERLINK \l "_Toc14444907" Pack PAGEREF _Toc14444907 \h 88
HYPERLINK \l "_Toc14444908" Register_shutdown_function PAGEREF _Toc14444908 \h 88
HYPERLINK \l "_Toc14444909" Serialize PAGEREF _Toc14444909 \h 88
HYPERLINK \l "_Toc14444910" Sleep PAGEREF _Toc14444910 \h 88
HYPERLINK \l "_Toc14444911" Unpack PAGEREF _Toc14444911 \h 88
HYPERLINK \l "_Toc14444912" Unserialize PAGEREF _Toc14444912 \h 89
HYPERLINK \l "_Toc14444913" Uniquid PAGEREF _Toc14444913 \h 89
HYPERLINK \l "_Toc14444914" Usleep PAGEREF _Toc14444914 \h 89
HYPERLINK \l "_Toc14444915" Rede PAGEREF _Toc14444915 \h 89
HYPERLINK \l "_Toc14444916" Checkdnsrr PAGEREF _Toc14444916 \h 89
HYPERLINK \l "_Toc14444917" Closelog PAGEREF _Toc14444917 \h 89
HYPERLINK \l "_Toc14444918" Debugger_on PAGEREF _Toc14444918 \h 89
HYPERLINK \l "_Toc14444919" Debugger_off PAGEREF _Toc14444919 \h 89
HYPERLINK \l "_Toc14444920" Fsockopen PAGEREF _Toc14444920 \h 89
HYPERLINK \l "_Toc14444921" Gethostbyaddr PAGEREF _Toc14444921 \h 89
HYPERLINK \l "_Toc14444922" Gethostbyname PAGEREF _Toc14444922 \h 90
HYPERLINK \l "_Toc14444923" Openlog PAGEREF _Toc14444923 \h 90
HYPERLINK \l "_Toc14444924" Pfsockopen PAGEREF _Toc14444924 \h 90
HYPERLINK \l "_Toc14444925" Set_socket_blocking PAGEREF _Toc14444925 \h 90
HYPERLINK \l "_Toc14444926" Syslog PAGEREF _Toc14444926 \h 90
HYPERLINK \l "_Toc14444927" Expressões regulares PAGEREF _Toc14444927 \h 90
HYPERLINK \l "_Toc14444928" Ereg PAGEREF _Toc14444928 \h 90
HYPERLINK \l "_Toc14444929" Ereg_replace PAGEREF _Toc14444929 \h 90
HYPERLINK \l "_Toc14444930" Eregi PAGEREF _Toc14444930 \h 91
HYPERLINK \l "_Toc14444931" Eregi_replace PAGEREF _Toc14444931 \h 91
HYPERLINK \l "_Toc14444932" Split PAGEREF _Toc14444932 \h 91
HYPERLINK \l "_Toc14444933" Sql_regcase PAGEREF _Toc14444933 \h 91
HYPERLINK \l "_Toc14444934" Tratamento de sessões PAGEREF _Toc14444934 \h 91
HYPERLINK \l "_Toc14444935" Session_decode[PHP4] PAGEREF _Toc14444935 \h 91
HYPERLINK \l "_Toc14444936" Session_destroy[PHP4] PAGEREF _Toc14444936 \h 91
HYPERLINK \l "_Toc14444937" Session_encode[PHP4] PAGEREF _Toc14444937 \h 91
HYPERLINK \l "_Toc14444938" Session_start[PHP4] PAGEREF _Toc14444938 \h 91
HYPERLINK \l "_Toc14444939" Session_id[PHP4] PAGEREF _Toc14444939 \h 92
HYPERLINK \l "_Toc14444940" Session_is_registered[PHP4] PAGEREF _Toc14444940 \h 92
HYPERLINK \l "_Toc14444941" Session_module_name[PHP4] PAGEREF _Toc14444941 \h 92
HYPERLINK \l "_Toc14444942" Session_name[PHP4] PAGEREF _Toc14444942 \h 92
HYPERLINK \l "_Toc14444943" Session_register[PHP4] PAGEREF _Toc14444943 \h 92
HYPERLINK \l "_Toc14444944" Session_save_path[PHP4] PAGEREF _Toc14444944 \h 92
HYPERLINK \l "_Toc14444945" Session_unregister[PHP4] PAGEREF _Toc14444945 \h 92
HYPERLINK \l "_Toc14444946" Strings PAGEREF _Toc14444946 \h 92
HYPERLINK \l "_Toc14444947" Addslashes PAGEREF _Toc14444947 \h 92
HYPERLINK \l "_Toc14444948" Bin2hex PAGEREF _Toc14444948 \h 93
HYPERLINK \l "_Toc14444949" Chop PAGEREF _Toc14444949 \h 93
HYPERLINK \l "_Toc14444950" Chr PAGEREF _Toc14444950 \h 93
HYPERLINK \l "_Toc14444951" Chunk_split PAGEREF _Toc14444951 \h 93
HYPERLINK \l "_Toc14444952" Convert_cyr_string PAGEREF _Toc14444952 \h 93
HYPERLINK \l "_Toc14444953" Crypt PAGEREF _Toc14444953 \h 93
HYPERLINK \l "_Toc14444954" Echo PAGEREF _Toc14444954 \h 93
HYPERLINK \l "_Toc14444955" Explode PAGEREF _Toc14444955 \h 93
HYPERLINK \l "_Toc14444956" Flush PAGEREF _Toc14444956 \h 94
HYPERLINK \l "_Toc14444957" Get_meta_tags PAGEREF _Toc14444957 \h 94
HYPERLINK \l "_Toc14444958" Htmlentities PAGEREF _Toc14444958 \h 94
HYPERLINK \l "_Toc14444959" Htmlspecialchars PAGEREF _Toc14444959 \h 94
HYPERLINK \l "_Toc14444960" Implode PAGEREF _Toc14444960 \h 94
HYPERLINK \l "_Toc14444961" Join PAGEREF _Toc14444961 \h 94
HYPERLINK \l "_Toc14444962" Ltrim PAGEREF _Toc14444962 \h 94
HYPERLINK \l "_Toc14444963" Md5 PAGEREF _Toc14444963 \h 94
HYPERLINK \l "_Toc14444964" Nl2br PAGEREF _Toc14444964 \h 95
HYPERLINK \l "_Toc14444965" Ord PAGEREF _Toc14444965 \h 95
HYPERLINK \l "_Toc14444966" Parse_str PAGEREF _Toc14444966 \h 95
HYPERLINK \l "_Toc14444967" Print PAGEREF _Toc14444967 \h 95
HYPERLINK \l "_Toc14444968" Printf PAGEREF _Toc14444968 \h 95
HYPERLINK \l "_Toc14444969" Quoted_printable_decode PAGEREF _Toc14444969 \h 95
HYPERLINK \l "_Toc14444970" Quotemeta PAGEREF _Toc14444970 \h 95
HYPERLINK \l "_Toc14444971" Rawurldeconde PAGEREF _Toc14444971 \h 95
HYPERLINK \l "_Toc14444972" Rawurlenconde PAGEREF _Toc14444972 \h 96
HYPERLINK \l "_Toc14444973" Setlocale PAGEREF _Toc14444973 \h 96
HYPERLINK \l "_Toc14444974" Similar_text PAGEREF _Toc14444974 \h 96
HYPERLINK \l "_Toc14444975" Soundex PAGEREF _Toc14444975 \h 96
HYPERLINK \l "_Toc14444976" Sprintf PAGEREF _Toc14444976 \h 96
HYPERLINK \l "_Toc14444977" Strchr PAGEREF _Toc14444977 \h 96
HYPERLINK \l "_Toc14444978" Strcmp PAGEREF _Toc14444978 \h 96
HYPERLINK \l "_Toc14444979" Strcspn PAGEREF _Toc14444979 \h 96
HYPERLINK \l "_Toc14444980" Strip_tags PAGEREF _Toc14444980 \h 97
HYPERLINK \l "_Toc14444981" Stripslashes PAGEREF _Toc14444981 \h 97
HYPERLINK \l "_Toc14444982" Strlen PAGEREF _Toc14444982 \h 97
HYPERLINK \l "_Toc14444983" Strpos PAGEREF _Toc14444983 \h 97
HYPERLINK \l "_Toc14444984" Strrpos PAGEREF _Toc14444984 \h 97
HYPERLINK \l "_Toc14444985" Strrchr PAGEREF _Toc14444985 \h 97
HYPERLINK \l "_Toc14444986" Strrev PAGEREF _Toc14444986 \h 97
HYPERLINK \l "_Toc14444987" Strspn PAGEREF _Toc14444987 \h 97
HYPERLINK \l "_Toc14444988" Strstr PAGEREF _Toc14444988 \h 97
HYPERLINK \l "_Toc14444989" Strtok PAGEREF _Toc14444989 \h 98
HYPERLINK \l "_Toc14444990" Strtolower PAGEREF _Toc14444990 \h 98
HYPERLINK \l "_Toc14444991" Strtoupper PAGEREF _Toc14444991 \h 98
HYPERLINK \l "_Toc14444992" Str_replace PAGEREF _Toc14444992 \h 98
HYPERLINK \l "_Toc14444993" Strtr PAGEREF _Toc14444993 \h 98
HYPERLINK \l "_Toc14444994" Substr PAGEREF _Toc14444994 \h 98
HYPERLINK \l "_Toc14444995" Trim PAGEREF _Toc14444995 \h 98
HYPERLINK \l "_Toc14444996" Ucfirst PAGEREF _Toc14444996 \h 99
HYPERLINK \l "_Toc14444997" Ucwords PAGEREF _Toc14444997 \h 99
HYPERLINK \l "_Toc14444998" Funções para variáveis PAGEREF _Toc14444998 \h 99
HYPERLINK \l "_Toc14444999" Doubleval PAGEREF _Toc14444999 \h 99
HYPERLINK \l "_Toc14445000" Empty PAGEREF _Toc14445000 \h 99
HYPERLINK \l "_Toc14445001" Gettype PAGEREF _Toc14445001 \h 99
HYPERLINK \l "_Toc14445002" Intval PAGEREF _Toc14445002 \h 99
HYPERLINK \l "_Toc14445003" Is_array PAGEREF _Toc14445003 \h 99
HYPERLINK \l "_Toc14445004" Is_double PAGEREF _Toc14445004 \h 99
HYPERLINK \l "_Toc14445005" Is_float PAGEREF _Toc14445005 \h 99
HYPERLINK \l "_Toc14445006" Is_int PAGEREF _Toc14445006 \h 100
HYPERLINK \l "_Toc14445007" Is_integer PAGEREF _Toc14445007 \h 100
HYPERLINK \l "_Toc14445008" Is_long PAGEREF _Toc14445008 \h 100
HYPERLINK \l "_Toc14445009" Is_object PAGEREF _Toc14445009 \h 100
HYPERLINK \l "_Toc14445010" Is_real PAGEREF _Toc14445010 \h 100
HYPERLINK \l "_Toc14445011" Is_string PAGEREF _Toc14445011 \h 100
HYPERLINK \l "_Toc14445012" Isset PAGEREF _Toc14445012 \h 100
HYPERLINK \l "_Toc14445013" Settype PAGEREF _Toc14445013 \h 100
HYPERLINK \l "_Toc14445014" Strval PAGEREF _Toc14445014 \h 101
HYPERLINK \l "_Toc14445015" Unset PAGEREF _Toc14445015 \h 101
HYPERLINK \l "_Toc14445016" 14. Referências na Internet PAGEREF _Toc14445016 \h 102
1. Introdução
O que é PHP?
PHP significa: Hypertext Preprocessor. Realmente, o produto foi originalmente chamado de “Personal Home Page Tools”; mas como se expandiu em escopo, um nome novo e mais apropriado foi escolhido por votação da comunidade. Você pode utilizar qualquer extensão que desejar para designar um arquivo PHP, mas os recomendados foram .php , .phtml. O PHP está atualmente na versão 4, chamado de PHP4 ou, simplesmente de PHP.
PHP é uma linguagem de criação de scripts embutida em HTML no servidor. Os produtos patenteados nesse nicho do mercado são as Active Server Pages da Microsoft, o Coldfusion da Allaire e as Java Server Pages da Sun. PHP é às vezes chamado de “o ASP de código-fonte aberto” porque sua funcionabilidade é tão semelhante ao produto/conceito, ou o que quer que seja, da Microsoft.
Exploraremos a criação de script no servidor, mais profundamente, nos próximos capítulos, mas, no momento, você pode pensar no PHP como uma coleção de supertags de HTML que permitem adicionar funções do servidor às suas páginas da Web. Por exemplo, você pode utilizar PHP para montar instantaneamente uma complexa página da Web ou desencadear um programa que automaticamente execute o débito no cartão de crédito quando um cliente realizar uma compra.
Falando estritamente, o PHP tem pouca relação com layout, eventos ou qualquer coisa relacionada à aparência de uma página da Web. De fato, a maior parte do que o PHP realiza é invisível para o usuário final. Alguém visualizando uma página de PHP não será capaz de dizer que não foi escrita em HTML, porque o resultado final do PHP é HTML.
O PHP é um módulo oficial do servidor http Apache, o líder do mercado de servidores Web livres que constitui aproximadamente 55 por cento da World Wide Web. Isso significa que o mecanismo de script do PHP pode ser construído no próprio servidor Web, tornando a manipulação de dados mais rápida. Assim como o servidor Apache, o PHP é compatível com várias plataformas, o que significa que ele executa em seu formato original em várias versões do UNIX e do Windows. Todos os projetos sob a égide da Apache Software Foundation – incluindo o PHP – são software de código-fonte aberto.
As várias versões do PHP foram aclamadas e premiadas nos últimos anos. O PHP3 foi o finalista em 1999 no LinuxWorld Editor´s Choice Awards (na categoria de biblioteca/ferramentas de programação) e ganhou o segundo lugar, perdendo só para o ColdFusion, em 1998 no Cnet Builder.com Product Awards (na categoria de melhor ferramenta de script de servidor – eles deram bastante importância ao IDE), ao passo que a combinação PHP3/MySQL ganhou prêmio de banco de dados do ano no Web98. Nada mau para um software sem relações públicas, sem publicidade e sem uma significativa exposição na mídia.
História do PHP
Rasmus Lerdorf – engenheiro de software, membro da equipe Apache e o homem misterioso do ano – é o criador e a força motriz original por trás do PHP. A primeira parte do PHP foi desenvolvida para utilização pessoal no final de 1994. Tratava-se de um wrapper de PerlCGI que o auxiliava a monitorar as pessoas que acessavam o seu site pessoal. No ano seguinte, ele montou um pacote chamado de Personal Home Page Tools (também conhecido como PHP Construction Kit) em resposta à demanda de usuários que por acaso ou por relatos falados depararam-se com o seu trabalho. A versão 2 foi logo lançada sob o título de PHP/FI e incluía o Form Interpreter, uma ferramenta para analisar sintaticamente consultas de SQL.
Em meados de 1997, o PHP estava sendo utilizado mundialmente em aproximadamente 50.000 sites. Obviamente estava se tornando muito grande para uma única pessoa administrar, mesmo para alguém concentrado e cheio de energia como Rasmus. Agora uma pequena equipe central de desenvolvimento mantinha o projeto sobre o modelo de “junta benevolente” do código-fonte aberto, com contribuições de desenvolvedores e usuários em todo o mundo. Zeev Suraski e Andi Gutmans, dois programadores israelenses que desenvolveram os analisadores de sintaxe PHP3 e PHP4, também generalizaram e estenderam seus trabalhos sob a rubrica de Zend.com (Zeev, Andi, Zend, entendeu?).
O quarto trimestre de 1998 iniciou um período de crescimento explosivo para o PHP, quando todas as tecnologias de código-fonte aberto ganharam uma publicidade intensa. Em outubro de 1998, de acordo com a melhor suposição, mais de 100.000 domínios únicos utilizavam PHP de alguma maneira. Um ano depois, o PHP quebrou a marca de um milhão de domínios. Enquanto escrevo esta apostila, o número explodiu para cerca de dois milhões de domínios.
O que pode ser feito com PHP?
Basicamente, qualquer coisa que pode ser feita por algum programa CGI pode ser feita também com PHP, como coletar dados de um formulário, gerar páginas dinamicamente ou enviar e receber cookies.
PHP também tem como uma das características mais importantes o suporte a um grande número de bancos de dados, como dBase, Interbase, mSQL, mySQL, Oracle, Sybase, PostgreSQL e vários outros. Construir uma página baseada em um banco de dados torna-se uma tarefa extremamente simples com PHP.
Além disso, PHP tem suporte a outros serviços através de protocolos como IMAP, SNMP, NNTP, POP3 e, logicamente, HTTP. Ainda é possível abrir sockets e interagir com outros protocolos.
Tabela comparativa
Custos ComparativosItemASPCold FusionJSPPHPDesenvolvimentoUS$ 0 – 480US$ 395US$ 0US$ 0ServidorUS$ 620US$ 1.295US$ 0 – 595US$ 0RDBMSUS$ 1.220 - 4220US$ 0 - ~10.000US$ 0 - ~10.000US$ 0Suporte de incidenteUS$0 - 245US$ 0 - 75US$ 0 - 75US$ 02. Sintaxe Básica
Delimitando o código PHP
O código PHP fica embutido no próprio HTML. O interpretador identifica quando um código é PHP pelas seguintes tags:
comandos
?>
<%
comandos
%>
O tipo de tags mais utilizado é o terceiro, que consiste em uma “abreviação” do primeiro. Para utilizá-lo, é necessário habilitar a opção short-tags na configuração do PHP. O último tipo serve para facilitar o uso por programadores acostumados à sintaxe de ASP. Para utilizá-lo também é necessário habilitá-lo no arquivo de configuração do PHP (php.ini)
Separador de instruções
Para cada fim de linha de código tem que haver um ponto e vírgula, indicando ao sistema fim de instrução.
Exemplo.
echo 'com ponto e vírgula' ;
?>
Linhas de comando, de controle, não precisam de ponto e vírgula.
Exemplo.:
if ($x == $x){ //aqui não precisa de ponto e vírgula
echo 'com ponto e vírgula' ; //aqui precisa de ponto e vírgula
}
?>
Nomes de variáveis
Toda variável em PHP tem seu nome composto pelo caracter $ e uma string, que deve iniciar por uma letra ou o caracter “_”. PHP é case sensitive, ou seja, as variáveis $php e $PHP são diferentes. Por isso é preciso ter muito cuidado ao definir os nomes das variáveis. É bom evitar os nomes em maiúsculas, pois como veremos mais adiante, o PHP já possui alguma variáveis pré-definidas cujos nomes são formados por letras maiúsculas.
Comentários
Há dois tipos de comentários em código PHP:
Comentários de uma linha:
Marca como comentário até o final da linha ou até o final do bloco de código PHP - o que vier antes. Pode ser delimitado pelo caracter “#” ou por duas barras ( // ).
Exemplo:
echo “teste”; #isto é um teste
echo “teste”; //este teste é similar ao anterior
?>
Comentários de mais de uma linha:
Tem como delimitadores os caracteres “/*” para o início do bloco e “*/” para o final do comentário. Se o delimitador de final de código PHP ( ?> ) estiver dentro de um comentário, não será reconhecido pelo interpretador.
Exemplos:
echo “teste”; /* Isto é um comentário com mais
de uma linha que funciona corretamente
*/
?>
3. Tipos
Tipos Suportados
PHP suporta os seguintes tipos de dados:
Inteiro
Ponto flutuante
String
Array
Objeto
PHP utiliza checagem de tipos dinâmica, ou seja, uma variável pode conter valores de diferentes tipos em diferentes momentos da execução do script. Por este motivo não é necessário declarar o tipo de uma variável para usá-la. O interpretador PHP decidirá qual o tipo daquela variável, verificando o conteúdo em tempo de execução.
Ainda assim, é permitido converter os valores de um tipo para outro desejado, utilizando o typecasting ou a função settype (ver adiante).
Inteiros (integer ou long)
Uma variável pode conter um valor inteiro com atribuições que sigam as seguintes sintaxes:
$php = 1234; # inteiro positivo na base decimal
$php = -234; # inteiro negativo na base decimal
$php = 0234; # inteiro na base octal-simbolizado pelo 0
# equivale a 156 decimal
$php = 0x34; # inteiro na base hexadecimal(simbolizado
# pelo 0x) - equivale a 52 decimal.
A diferença entre inteiros simples e long está no número de bytes utilizados para armazenar a variável. Como a escolha é feita pelo interpretador PHP de maneira transparente para o usuário, podemos afirmar que os tipos são iguais.
Números em Ponto Flutuante (double ou float)
Uma variável pode ter um valor em ponto flutuante com atribuições que sigam as seguintes sintaxes:
$php = 1.234;
$php = 23e4; # equivale a 230.000
Strings
Strings podem ser atribuídas de duas maneiras:
a) utilizando aspas simples ( ' ) - Desta maneira, o valor da variável será exatamente o texto contido entre as aspas (com exceção de \\ e \' - ver tabela abaixo)
b) utilizando aspas duplas ( " ) - Desta maneira, qualquer variável ou caracter de escape será expandido antes de ser atribuído.
Exemplo:
$teste = "Brasil";
$php = '---$teste--\n';
echo "$php";
?>
A saída desse script será "---$teste--\n".
$teste = "Brasil";
$php = "---$teste---\n";
echo "$php";
?>
A saída desse script será "---Brasil--" (com uma quebra de linha no final).
A tabela seguinte lista os caracteres de escape:
SintaxeSignificado\nNova linha\rRetorno de carro (semelhante a \n)\tTabulação horizontal\\A própria barra ( \ )\$O símbolo $\’Aspa simples\”Aspa dupla
Arrays
Arrays em PHP podem ser observados como mapeamentos ou como vetores indexados. Mais precisamente, um valor do tipo array é um dicionário onde os índices são as chaves de acesso. Vale ressaltar que os índices podem ser valores de qualquer tipo e não somente inteiros. Inclusive, se os índices forem todos inteiros, estes não precisam formar um intervalo contínuo
Como a checagem de tipos em PHP é dinâmica, valores de tipos diferentes podem ser usados como índices de array, assim como os valores mapeados também podem ser de diversos tipos.
Exemplo:
$cor[1] = “vermelho”;
$cor[2] = “verde”;
$cor[3] = “azul”;
$cor[“teste”] = 1;
?>
Equivalentemente, pode-se escrever:
$cor = array(1 => “vermelho, 2 => “verde, 3 => “azul”, “teste => 1);
?>
Listas
As listas são utilizadas em PHP para realizar atribuições múltiplas. Através de listas é possível atribuir valores que estão num array para variáveis. Vejamos o exemplo:
Exemplo:
list($a, $b, $c) = array(“a”, “b”, “c”);
O comando acima atribui valores às três variáveis simultaneamente. É bom notar que só são atribuídos às variáveis da lista os elementos do array que possuem índices inteiros e não negativos. No exemplo acima as três atribuições foram bem sucedidas porque ao inicializar um array sem especificar os índices eles passam a ser inteiros, a partir do zero. Um fator importante é que cada variável da lista possui um índice inteiro e ordinal, iniciando com zero, que serve para determinar qual valor será atribuído. No exemplo anterior temos $a com índice 0, $b com índice 1 e $c com índice 2. Vejamos um outro exemplo:
$arr = array(1=>”um”,3=>”tres”,”a”=>”letraA”,2=>”dois);
list($a,$b,$c,$d) = $arr;
Após a execução do código acima temos os seguintes valores:
$a == null
$b == “um”
$c == “dois”
$d == “tres”
Devemos observar que à variável $a não foi atribuído valor, pois no array não existe elemento com índice 0 (zero). Outro detalhe importante é que o valor “tres” foi atribuído à variável $d, e não a $b, pois seu índice é 3, o mesmo que $d na lista. Por fim, vemos que o valor “letraA” não foi atribuído a elemento algum da lista, pois seu índice não é inteiro.
Os índices da lista servem apenas como referência ao interpretador PHP para realizar as atribuições, não podendo ser acessados de maneira alguma pelo programador. De maneira diferente do array, uma lista não pode ser atribuída a uma variável, servindo apenas para fazer múltiplas atribuições através de um array.
Objetos
Um objeto pode ser inicializado utilizando o comando new para instanciar uma classe para uma variável.
Exemplo:
class teste {
function nada() {
echo “nada”;
}
}
$php = new teste;
$php -> nada();
A utilização de objetos será mais detalhada mais à frente.
Booleanos
PHP não possui um tipo booleano, mas é capaz de avaliar expressões e retornar true ou false, através do tipo integer: é usado o valor 0 (zero) para representar o estado false, e qualquer valor diferente de zero (geralmente 1) para representar o estado true.
Transformação de tipos
A transformação de tipos em PHP pode ser feita das seguintes maneiras:
Coerções
Quando ocorrem determinadas operações (“+”, por exemplo) entre dois valores de tipos diferentes, o PHP converte o valor de um deles automaticamente (coerção). É interessante notar que se o operando for uma variável, seu valor não será alterado.
O tipo para o qual os valores dos operandos serão convertidos é determinado da seguinte forma: Se um dos operandos for float, o outro será convertido para float, senão, se um deles for integer, o outro será convertido para integer.
Exemplo:
$php = “1”; // $php é a string “1”
$php = $php + 1; // $php é o integer 2
$php = $php + 3.7;// $php é o double 5.7
$php = 1 + 1.5 // $php é o double 2.5
Como podemos notar, o PHP converte string para integer ou double mantendo o valor. O sistema utilizado pelo PHP para converter de strings para números é o seguinte:
É analisado o início da string. Se contiver um número, ele será avaliado. Senão, o valor será 0 (zero);
O número pode conter um sinal no início (“+” ou “-“);
Se a string contiver um ponto em sua parte numérica a ser analisada, ele será considerado, e o valor obtido será double;
Se a string contiver um “e” ou “E” em sua parte numérica a ser analisada, o valor seguinte será considerado como expoente da base 10, e o valor obtido será double;
Exemplos:
$php = 1 + “10.5”; // $php == 11.5
$php = 1 + “-1.3e3”; // $php == -1299
$php = 1 + “teste10.5”; // $php == 1
$php = 1 + “10testes”; // $php == 11
$php = 1 + " 10testes"; // $php == 11
$php = 1 + "+ 10testes"; // $php == 1
Transformação explícita de tipos
A sintaxe do typecast de PHP é semelhante ao C: basta escrever o tipo entre parênteses antes do valor
Exemplo:
$php = 15; // $php é integer (15)
$php = (double) $php // $php é double (15.0)
$php = 3.9 // $php é double (3.9)
$php = (int) $php // $php é integer (3)
// o valor decimal é truncado
Os tipos de cast permitidos são:
(int), (integer) Þð m u d a p a r a i n t e g e r ;
( r e a l ) , ( d o u b l e ) , ( f l o a t ) Þð m u d a p a r a f l o a t ;
( s t r i n g ) Þð m u d a p a r a s t r i n g ;
( a r r a y ) Þð m u d a p a r a a r r a y ;
( o b j e c t ) Þð m u d a p a r a o b j e t o .
C o m a f u n ç ã o s e t t y p e
A f u n ç ã o s e t t y p e c o n v e r t e u m a v a r i á v e l p a r a o t i p o e s p e c i f i c a d o , q u e p o d e s e r “integer”, “double”, “string”, “array” ou “object”.
Exemplo:
$php = 15; // $php é integer
settype($php,double) // $php é double
4. Constantes
Constantes pré-definidas
O PHP possui algumas constantes pré-definidas, indicando a versão do PHP, o Sistema Operacional do servidor, o arquivo em execução, e diversas outras informações. Para ter acesso a todas as constantes pré-definidas, pode-se utilizar a função phpinfo(), que exibe uma tabela contendo todas as constantes pré-definidas, assim como configurações da máquina, sistema operacional, servidor http e versão do PHP instalada.
Definindo constantes
Para definir constantes utiliza-se a função define. Uma vez definido, o valor de uma constante não poderá mais ser alterado. Uma constante só pode conter valores escalares, ou seja, não pode conter nem um array nem um objeto. A assinatura da função define é a seguinte:
int define(string nome_da_constante, mixed valor);
A função retorna true se for bem-sucedida. Veja um exemplo de sua utilização a seguir:
define ("pi", 3.1415926536);
$circunf = 2*pi*$raio;
5. Operadores
Aritméticos
Só podem ser utilizados quando os operandos são números (integer ou float). Se forem de outro tipo, terão seus valores convertidos antes da realização da operação.
+adição-subtração*multiplicação/divisão%módulo
de strings
Só há um operador exclusivo para strings:
.concatenação
de atribuição
Existe um operador básico de atribuição e diversos derivados. Sempre retornam o valor atribuído. No caso dos operadores derivados de atribuição, a operação é feita entre os dois operandos, sendo atribuído o resultado para o primeiro. A atribuição é sempre por valor, e não por referência.
=atribuição simples+=atribuição com adição-=atribuição com subtração*=atribuição com multiplicação/=atribuição com divisão%=atribuição com módulo.=atribuição com concatenação
Exemplo:
$a = 7;
$a += 2; // $a passa a conter o valor 9
bit a bit
Comparam dois números bit a bit.
&“e” lógico|“ou” lógico^ou exclusivo~não (inversão)<<shift left>>shift rightLógicos
Utilizados para inteiros representando valores booleanos
and“e” lógicoor“ou” lógicoxorou exclusivo!não (inversão)&&“e” lógico||“ou” lógico
Existem dois operadores para “e” e para “ou porque eles têm diferentes posições na ordem de precedência.
Comparação
As comparações são feitas entre os valores contidos nas variáveis, e não as referências. Sempre retornam um valor booleano.
==igual a!=diferente de<menor que>maior que<=menor ou igual a>=maior ou igual a
Expressão condicional
Existe um operador de seleção que é ternário. Funciona assim:
(expressao1)?(expressao2):( expressao3)
o interpretador PHP avalia a primeira expressão. Se ela for verdadeira, a expressão retorna o valor de expressão2. Senão, retorna o valor de expressão3.
de incremento e decremento
++incremento--decremento
Podem ser utilizados de duas formas: antes ou depois da variável. Quando utilizado antes, retorna o valor da variável antes de incrementá-la ou decrementá-la. Quando utilizado depois, retorna o valor da variável já incrementado ou decrementado.
Exemplos:
$a = $b = 10; // $a e $b recebem o valor 10
$c = $a++; // $c recebe 10 e $a passa a ter 11
$d = ++$b; // $d recebe 11, valor de $b já incrementado
Ordem de precedência dos operadores
A tabela a seguir mostra a ordem de precedência dos operadores no momento de avaliar as expressões;
PrecedênciaAssociatividadeOperadoresEsquerda,EsquerdaorEsquerdaxorEsquerdaandDireitaprintEsquerda= += -= *= /= .= %= &= != ~= <<= >>=Esquerda? :Esquerda||Esquerda&&Esquerda|Esquerda^Esquerda&não associa== !=não associa< <= > >=Esquerda<< >>Esquerda+ - .Esquerda* / %Direita! ~ ++ -- (int) (double) (string) (array) (object) @Direita[não associanew6. Estruturas de Controle
As estruturas que veremos a seguir são comuns para as linguagens de programação imperativas, bastando, portanto, descrever a sintaxe de cada uma delas, resumindo o funcionamento.
Blocos
Um bloco consiste de vários comandos agrupados com o objetivo de relacioná-los com determinado comando ou função. Em comandos como if, for, while, switch e em declarações de funções blocos podem ser utilizados para permitir que um comando faça parte do contexto desejado. Blocos em PHP são delimitados pelos caracteres “{” e “}”. A utilização dos delimitadores de bloco em uma parte qualquer do código não relacionada com os comandos citados ou funções não produzirá efeito algum, e será tratada normalmente pelo interpretador.
Exemplo:
if ($x == $y)
comando1;
comando2;
Para que comando2 esteja relacionado ao if é preciso utilizar um bloco:
if ($x == $y){
comando1;
comando2;
}
Comandos de seleção
Também chamados de condicionais, os comandos de seleção permitem executar comandos ou blocos de comandos com base em testes feitos durante a execução.
if
O mais trivial dos comandos condicionais é o if. Ele testa a condição e executa o comando indicado se o resultado for true (valor diferente de zero). Ele possui duas sintaxes:
if (expressão)
comando;
if (expressão){
comando1;
comando2;
comando3;
comando4;
comando5;
comando1;
comando2;
comando3;
}
if (expressão):
comando;
. . .
comando;
endif;
Para incluir mais de um comando no if da primeira sintaxe, é preciso utilizar um bloco, demarcado por chaves.
O else é um complemento opcional para o if. Se utilizado, o comando será executado se a expressão retornar o valor false (zero). Suas duas sintaxes são:
if (expressão)
comando;
else
comando;
if (expressão):
comando;
. . .
comando;
else
comando;
. . .
comando;
endif;
A seguir, temos um exemplo do comando if utilizado com else:
if ($a > $b)
$maior = $a;
else
$maior = $b;
O exemplo acima coloca em $maior o maior valor entre $a e $b
Em determinadas situações é necessário fazer mais de um teste, e executar condicionalmente diversos comandos ou blocos de comandos. Para facilitar o entendimento de uma estrutura do tipo:
if (expressao1)
comando1;
else
if (expressao2)
comando2;
else
if (expressao3)
comando3;
else
comando4;
foi criado o comando, também opcional elseif. Ele tem a mesma função de um else e um if usados seqüencialmente, como no exemplo acima. Num mesmo if podem ser utilizados diversos elseif’s, ficando essa utilização a critério do programador, que deve zelar pela legibilidade de seu script.
O comando elseif também pode ser utilizado com dois tipos de sintaxe. Em resumo, a sintaxe geral do comando if fica das seguintes maneiras:
if (expressao1)
comando;
[ elseif (expressao2)
comando; ]
[ else
comando; ]
if (expressao1) :
comando;
. . .
comando;
[ elseif (expressao2)
comando;
. . .
comando; ]
[ else
comando;
. . .
comando; ]
endif;
switch
O comando switch atua de maneira semelhante a uma série de comandos if na mesma expressão. Freqüentemente o programador pode querer comparar uma variável com diversos valores, e executar um código diferente a depender de qual valor é igual ao da variável. Quando isso for necessário, deve-se usar o comando switch. O exemplo seguinte mostra dois trechos de código que fazem a mesma coisa, sendo que o primeiro utiliza uma série de if’s e o segundo utiliza switch:
if ($i == 0)
print “i é igual a zero”;
elseif ($i == 1)
print “i é igual a um”;
elseif ($i == 2)
print “i é igual a dois”;
switch ($i) {
case 0:
print “i é igual a zero”;
break;
case 1:
print “i é igual a um”;
break;
case 2:
print “i é igual a dois”;
break;
}
É importante compreender o funcionamento do switch para não cometer enganos. O comando switch testa linha a linha os cases encontrados, e a partir do momento que encontra um valor igual ao da variável testada, passa a executar todos os comandos seguintes, mesmo os que fazem parte de outro teste, até o fim do bloco. por isso usa-se o comando break, quebrando o fluxo e fazendo com que o código seja executado da maneira desejada. Veremos mais sobre o break mais adiante. Veja o exemplo:
switch ($i) {
case 0:
print “i é igual a zero”;
case 1:
print “i é igual a um”;
case 2:
print “i é igual a dois”;
}
No exemplo acima, se $i for igual a zero, os três comandos “print” serão executados. Se $i for igual a 1, os dois últimos “print” serão executados. O comando só funcionará da maneira desejada se $i for igual a 2.
Em outras linguagens que implementam o comando switch, ou similar, os valores a serem testados só podem ser do tipo inteiro. Em PHP é permitido usar valores do tipo string como elementos de teste do comando switch. O exemplo abaixo funciona perfeitamente:
switch ($s) {
case “casa”:
print “A casa é amarela”;
case “arvore”:
print “a árvore é bonita”;
case “lâmpada”:
print “João apagou a lâmpada”;
}
comandos de repetição
while
O while é o comando de repetição (laço) mais simples. Ele testa uma condição e executa um comando, ou um bloco de comandos, até que a condição testada seja falsa. Assim como o if, o while também possui duas sintaxes alternativas:
while ()
;
while (){
;
;
;
;
;
;
}
while ():
;
. . .
;
endwhile;
A expressão só é testada a cada vez que o bloco de instruções termina, além do teste inicial. Se o valor da expressão passar a ser false no meio do bloco de instruções, a execução segue até o final do bloco. Se no teste inicial a condição for avaliada como false, o bloco de comandos não será executado.
O exemplo a seguir mostra o uso do while para imprimir os números de 1 a 10:
$i = 1;
while ($i <=10)
print $i++;
do... while
O laço do...while funciona de maneira bastante semelhante ao while, com a simples diferença que a expressão é testada ao final do bloco de comandos. O laço do...while possui apenas uma sintaxe, que é a seguinte:
do {
. . .
} while ();
O exemplo utilizado para ilustrar o uso do while pode ser feito da seguinte maneira utilizando o do... while:
$i = 0;
do {
print ++$i;
} while ($i < 10);
for
O tipo de laço mais complexo é o for. Para os que programam em C, C++ ou Java, a assimilação do funcionamento do for é natural. Mas para aqueles que estão acostumados a linguagens como Pascal, há uma grande mudança para o uso do for. As três sintaxes permitidas são:
for (;;)
;
for (;;){
;
;
;
;
;
}
for (;;):
;
. . .
;
endfor;
As três expressões que ficam entre parênteses têm as seguintes finalidades:
Inicialização: comando ou seqüência de comandos a serem realizados antes do inicio do laço. Serve para inicializar variáveis.
Condição: Expressão booleana que define se os comandos que estão dentro do laço serão executados ou não. Enquanto a expressão for verdadeira (valor diferente de zero) os comandos serão executados.
Incremento: Comando executado ao final de cada execução do laço.
Um comando for funciona de maneira semelhante a um while escrito da seguinte forma:
while () {
comandos
...
}
Quebra de fluxo
Break
O comando break pode ser utilizado em laços de do, for e while, além do uso já visto no comando switch. Ao encontrar um break dentro de um desses laços, o interpretador PHP para imediatamente a execução do laço, seguindo normalmente o fluxo do script.
while ($x > 0) {
...
if ($x == 20) {
echo “erro! x = 20”;
break;
...
}
No trecho de código acima, o laço while tem uma condição para seu término normal ($x <= 0), mas foi utilizado o break para o caso de um término não previsto no início do laço. Assim o interpretador seguirá para o comando seguinte ao laço.
Continue
O comando continue também deve ser utilizado no interior de laços, e funciona de maneira semelhante ao break, com a diferença que o fluxo ao invés de sair do laço volta para o início dele. Vejamos o exemplo:
for ($i = 0; $i < 100; $i++) {
if ($i % 2) continue;
echo “ $i “;
}
O exemplo acima é uma maneira ineficiente de imprimir os números pares entre 0 e 99. O que o laço faz é testar se o resto da divisão entre o número e 2 é 0. Se for diferente de zero (valor lógico true) o interpretador encontrará um continue, que faz com que os comandos seguintes do interior do laço sejam ignorados, seguindo para a próxima iteração.
7. Funções
Definindo funções
A sintaxe básica para definir uma função é:
function nome_da_função([arg1, arg2, arg3]) {
Comandos;
... ;
[return ];
}
Qualquer código PHP válido pode estar contido no interior de uma função. Como a checagem de tipos em PHP é dinâmica, o tipo de retorno não deve ser declarado, sendo necessário que o programador esteja atento para que a função retorne o tipo desejado. É recomendável que esteja tudo bem documentado para facilitar a leitura e compreensão do código. Para efeito de documentação, utiliza-se o seguinte formato de declaração de função:
tipo function nome_da_funcao(tipo arg1, tipo arg2, ...);
Este formato só deve ser utilizado na documentação do script, pois o PHP não aceita a declaração de tipos. Isso significa que em muitos casos o programador deve estar atento ao tipos dos valores passados como parâmetros, pois se não for passado o tipo esperado não é emitido nenhum alerta pelo interpretador PHP, já que este não testa os tipos.
Valor de retorno
Toda função pode opcionalmente retornar um valor, ou simplesmente executar os comandos e não retornar valor algum.
Não é possível que uma função retorne mais de um valor, mas é permitido fazer com que uma função retorne um valor composto, como listas ou arrays.
Argumentos
É possível passar argumentos para uma função. Eles devem ser declarados logo após o nome da função, entre parênteses, e tornam-se variáveis pertencentes ao escopo local da função. A declaração do tipo de cada argumento também é utilizada apenas para efeito de documentação.
Exemplo:
function imprime($texto){
echo $texto;
}
imprime(“teste de funções”);
Passagem de parâmetros por referência
Normalmente, a passagem de parâmetros em PHP é feita por valor, ou seja, se o conteúdo da variável for alterado, essa alteração não afeta a variável original.
Exemplo:
function mais5($numero) {
$numero += 5;
}
$a = 3;
mais5($a); //$a continua valendo 3
No exemplo acima, como a passagem de parâmetros é por valor, a função mais5 é inútil, já que após a execução sair da função o valor anterior da variável é recuperado. Se a passagem de valor fosse feita por referência, a variável $a teria 8 como valor. O que ocorre normalmente é que ao ser chamada uma função, o interpretador salva todo o escopo atual, ou seja, os conteúdos das variáveis. Se uma dessas variáveis for passada como parâmetro, seu conteúdo fica preservado, pois a função irá trabalhar na verdade com uma cópia da variável.7 Porém, se a passagem de parâmetros for feita por referência, toda alteração que a função realizar no valor passado como parâmetro afetará a variável que o contém.
Há duas maneiras de fazer com que uma função tenha parâmetros passados por referência: indicando isso na declaração da função, o que faz com que a passagem de parâmetros sempre seja assim; e também na própria chamada da função. Nos dois casos utiliza-se o modificador “&”. Vejamos um exemplo que ilustra os dois casos:
function mais5(&$num1, $num2) {
$num1 += 5;
$num2 += 5;
}
$a = $b = 1;
mais5($a, $b); /* Neste caso, só $num1 terá seu valor alterado, pois a passagem por referência está definida na declaração da função. */
mais5($a, &$b); /* Aqui as duas variáveis terão seus valores alterados. */
Argumentos com valores pré-definidos (default)
Em PHP é possível ter valores default para argumentos de funções, ou seja, valores que serão assumidos em caso de nada ser passado no lugar do argumento. Quando algum parâmetro é declarado desta maneira, a passagem do mesmo na chamada da função torna-se opcional.
function teste($php = “testando”) {
echo $php;
}
teste(); // imprime “testando”
teste(“outro teste”); // imprime “outro teste”
É bom lembrar que quando a função tem mais de um parâmetro, o que tem valor default deve ser declarado por último:
function teste($figura = circulo, $cor) {
echo “a figura é um “. $figura. “ de cor “ $cor;
}
teste(azul);
/* A função não vai funcionar da maneira esperada, ocorrendo um erro no interpretador. A declaração correta é: */
function teste2($cor, $figura = circulo) {
echo “a figura é um “. $figura. “ de cor “ $cor;
}
teste2(azul);
/* Aqui a função funciona da maneira esperada, ou seja, imprime o texto: “a figura é um círculo de cor azul” */
Contexto
O contexto é o conjunto de variáveis e seus respectivos valores num determinado ponto do programa. Na chamada de uma função, ao iniciar a execução do bloco que contém a implementação da mesma é criado um novo contexto, contendo as variáveis declaradas dentro do bloco, ou seja, todas as variáveis utilizadas dentro daquele bloco serão eliminadas ao término da execução da função.
Escopo
O escopo de uma variável em PHP define a porção do programa onde ela pode ser utilizada. Na maioria dos casos todas as variáveis têm escopo global. Entretanto, em funções definidas pelo usuário um escopo local é criado. Uma variável de escopo global não pode ser utilizada no interior de uma função sem que haja uma declaração.
Exemplo:
$php = “Testando”;
function Teste() {
echo $php;
}
Teste();
O trecho acima não produzirá saída alguma, pois a variável $php é de escopo global, e não pode ser referida num escopo local, mesmo que não haja outra com nome igual que cubra a sua visibilidade. Para que o script funcione da forma desejada, a variável global a ser utilizada deve ser declarada.
Exemplo:
$php = “Testando”;
function Teste() {
global $php;
echo $php;
}
Teste();
Uma declaração “global” pode conter várias variáveis, separadas por vírgulas. Uma outra maneira de acessar variáveis de escopo global dentro de uma função é utilizando um array pré-definido pelo PHP cujo nome é $GLOBALS. O índice para a variável referida é o próprio nome da variável, sem o caracter $. O exemplo acima e o abaixo produzem o mesmo resultado:
Exemplo:
$php = "Testando";
function Teste() {
echo $GLOBALS["php"]; // imprime $php
echo $php; // não imprime nada
}
Teste();
8. Variáveis
O modificador static
Uma variável estática é visível num escopo local, mas ela é inicializada apenas uma vez e seu valor não é perdido quando a execução do script deixa esse escopo. Veja o seguinte exemplo:
function Teste() {
$a = 0;
echo $a;
$a++;
}
O último comando da função é inútil, pois assim que for encerrada a execução da função a variável $a perde seu valor. Já no exemplo seguinte, a cada chamada da função a variável $a terá seu valor impresso e será incrementada:
function Teste() {
static $a = 0;
echo $a;
$a++;
}
O modificador static é muito utilizado em funções recursivas, já que o valor de algumas variáveis precisa ser mantido. Ele funciona da seguinte forma: O valor das variáveis declaradas como estáticas é mantido ao terminar a execução da função. Na próxima execução da função, ao encontrar novamente a declaração com static, o valor da variável é recuperado.
Em outras palavras, uma variável declarada como static tem o mesmo “tempo de vida” que uma variável global, porém sua visibilidade é restrita ao escopo local em que foi declarada e só é recuperada após a declaração.
Exemplo:
function Teste() {
echo "$a";
static $a = 0;
$a++;
}
O exemplo acima não produzirá saída alguma. Na primeira execução da função, a impressão ocorre antes da atribuição de um valor à função e, portanto o conteúdo de $a é nulo (string vazia). Nas execuções seguintes da função Teste() a impressão ocorre antes da recuperação do valor de $a e, portanto nesse momento seu valor ainda é nulo. Para que a função retorne algum valor o modificador static deve ser utilizado.
Variáveis Variáveis
O PHP tem um recurso conhecido como variáveis variáveis, que consiste em variáveis cujos nomes também são variáveis. Sua utilização é feita através do duplo cifrão ($$).
$a = “teste”;
$$a = “Mauricio Vivas”;
O exemplo acima e equivalente ao seguinte:
$a = “teste”;
$teste = “Mauricio Vivas”;
Variáveis enviadas pelo navegador
Para interagir com a navegação feita pelo usuário, é necessário que o PHP possa enviar e receber informações para o software de navegação. A maneira de enviar informações, como já foi visto anteriormente, geralmente é através de um comando de impressão, como o echo. Para receber informações vindas do navegador através de um link ou um formulário html o PHP utiliza as informações enviadas através da URL. Por exemplo: se seu script php está localizado em “http://localhost/teste.php3” e você o chama com a url “http://localhost/teste.php3?php=teste”, automaticamente o PHP criará uma variável com o nome $php contendo a string “teste”. Note que o conteúdo da variável está no formato urlencode. Os formulários html já enviam informações automaticamente nesse formato, e o PHP decodifica sem necessitar de tratamento pelo programador.
URLencode
O formato urlencode é obtido substituindo os espaços pelo caracter “+” e todos os outros caracteres não alfa-numéricos (com exceção de “_”) pelo caracter “%” seguido do código ASCII em hexadecimal.
Por exemplo: o texto “Testando 1 2 3 !!” em urlencode fica “Testando+1+2+3+%21%21”
O PHP possui duas funções para tratar com texto em urlencode. Seguem suas sintaxes:
string urlencode(string texto);
string urldecode(string texto);
Essas funções servem respectivamente para codificar ou decodificar um texto passado como argumento. Para entender melhor o que é um argumento e como funciona uma função, leia o tópico “funções”.
Variáveis de ambiente
O PHP possui diversas variáveis de ambiente, como a $PHP_SELF, por exemplo, que contém o nome e o path do próprio arquivo. Algumas outras contém informações sobre o navegador do usuário, o servidor http, a versão do PHP e diversas informações. Para ter uma listagem de todas as variáveis e constantes de ambiente e seus respectivos conteúdos, deve-se utilizar a função phpinfo().
Verificando o tipo de uma variável
Por causa da tipagem dinâmica utilizada pelo PHP, nem sempre é possível saber qual o tipo de uma variável em determinado instantes não contar com a ajuda de algumas funções que ajudam a verificar isso. A verificação pode ser feita de duas maneiras:
Função que retorna o tipo da variável
Esta função é a gettype. Sua assinatura é a seguinte:
string gettype(mixed var);
A palavra “mixed” indica que a variável var pode ser de diversos tipos.
A função gettype pode retornar as seguintes strings: “integer”, “double”, “string”, “array”, “object” e “unknown type”.
Funções que testam o tipo da variável
São as funções is_int, is_integer, is_real, is_long, is_float, is_string, is_array e is_object. Todas têm o mesmo formato, seguindo modelo da assinatura a seguir:
int is_integer(mixed var);
Todas essas funções retornam true se a variável for daquele tipo, e false em caso contrário.
Destruindo uma variável
É possível desalocar uma variável se ela não for usada posteriormente através da função unset, que tem a seguinte assinatura:
int unset(mixed var);
A função destrói a variável, ou seja, libera a memória ocupada por ela, fazendo com que ela deixe de existir. Se mais na frente for feita uma chamada á variável, será criada uma nova variável de mesmo nome e de conteúdo vazio, a não ser que a chamada seja pela função isset. Se a operação for bem sucedida, retorna true.
Verificando se uma variável possui um valor
Existem dois tipos de teste que podem ser feitos para verificar se uma variável está setada: com a função isset e com a função empty.
A função isset
Possui o seguinte protótipo:
int isset(mixed var);
E retorna true se a variável estiver setada (ainda que com uma string vazia ou o valor zero), e false em caso contrário.
A função empty
Possui a seguinte assinatura:
int empty(mixed var);
E retorna true se a variável não contiver um valor (não estiver setada) ou possuir valor 0 (zero) ou uma string vazia. Caso contrário, retorna false.
Arrays Multidimensionais
Arrays multidimensionais são arrays simples com um dos (ou todos) seus elementos sendo outro array e assim consecutivamente.
Exemplo:
$Campeao[5] = 123456789 ;
$Tricampeao[“casa”] = $Campeao;
$Tricampeao[“predio”] = 19191919;
$Brasil[1] = $Tricampeao;
$Brasil[2] = “Bicampeao”;
$Brasil[“copa”] = $Tricampeao;
$Brasil[4] = “Tetracampeao”;
$Brasil[“mundo”] = “Pentacampeao”;
echo $Campeao[5];// resultará 123456789Array simplesecho $Brasil[1][“casa”][5] ;// resultará 19191919Array tridimensionalecho $Tricampeao[“casa”][5];// resultará 123456789Array bidimensionalecho $Brasil[“copa”][“predio”];// resultará 19191919Array bidimensional
9. Classes e Objetos
Classe
Uma classe é um conjunto de variáveis e funções relacionadas a essas variáveis. Uma vantagem da utilização é poder usufruir o recurso de encapsulamento de informação. Com o encapsulamento o usuário de uma classe não precisa saber como ela é implementada, bastando para a utilização conhecer a interface, ou seja, as funções disponíveis. Uma classe é um tipo e, portanto não pode ser atribuída a uma variável. Para definir uma classe, deve-se utilizar a seguinte sintaxe:
class Nome_da_classe {
var $variavel1;
var $variavel2;
function funcao1 ($parâmetro) {
/* === corpo da função === */
}
}
Objeto
Como foi dito anteriormente, classes são tipos, e não podem ser atribuídas a variáveis. Variáveis do tipo de uma classe são chamadas de objetos, e devem ser criadas utilizando o operador new, seguindo o exemplo abaixo:
$variável = new $nome_da_classe;
Para utilizar as funções definidas na classe, deve ser utilizado o operador “->”, como no exemplo:
$variável->funcao1();
A variável $this
Na definição de uma classe, pode-se utilizar a variável $this, que é o próprio objeto. Assim, quando uma classe é instanciada em um objeto, e uma função desse objeto na definição da classe utiliza a variável $this, essa variável significa o objeto que estamos utilizando.
Como exemplo da utilização de classes e objetos, podemos utilizar a classe conta, que define uma conta bancária bastante simples, com funções para ver saldo e fazer um crédito.
class conta {
var $saldo;
function saldo() {
return $this->saldo;
}
function credito($valor) {
$this->saldo += $valor;
}
}
$minhaconta = new conta;
$minhaconta->saldo(); // a variável interna não foi
// inicializada, e não contém
// valor algum
$minhaconta->credito(50);
$minhaconta->saldo(); // retorna 50
SubClasses
Uma classe pode ser uma extensão de outra. Isso significa que ela herdará todas as variáveis e funções da outra classe, e ainda terá as que forem adicionadas pelo programador. Em PHP não é permitido utilizar herança múltipla, ou seja, uma classe pode ser extensão de apenas uma outra.Para criar uma classe extendida, ou derivada de outra, deve ser utilizada a palavra reservada extends, como pode ser visto no exemplo seguinte:
class novaconta extends conta {
var $numero;
function numero() {
return $this->numero;
}
}
A classe acima é derivada da classe conta, tendo as mesmas funções e variáveis, com a adição da variável $numero e a função numero().
Construtores
Um construtor é uma função definida na classe que é automaticamente chamada no momento em que a classe é instanciada (através do operador new). O construtor deve ter o mesmo nome que a classe a que pertence. Veja o exemplo:
class conta {
var $saldo;
function conta () {
$this.saldo = 0;
}
function saldo() {
return $this->saldo;
}
function credito($valor) {
$this->saldo += $valor;
}
}
Podemos perceber que a classe conta agora possui um construtor, que inicializa a variável $saldo com o valor 0.
Um construtor pode conter argumentos, que são opcionais, o que torna esta ferramenta mais poderosa. No exemplo acima, o construtor da classe conta pode receber como argumento um valor, que seria o valor inicial da conta.
Vale observar que para classes derivadas, o construtor da classe pai não é automaticamente herdado quando o construtor da classe derivada é chamado.
10. PHP avançado
Interagindo com o browser
PHP também permite interagir com informações do browser automaticamente. Por exemplo, o script a seguir mostra informações sobre o browser do usuário.
Aprendendo PHP
echo $HTTP_USER_AGENT; ?>
Esse código em um Internet Explorer 6.0 com sistema operacional Windows 98, geraria: Mozilla/4.0 (compatible; MSIE 6.0; Windows 98)
Aprendendo PHP
if (strpos($HTTP_USER_AGENT,"MSIE”) != 0) {
echo "Você usa Internet Explorer";
} else {
echo "Você não usa Internet Explorer";
}
?>
Neste exemplo, será apenas exibido um texto informando se está sendo utilizado o Microsoft Internet Explorer ou não, mas para outras funções poderia ser utilizado algo semelhante.
É bom notar o surgimento de mais uma função no código anterior: strpos(string1,string2). Essa função retorna a posição da primeira aparição de string2 em string1, contando a partir de zero, e não retorna valor algum se não ocorrer. Assim, para testar se a string $HTTP_USER_AGENT contém a string “MSIE”, basta testar se strpos devolve algum valor.
Utilizando formulários HTML
Ao clicar num botão “Submit” em um formulário HTML as informações dos campos serão enviadas ao servidor especificado para que possa ser produzida uma resposta. O PHP trata esses valores como variáveis, cujo nome é o nome do campo definido no formulário. O exemplo a seguir mostra isso, e mostra também como o código PHP pode ser inserido em qualquer parte do código HTML:
Aprendendo PHP ";
?>
Ao salvar o arquivo acima e carregá-lo no browser, o usuário verá apenas um formulário que contém um espaço para digitar o texto. Ao digitar um texto qualquer e submeter o formulário, a resposta, que é o mesmo arquivo PHP (indicado pela constante $PATH_INFO, que retorna o nome do arquivo) exibirá a mensagem "Você digitou <>".
Isso ocorre porque o código PHP testa o conteúdo da variável $texto. Inicialmente ele é uma string vazia, e por isso nada é impresso na primeira parte. Quando algum texto é digitado no formulário e submetido, o PHP passa a tratá-lo como uma variável. Como no formulário o campo possui o nome “texto”, a variável com seu conteúdo será $texto. Assim, no próximo teste o valor da variável será diferente de uma string vazia, e o PHP imprime um texto antes do formulário.
Cookies
Cookies são mecanismos para armazenar e consultar informações nos browsers dos visitantes da página. O PHP atribui cookies utilizando a função setcookie, que deve ser utilizada antes da tag numa página.
O uso de cookies não é recomendado quando se trata de informações sigilosas. Os dados dos cookies são armazenados no diretório de arquivos temporários do visitante, sendo facilmente visualizado por pessoas mal intencionadas.
Além da opção “aceitar cookies” que pode ser desativada a qualquer momento pelo visitante.
Para uma transmissão de dados segura é recomendável o uso de sessões(ver adiante).
Setcookie(“nome_do_cookie”,”seu_valor”,”tempo_de_vida”,”path”,”domínio”,”conexão_segura”)
Nome_do_cookie = É o nome que, posteriormente, se tornará a variável e o que o servirá de referência para indicar o cookie.
Seu_valor = É o valor que a variável possuirá. Esse valor pode ser de todos os tipos.
Tempo_de_vida = É o tempo, em segundos, que o cookie existirá no computador do visitante. Uma vez excedido esse prazo o cookie se apaga de modo irrecuperável. Se esse argumento ficar vazio, o cookie se apagará quando o visitante fechar o browser.
Path = endereço da página que gerou o cookie – automático
Domínio = domínio ao qual pertence o cookie – automático
Conexão_segura = Indica se o cookie deverá ser transmitido somente em uma conexão segura HTTPS.
Sessão
Sessões são mecanismos muito parecidos com os tradicionais cookies. Suas diferenças são que sessões são armazenadas no próprio servidor e não expiram a menos que o programador queira apagar a sessão.
Existem algumas funções que controlam sessões e estão detalhadas no capítulo “12.Bibliotecas de funções”.
Aqui estão as funções de sessão mais usadas.
Nome da funçãoArgumentosSession_start()Não precisa de argumentoSession_register()A variável sem o cifrãoSession_unregister()A variável sem o cifrãoSession_is_registered()A variável sem o cifrão
O session_destroy() só deve ser usado quando for da vontade do programador acabar com todos as sessões daquele visitante, portanto muito cuidado com essa função.
Require
A função require põe o conteúdo de um outro arquivo no arquivo php atual, antes de ser executado. Quando o interpretador do PHP ler este arquivo, ele encontrará todo o conteúdo dos “require´s” adicionado no arquivo corrente.
Require(“nomedoarquivo”);
Criando o hábito de usar essa função, o programador pode vir a encontrar um erro de arquivo já declarado. Para evitar isso é recomendável que sempre que a função require for utilizada ela seja substituída pela função require_once.
Require_once(“nome_do_arquivo“);
Include
A função Include é semelhante à função require, com a diferença que o código do arquivo incluído é processado em tempo de execução, permitindo que sejam usados “includes” dentro de estruturas de controle como for e while.
$arqs = array(‘a1.inc’,’a2.inc’,’a3.inc’) ;
for ($i=0;$i
Nome :
Email :
Esportes de preferência: