Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] Tipico problema con Charset entre PHP en Linux con SQL Server 2000

Estas en el tema de Tipico problema con Charset entre PHP en Linux con SQL Server 2000 en el foro de PHP en Foros del Web. Buenas a todos, Sé que de este tema ya se ha escrito hasta la saciedad, y he mirado, y requetemirado por casi todos los sitios ...
  #1 (permalink)  
Antiguo 10/05/2013, 08:08
 
Fecha de Ingreso: marzo-2011
Ubicación: Barcelona
Mensajes: 9
Antigüedad: 13 años, 1 mes
Puntos: 1
Tipico problema con Charset entre PHP en Linux con SQL Server 2000

Buenas a todos,

Sé que de este tema ya se ha escrito hasta la saciedad, y he mirado, y requetemirado por casi todos los sitios por los que se puede buscar. El problema? Pues con los carácteres especiales (acentos, la ñ, etc. etc.). A ver si alguien puede echarme un cable porque ya he probado de todo sin éxito:

- Servidor Web: PHP Version 5.3.6-13ubuntu3.9
- Base de Datos: Microsoft SQL Server 2000 - Language Spanish

Os indico el método que utilizo para realizar la conexión:

Código:
	// Método Verificar y Conectar (consultas Simples)
	function conectar(){
		ini_set('mssql.charset', 'iso-8859-1');
		// Realizamos la conexión con Servidor SQLServer
		if(!($con = mssql_connect($this->servidor, $this->usuario, $this->clave) )){
			echo "ERROR AL CONECTAR CON EL SERVIDOR DE BASE DE DATOS";
			exit();
		}
		
		// Seleccionamos Base De Datos
		if (!mssql_select_db($this->basedatos, $con)){
			echo "ERROR AL CONECTAR CON LA BASE DE DATOS";
			exit();
		}
		$this->connect=$con;
		return true;
	}
Como podeis ver, le marco el Charset como ISO-8859-1, y en todas mis páginas PHP añado su correspondiente cabecera con el Charset anterior.

Pues no consigo que me devuelva los datos correctamente, es decir, los acentos los muestra erroneos. He utilizado las funciones de utf8_decode, utf8_decode, mb_convert_encoding, sin suerte.

¿Alquien sabe con claridad como se deben configurar el PHP para conseguir que me funcione bien?

Muchas Gracias de antemano por vuestra ayuda.

Saludos.
  #2 (permalink)  
Antiguo 10/05/2013, 09:02
 
Fecha de Ingreso: abril-2011
Mensajes: 31
Antigüedad: 13 años
Puntos: 2
Respuesta: Tipico problema con Charset entre PHP en Linux con SQL Server 2000

tu lo que estas hablando es que al guardar en la base de datos no se guardan muy bien los caracteres como Ñ, ó.......prueba con el estandar 'utf8''.

cualquier cosa comenta"
  #3 (permalink)  
Antiguo 10/05/2013, 09:08
 
Fecha de Ingreso: abril-2011
Mensajes: 31
Antigüedad: 13 años
Puntos: 2
Respuesta: Tipico problema con Charset entre PHP en Linux con SQL Server 2000

que Framework estas usando???
  #4 (permalink)  
Antiguo 10/05/2013, 09:16
 
Fecha de Ingreso: marzo-2011
Ubicación: Barcelona
Mensajes: 9
Antigüedad: 13 años, 1 mes
Puntos: 1
Respuesta: Tipico problema con Charset entre PHP en Linux con SQL Server 2000

Buenas,

Ya ha quedado solucionado. Hay que configurar el FreeTDS para una correcta conexión con el SQL Server de este modo:

- Fichero de configuración /etc/freetds/freetds.conf.
Código:
	#SQL Server Connection
	[<alias_server_name>]
		host = <host>
		port = 1433
		tds version = 7.0
		client charset = UTF-8
Muchas Gracias y espero que ayude al resto de personas.

Etiquetas: 2000, charset, linux, select, server, sql
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 23:04.