Jump to content


Photo

Acentuação Xajax 0.5 Por Post


  • Faça o login para participar
4 replies to this topic

#1 strago

strago

    Novato no fórum

  • Usuários
  • 7 posts
  • Sexo:Não informado

Posted 10/04/2008, 09:48

Fala ae galera .... to com um probleminha xarope de resolver, vou comentar o problema a minha estrtura e depois descreve-lo , se alguem puder me ajudar eu ficaria muito grato.

estou usando o framework xajax 0.54
PHP 5
MySQL 5.2.4
Apache 2.2.8

Montei um script ajax.common.php
Onde eu ... instancio o xajax , efetuo as cfgs, registro as funcoes ....

Outro script ajax.server.php
Onde eu crio as funções que serão chamadas nas páginas, a maioria das funções usam classes externas que são declaradas no inicio do script, essas classes fazem as consultas, inserções, enfim, são elas que interagem diretamente com o db. Pra ficar mais claro vou colocar um exemplo

# ajax.server.php
require("class.agenda.php");

function facaisso($frm) {
$obj = new xajaxResponse();
$agenda = new agenda;
$agenda->gravar($frm);
if ($agenda->erro) {
$obj->alert($agenda->erro);
return $obj;
} else {
$obj->aler($agenda->resultado);
return $obj;
}
}

o problema é:
O formulário é pasado como um parâmetro, e os campos podem conter caracteres acentuados, quando a classe recebe o formulario, ela testa os dados e salva no db, outra classe faz o processo inverso para a recuperação.
Já tentei usar o htmlentities antes de salvar e na recuperação dos dados, porém , os entities só são aceitos quando eu utilizo o xajax->assign, quando eu tento jogar os valores devolta aos campos com o xajax->script, os acentos ficam doidos.

já tentei fazer de tudo que é jeito, convertendo na ida e nao da volta, na volta e nao na ida, nos dois, em nenhum e sempre da a mesma xxxxxx.

O que eu andei percebendo, é que os dados chegam na classe já com os caracteres acentuados com problemas, ou seja, em algum lugar entre o form html e a classe eles estão sendo lidos em utf-8.

estou usando o $xajax->configure("characterEncoding","ISO-8859-1"); no arquivo ajax.common.php depois da classe ser instanciada, o debug informa que o ajax está usando o ISO-8859-1. é ai que eu não entendo.

O HTML está setado para usar o ISO-8859-1 tb, mas mesmo assim a conversão é feita antes mesmo que eu possa usar o htmlentities.

Vejam:
Usuario -> xajax(form) -> Classe -> db;
Cuiabá -> Cuiabá -> Cuiabá -> db
OK ERRO

Ao meu entender ela deveria proceder como
Cuiabá -> Cuiabá -> Cuiabá -> db

Alguem ?

#2 Tohma

Tohma

    12 Horas

  • Usuários
  • 202 posts
  • Sexo:Masculino
  • Localidade:Curitiba

Posted 10/04/2008, 09:54

usa utf8_encode no lugar de htmlenties ... para resolver problemas com acentos no ajax
DBPlex dbplex.com.br

#3 strago

strago

    Novato no fórum

  • Usuários
  • 7 posts
  • Sexo:Não informado

Posted 10/04/2008, 10:34

Não resolveu,

O problema é que os dados saem do form html para o xajax pelo método POST, o xajax reenvia o form para a Classe já com os acentos doidos, na classe, não importa o que eu faça, pq ele ja ta com os acentos trocados. O que eu não quero é ter que no xajax, ler os campos e envia-los a classe como parâmetros separados. Mesmo porque eu axo que eles vão ter o mesmo problema.

Alguma coisa me diz que é algo besta que ta passando desapercebido, vou colar os scripts e funcoes que estou usando pra ver c ajuda.

<?php
//ajax.common.php
	require("../xajax/xajax_core/xajax.inc.php");
	$xajax = new xajax("class/ajax.server.php");
	
	$xajax->configure('debug', true);
	$xajax->configure("characterEncoding","ISO-8859-1");
	$xajax->configure('javascript URI', '../xajax/');

	$xajax->registerFunction("agendaListar");
	$xajax->registerFunction("agendaGravar");

?>

//ajax.server.php
<?php
	require("../dbdoc/class.agenda.php");
	function agendaGravar($frm) {
		$obj = new xajaxResponse();
		$agenda = new agenda;
		$agenda->gravar($frm);
		if ($agenda->erro) {
			$obj->alert($agenda->erro);
			return $obj;
		} else {
			if ($agenda->tipo == "Exito") {
				$obj->script("$('edtNumero').value = ''");
				$obj->script("$('edtTitulo').value = ''");
				$obj->script("$('edtCidade').value = ''");
				$obj->script("$('edtEnd').value = ''");
				$obj->script("$('edtData').value = ''");
				$obj->script("$('edtHora').value = ''");
				$obj->script("$('edtConf').options[0].selected = \"selected\";");
				$obj->script("$('btnGravar').disabled = true");
				$obj->assign('edtDescricao', 'innerHTML', '');
				$obj->script("$('edtTitulo').focus();");
				$obj->alert($agenda->resultado);
				return $obj;			
			} else {
				$obj->alert($agenda->erro);
				return $obj;			
			}
		}
	}

	require("class/ajax.common.php");
	
	$xajax->processRequest();

?>

//class.agenda.php
<?php
	class agenda {
		public $resultado;
		public $erro;
		public $tipo;

		//GRAVAR COMPROMISSO
		function gravar($frm) {
			if (strlen(trim(strip_tags(stripslashes($frm['edtTitulo'])))) == "0") {
				$this->tipo = "Dados";
				$this->erro = "Por favor, informe um título para o compromisso.";
				return $this->tipo;
			} elseif (strlen(trim(strip_tags(stripslashes($frm['edtCidade'])))) == "0") {
				$this->tipo = "Dados";
				$this->erro = "Por favor, informe a cidade do compromisso.";
				return $this->tipo;			
			} elseif (strlen(trim(strip_tags(stripslashes($frm['edtEnd'])))) == "0") {
				$this->tipo = "Dados";
				$this->erro = "Por favor, informe o endereço do compromisso.";
				return $this->tipo;			
			} elseif (strlen(trim(strip_tags(stripslashes($frm['edtData'])))) != "10") {
				$this->tipo = "Dados";
				$this->erro = "Por favor, informe uma data válida.\r\n (Ex: 00/00/0000).";
				return $this->tipo;			
			} elseif (strlen(trim(strip_tags(stripslashes($frm['edtHora'])))) < "5") {
				$this->tipo = "Dados";
				$this->erro = "Por favor, informe uma hora válida.\r\n (Ex: 00:00).";
				return $this->tipo;			
			} elseif (strlen(trim(strip_tags(stripslashes($frm['edtDescricao'])))) == "0") {
				$this->tipo = "Dados";
				$this->erro = "Por favor, descreva o compromisso.";
				return $this->tipo;			
			} else {
				$dbx = new db;
				$dbx->conectar();
				if ($dbx->erro) {
					$this->tipo = "Conexao";
					$this->erro = "Não foi possível gravar o compromisso";
					return $this->tipo;
				} else {
					//VERIFICANDO SE EXISTE ALGUM COMPROMISSO NA MESMA DATA E HORA
					$titulo		= checkslashes(strip_tags(stripslashes(htmlentities($frm['edtTitulo']))));
					$cidade		= checkslashes(strip_tags(stripslashes(htmlentities($frm['edtCidade']))));
					$end		= checkslashes(strip_tags(stripslashes(htmlentities($frm['edtEnd']))));
					$data		= checkslashes(datetosql(strip_tags(stripslashes($frm['edtData']))));
					$hora		= checkslashes(strip_tags(stripslashes($frm['edtHora'])));
					$descricao	= checkslashes(strip_tags(stripslashes(htmlentities($frm['edtDescricao']))));
					$conf		= $frm['edtConf'];				
					if (!strip_tags(stripslashes($frm['edtNumero']))) {
						$sql = "SELECT * FROM tab_agenda WHERE (data = '$data') AND (hora = '$hora')";
						$dbx->consultar($sql);
						if (@mysql_num_rows($dbx->consulta) > "0") {
							$temp = $frm['edtData'];
							$this->tipo = "Dados";
							$this->erro = "Desculpe, Já existe um compromisso agendado para $temp as $hora";
							return $this->tipo;
						}						
						$sql = "INSERT INTO tab_agenda SET data = '$data', hora = '$hora', compro = '$titulo', cidade = '$cidade', end = '$end', descricao = '$descricao', conf = '$conf'";
					} else {
						$id = checkslashes(strip_tags(stripslashes($frm['edtNumero'])));
						$sql = "UPDATE tab_agenda SET data = '$data', hora = '$hora', compro = '$titulo', cidade = '$cidade', end = '$end', descricao = '$descricao', conf = '$conf' WHERE id_agenda = '$id'";
					}					
					//INSERÇÃO					
					$dbx->consultar($sql);
					if ($dbx->erro) {
						$this->tipo = "Consulta";
						$this->erro = "Não foi possível gravar o compromisso";
						return $this->tipo;					
					} else {
						$this->tipo = "Exito";
						$this->erro = "";
						if ($id) {
							$this->resultado = "O compromisso foi alterado.";
						} else {
							$this->resultado = "O compromisso foi agendado.";
						}
						return $this->tipo;
					}
				}
			}
		}
}
?>


//lista-agenda.php
//form
					<form id="frmCadastro" action="" onsubmit="return false">
						<fieldset class="field-pesquisa">
							<legend class="ind-texto">Cadastro de Compromissos</legend>
							<p class="texto-l">Número</p>
							<p class="texto-r">Título</p>							
							<p class="campo-l"><input type="text" class="ind-filtro" id="edtNumero" name="edtNumero" size="20" maxlength="11" readonly="true" /></p>
							<p class="campo-r"><input type="text" class="ind-filtro" id="edtTitulo" name="edtTitulo" size="126" maxlength="100" onchange="checkCampos('frmCadastro');" onblur="checkCampos('frmCadastro');" onkeydown="Tabular();" /></p>
							<p class="texto-l2">Cidade</p>
							<p class="texto-r">Endereço</p>							
							<p class="campo-l"><input type="text" class="ind-filtro" id="edtCidade" name="edtCidade" size="53" maxlength="100" onchange="checkCampos('frmCadastro');" onblur="checkCampos('frmCadastro');" onkeydown="Tabular();" /></p>
							<p class="campo-r"><input type="text" class="ind-filtro" id="edtEnd" name="edtEnd" size="93" maxlength="100" onchange="checkCampos('frmCadastro');" onblur="checkCampos('frmCadastro');" onkeydown="Tabular();" /></p>
							<p class="texto-l">Data</p>
							<p class="texto-l">Hora</p>
							<p class="texto-r">Confirmado</p>
							<p class="campo-l">
								<input type="text" class="ind-filtro" id="edtData" name="edtData" size="15" maxlength="10" onchange="checkCampos('frmCadastro');" onblur="checkCampos('frmCadastro');" onkeydown="Tabular();" />
								<a href="#" onclick="displayCalendar(document.forms[0].edtData,'dd/mm/yyyy',this)"><img src="imagens/calendario.gif" height="16" width="16" alt="Calendário"  /></a>
							</p>
							<p class="campo-l">
								<input type="text" class="ind-filtro" id="edtHora" name="edtHora" size="16" maxlength="8" onchange="checkCampos('frmCadastro');" onblur="checkCampos('frmCadastro');" onkeydown="Tabular();" />
								<a href="#" onclick="displayCalendar(document.forms[0].edtHora,'hh:ii',this,true,document.forms[0].edtHora)"><img src="imagens/calendario.gif" height="16" width="16" alt="Calendário"  /></a>								
							</p>
							<p class="campo-r">
								<select id="edtConf" name="edtConf" class="ind-filtro">
									<option value="Aguardando" selected="selected">Aguardando</option>
									<option value="Confirmado">Confirmado</option>
									<option value="Cancelado">Cancelado</option>
								</select>
							<p class="foto-texto">Descrição</p>
							<p class="foto-campo">
								<textarea id="edtDescricao" name="edtDescricao" cols="151" rows="5" class="ind-filtro" onchange="checkCampos('frmCadastro');" onblur="checkCampos('frmCadastro');"></textarea>
							</p>					
							<p class="foto-btn">
								<input type="button" value="  Gravar  " id="btnGravar" name="btnGravar" class="ind-filtro" disabled="true" onclick="xajax_agendaGravar(xajax.getFormValues('frmCadastro'));" />
								<input type="button" value="Excluir" id="btnExcluir" name="btnExcluir" class="ind-filtro" disabled="true" onclick="agendaExcluir($('edtNumero').value);" />
								<input type="reset" value=" Limpar " id="btnLimpar" name="btnLimpar" class="ind-filtro" onclick="$('btnExcluir').disabled = true; $('btnGravar').disabled = true;" />
							</p>
						</fieldset>
					</form>


#4 Tohma

Tohma

    12 Horas

  • Usuários
  • 202 posts
  • Sexo:Masculino
  • Localidade:Curitiba

Posted 10/04/2008, 10:56

vc tem q colocar o utf8_encode na pagina que processa os dados antes de serem enviados para classe ...
DBPlex dbplex.com.br

#5 strago

strago

    Novato no fórum

  • Usuários
  • 7 posts
  • Sexo:Não informado

Posted 10/04/2008, 12:36

Tohma obrigado pela dica mas ...
hehehe

Eu mudei pra utf8_decode e coloquei dentro da classe agenda quando estou recuperando os dados recebidos

$titulo = checkslashes(strip_tags(stripslashes(utf8_decode($frm['edtTitulo']))));

agora salvou corretamente no DB.

=]




1 user(s) are reading this topic

0 membro(s), 1 visitante(s) e 0 membros anônimo(s)

IPB Skin By Virteq