Olá.. Hoje vou mostrar como instalar e configurar o IIS em seu computador. Lembrando que o IIS 7.0 só está disponível nas versões do Windows XP Prof., Vista business, Ultimate e Windows 7 Business e Ultimate.
Estou usando o Windows Vista Ultimate neste tutorial.
Para instalar o IIS em seu computador siga os seguintes passos:
1° Passo – Acesse o painel de controle, Programas e recursos.
2° Passo – Clique em Ativar, Desativar recursos do Windows. (imagem 1)
3° Passo – Marque a opção Serviços de Informações da Internet. (imagem 2)
Certifique de que as funcionalidades desejadas estão marcadas, como ASP, ASP.NET…etc…
Clique em Ok e aguarde a finalização da instalação.
Agora faça o seguinte teste.
Abra o browser e acesse http://localhost, ou http://127.0.0.1, deverá aparecer o logo do iis. (imagem 4)
Para obter mais informações acesse o site do iis pelo endereço http://www.iis.net/
Configurando o IIS
1° Passo – Acesse o painel de controle, Ferramentas Administrativas, e abra o
Gerenciador do Serviços de Informações da Internet (IIS). (imagem 5)
2° Passo – Para adicionar um site ao IIS clique com o botão do lado deito do mouse sobre o nome do computador e selecione a opção adicionar site. (imagem 6)
3° Passo – Preencha com os dados do seu site. Senão tiver muito conhecimento sobre portas e outras configurações deixe o padrão ou conforme imagem abaixo. Aconselho criar uma pasta dentro do diretório C:inetpubwwwrootNome-Site
O nome do seu site que você configurou irá aparecer abaixo do site pré configurado “Default Web Site”.
Seu site esta configurado. (Imagem 8 )
Pare o serviço do site Default Web Site e inicie o que você criou.
ASP é uma tecnologia da Microsoft que disponibiliza um conjunto de componentes para o desenvolvimento de páginas Web dinâmicas. Tais páginas consistem em arquivos de extensão *.asp no formato texto(ASCII) que contém combinações de scripts e tags HTML.
Para compilar seus arquivos .ASP é recomendado pela microsoft usar o servidor web IIS (que por sua vez é da propria microsoft, não preciso nem comentar….certo!) mas pode ser compilado em outros servidores como APACHE.
A instalação e configuração do IIS é bem rápida e prática para um ambiente de testes.
Na próxima postagem vou mostrar como instalar o IIS em seu computador.
O uso de session ajuda bastante, permite setarmos váriaveis globais para usar em todo o site sem a necessidade de ficar carregando ou obtendo o valor da váriavel atraves do $_GET (usuário.php?ID=123).
Para começar a usar sessão no PHP siga o exemplo abaixo.
crie um arquivo chamado teste1.php
session_start('nome_sessao'); //esse comando deve estar na primeira linha
//você também poderá ativar o buffer usando o comando ob_start que evita alguns erros
ob_start(); //ob_start — Ativa o buffer de saída
//atribuimos a palavra valor para variavel global nome_var_session
$_SESSION['nome_var_session'] = "valor";
Agora para testar crie um segundo arquivo chamado teste2.php
//inicie com o comando session e lembre-se de manter o mesmo nome que atribuiu para a sessão anterior.
session_start('nome_sessao');
//imprimi a variavel global
echo $_SESSION['nome_var_session'];
Funções para Sessão
* session_cache_expire — Retorna o prazo do cache atual
* session_cache_limiter — Obtém e/ou define o limitador do cache atual
* session_commit — Sinônimo de session_write_close
* session_decode — Decifra dado de sessão de uma string
* session_destroy — Destrói todos os dados registrados em uma sessão
* session_encode — Codifica os dados da sessão atual como uma string
* session_get_cookie_params — Obtém os parâmetros do cookie da sessão
* session_id — Obtém e/ou define o id de sessão atual
* session_is_registered — Descobre se uma variável global está registrada numa sessão
* session_module_name — Obtém e/ou define o módulo da sessão atual
* session_name — Obtém e/ou define o nome da sessão atual
* session_regenerate_id — Atualiza o id da sessão atual com um novo gerado
* session_register — Registrar uma ou mais variáveis globais na sessão atual
* session_save_path — Obtém e/ou define o save path da sessão atual
* session_set_cookie_params — Define os parâmetros do cookie de sessão
* session_set_save_handler — Define a sequência de funções de armazenamento
* session_start — Inicia dados de sessão
* session_unregister — Desregistra uma variável global da sessão atual
* session_unset — Libera todas as variáveis de sessão
* session_write_close — Escreve dados de sessão e termina a sessão
O PHP tem uma função que verifica se um arquivo ou diretorio existe.
file_exists — Checa se um arquivo ou diretório existe
pode ser usado em vários casos, como exemplo um upload de imagens e arquivos que há necessidade de checar se a pasta onde serão salvos os uploads existe ou verificar se determinada imagem existe.
$arquivo = '/diretorio/arquivo.txt';
if (file_exists($arquivo)) {
echo "O arquivo $arquivo existe";
} else {
echo "O arquivo $arquivo não existe";
}
Em um cadastro de pessoas onde poderá ter ou não uma foto cadastrada.
Olá pessoal, hoje vou mostrar sobre os tipos de dados que podem ser definidos para as colunas do seu banco de dados e tornar suas consultas mais rápidas.
Tipos de data e Hora:
DATE – armazena data tipo AAAA-MM-DD
DATETIME – armazena data e hora no formato – AAAA-MM-DD HH:MM:SS
TIME – armazena hora no formato – hh:mm:ss
YEAR – armazena ano no formato – aaaa
TIMESTAMP – armazena data e hora podendo ser usando com TIME_STAMP
Tipos numéricos
Bytes Range
TINYINT 1 -128 até 127
SMALLINT 2 -32768 até 32767
MEDIUMINT 3 -8388608 até 8388607
INT 4 -2147483648 até 2147483647
BIGINT 8 -9223372036854775808 até 9223372036854775807
Tipos string
Os tipos strings são CHAR, VARCHAR, BLOB, TEXT, ENUM, e SET.
A seguinte tabela ilustra as diferenças entre os dois tipos de colunas, mostrando o resultado de se armazenar vários valores de strings em campos CHAR(4) e VARCHAR(4):
Então usar varchar é melhor para meu banco ficar mais leve certo ? Errado!
É obvio que para um colunas com valores fixos você deve usar CHAR, e colunas com valores variaveis deve-se usar o VARCHAR.
Mas isso vai depender muito do tipo de informação que será guardada pois em alguns casos é melhor usar CHAR pois a maneira que o Mysql trabalha internamente para essas colunas poderá fazer sua consulta ficar mais lenta.
E também depende de como esta seus indices entre outros fatores que influenciam.
Tipo ENUM
Enum – armazena um valor único de uma lista pré especificada.
Ex.: ENUM(‘S’,’N’) – somente será aceito os valos S,N
pode ser usado para campos como, sexo, recebe newsletter,
Por incrivel que pareça ainda encontramos usuários utilizando navegadores com versões desatualizadas.
Para ajudar na campanha Update your Browser(atualize seu navegador), estou divulgando o site e links para atualização dos navegadores mais usados.
“Versões antigas e desatualizadas de navegadores têm problemas de segurança e não acompanham os novos padrões de desenvolvimento para a Internet. O Atualize seu navegador faz parte de um movimento internacional para eliminar os navegadores obsoletos do mercado.”
Faça download da nova versão do seu navegador agora mesmo.
Hoje vamos aprender a fazer um Filtro de palavras inapropriadas com substiuição de palavras. Poderá ser implementado no seu sistema de mural de recados, comentários de artigos ou fotos, enfim vamos ao que interessa.
Nessa parte vamos criar uma tabela no banco de dados para armazenar as palavras que queremos filtrar.
CREATE TABLE IF NOT EXISTS `filtro_palavras` (
`Codigo` int(4) NOT NULL AUTO_INCREMENT,
`MsgErrada` varchar(200) DEFAULT NULL,
`MsgCorreta` varchar(200) DEFAULT '--',
PRIMARY KEY (`Codigo`),
UNIQUE KEY `MsgErrada` (`MsgErrada`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COMMENT='armazena filtros de palavras' AUTO_INCREMENT=1 ;
Agora vamos criar a função que vai fazer todo o trabalho.
Crie um arquivo chamado filtro.php e coloque o codigo abaixo.
//conexão com o banco de dados
$conexao = mysql_connect('servidor', 'usuario', 'senha') or die(mysql_error());
//seleciona banco de dados
$db = mysql_select_db('banco', $conexao) or die(mysql_error());
// função para Filtrar palavras inapropriadas
function filtro($mensagem)
{
if ($mensagem) {
$resultado = mysql_query("SELECT * FROM filtro_palavras");
while ($mostra = mysql_fetch_array($resultado)) {
$mensagem= str_replace($mostra['MsgErrada'], $mostra['MsgCorreta'], $mensagem);
}
}
return $mensagem;
}
?
Para chamar a função dentro do seu código siga o exemplo abaixo:
//inclue a função
include('filtro.php');
//chama a função
filtro("frase mural recado")
Continuando a primeira aula, vamos gerar a exibição da enquete.
Assista a video aula para entender cada arquivo, estou explicando detalhadamente.
Começando crie um arquivo chamado conexao.php
//este arquivo é responsavel pela conexao do banco de dados
$host = "localhost";
$database = "enquete";
$login_db = "root";
$senha_db = "pass123";
$conexao = mysql_connect ($host, $login_db, $senha_db) or die ("Erro: ".mysql_error());
$db = mysql_select_db($database);
Agora vamos criar o arquvo enquete.php para mostrar nossa enquete.
A imagem abaixo mostra como será o resultado no final.
////////////////arquivo enquete_comentar.php
/*
desenvolvido por Fabiano Bento
http://www.fabianobento.com.br
*/
//arquivo CSS de estilos
//java script para validar formulário
//verifica se existe a variavel ACT no GET
if(isset($_GET['act'])){
$act = $_GET['act'];
switch ($act) {
case "escrever":
echo "Escreva seu comentário!";
//cria o formulário e envia para o mesmo arquivo e seta avariavel act
//termina o switct
break;
//verifica se o valor de ACT é igual a inc
case "inc":
//chama o arquivo de conexao com o banco
require_once('inc/conexao.php');
$codigo_enquete = $_POST['codigo_enquete'];
$ip = getenv('REMOTE_ADDR');
$provedor = gethostbyaddr($_SERVER['REMOTE_ADDR']);
$datahora = date(" Y-m-d H:i:s");
$form_nome = $_POST['nome'];
$form_email = $_POST['email'];
$form_cidade = $_POST['cidade'];
$form_uf = $_POST['uf'];
$form_comentario = $_POST['comentario'];
$form_btn_comentar = $_POST['btn_comentar'];
$enqcStatus = "A";
//grava os dados dentro da tabela enquetes comentarios
$sql = " INSERT INTO enquetes_comentarios (`enqcCodigo` ,`enqcCodEnquete` ,`enqcIpEnvio` ,`enqcProvedorEnvio` ,`enqcDtHrEnvio` ,`enqcNome` ,`enqcEmail` ,`enqcCidade` ,`enqcUF` ,`enqcComentario` ,`enqcStatus`)VALUES (' ', '$codigo_enquete', '$ip', '$provedor', '$datahora', '$form_nome', '$form_email', '$form_cidade', '$form_uf', '$form_comentario', '$enqcStatus')";
mysql_query("$sql");
echo "";
echo "";
break;
}
}
?>
Tela do formulário do arquivo enquete_comentar.php
Explicando o conteudo e funcionamento de cada arquivo.
*Lembrando que o texto antes da barra é o nome da pasta.
enquete/inc/conexao.php - função que conecta no banco de dados
enquete/enquete.php - este arquivo mostra a enquete com as opções para votar e links para comentar e resultado
enquete/enquete_resultado.php - aqui mostra o resultado da enquete e comentários
enquete/enquete_comentar.php - este é o formulário para envio dos comentarios
enquete/enquete_votar.php - este arquivo recebe os dados do arquivo enquete.php e grava a opções escolhida no banco de dados
Nesta aula, vou ensinar com desenvolver um sistema de enquetes para ilimitadas enquetes.
Primeiro nos vamos criar o banco de dados e as tabelas para armazenar as enquetes, os votos, comentarios, e log de registros os votos.
Assista ao video para entender sobre cada coluna das tabelas
O SQL das tabelas;
//tabela enquetes
CREATE TABLE IF NOT EXISTS `enquetes` (
`enqCodigo` int(10) NOT NULL AUTO_INCREMENT COMMENT 'codigo da enquete',
`enqDtCadastro` date NOT NULL COMMENT 'data do cadastro',
`enqNmEnquete` varchar(200) NOT NULL COMMENT 'pergunta da enquete',
`enqOpcao1` varchar(150) NOT NULL COMMENT 'resposta 1',
`enqOpcao2` varchar(150) NOT NULL COMMENT 'resposta 2',
`enqOpcao3` varchar(150) NOT NULL COMMENT 'resposta 3',
`enqOpcao4` varchar(150) NOT NULL COMMENT 'resposta 4',
`enqOpcao5` varchar(150) NOT NULL COMMENT 'resposta 5',
`enqOpcao6` varchar(150) NOT NULL COMMENT 'resposta 6',
`enqOpcao7` varchar(150) NOT NULL COMMENT 'resposta 7',
`enqOpcao8` varchar(150) NOT NULL COMMENT 'resposta 8',
`enqOpcao9` varchar(150) NOT NULL COMMENT 'resposta 9',
`enqOpcao10` varchar(150) NOT NULL COMMENT 'resposta 10',
`enqVotos1` int(10) NOT NULL DEFAULT '0' COMMENT 'htis 1',
`enqVotos2` int(10) NOT NULL DEFAULT '0' COMMENT 'htis 2',
`enqVotos3` int(10) NOT NULL DEFAULT '0' COMMENT 'htis 3',
`enqVotos4` int(10) NOT NULL DEFAULT '0' COMMENT 'htis 4',
`enqVotos5` int(10) NOT NULL DEFAULT '0' COMMENT 'htis 5',
`enqVotos6` int(10) NOT NULL DEFAULT '0' COMMENT 'htis 6',
`enqVotos7` int(10) NOT NULL DEFAULT '0' COMMENT 'htis 7',
`enqVotos8` int(10) NOT NULL DEFAULT '0' COMMENT 'htis 8',
`enqVotos9` int(10) NOT NULL DEFAULT '0' COMMENT 'htis 9',
`enqVotos10` int(10) NOT NULL DEFAULT '0' COMMENT 'htis 10',
`enqDtInicioExibicao` date NOT NULL COMMENT 'data inicio da exiicao',
`enqDtFinalExibicao` date NOT NULL COMMENT 'data final da exibicao',
`enqStatus` enum('A','I') NOT NULL DEFAULT 'A' COMMENT 'ativo ou inativo',
PRIMARY KEY (`enqCodigo`,`enqNmEnquete`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COMMENT='Entidade para os dados das enquetes' AUTO_INCREMENT=1 ;
//tabela enquetes_comentarios
CREATE TABLE IF NOT EXISTS `enquetes_comentarios` (
`enqcCodigo` int(20) NOT NULL AUTO_INCREMENT COMMENT 'codigo do comentario',
`enqcCodEnquete` int(10) NOT NULL,
`enqcIpEnvio` varchar(30) NOT NULL COMMENT 'ip do usuario',
`enqcProvedorEnvio` varchar(150) NOT NULL COMMENT 'provedor do ip',
`enqcDtHrEnvio` datetime NOT NULL COMMENT 'data e hora do envio',
`enqcNome` varchar(40) NOT NULL COMMENT 'nome que quem enviou',
`enqcEmail` varchar(60) NOT NULL COMMENT 'email de quem envu',
`enqcCidade` varchar(150) NOT NULL,
`enqcUF` char(2) NOT NULL,
`enqcComentario` mediumtext NOT NULL COMMENT 'comentáro',
`enqcStatus` enum('A','I') NOT NULL,
PRIMARY KEY (`enqcCodigo`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COMMENT='Entidade para os comentários das enquetes' AUTO_INCREMENT=1 ;
//tabela enquete_log
CREATE TABLE IF NOT EXISTS `enquetes_log` (
`enqlCodigo` int(30) NOT NULL AUTO_INCREMENT COMMENT 'codigo do envio',
`enqlCodEnquete` int(10) NOT NULL COMMENT 'codigo da enquete',
`enqlIpEnvio` varchar(30) NOT NULL COMMENT 'ip que enviou',
`enqlDtHrEnvio` datetime NOT NULL COMMENT 'data e hora do envio',
`enqlOpcao` varchar(5) NOT NULL,
PRIMARY KEY (`enqlCodigo`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COMMENT='Entidade para os dados de log dos votos' AUTO_INCREMENT=2 ;