FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
Menú dinámico con JavaScript y PHP
Hola comunidad,
Les comento que tengo implementado un menú dinámico hecho mediante javascript y php y que en mi PC funciona correctamente tanto en Firefox y IE6, debo decir además que en mi PC yo configure el PHP, MySQL y Apache 2.0. Por otra parte he instalado en mi notebook el AppServ y fue en realidad por flojera (es mas rápido...) y carge mis páginas, pero al momento de cargar el menú dinámico este no aparece simplemente. Les dejo el código que cree para implementar este menu tipo "arbolito" Código PHP:
invalid falg after regular expression (Linea 22) TREE_NODES is not defined (Linea 39) Mi pregunta es: ¿Existe alguna configuración especial en el archivo ini para las expresiones regulares?, ¿Es posible? Esperando la respuesta de todos los maestros.........realmente la necesito, me tiene desconcertado este error. Gracias Hasta Luego .-
__________________
No todo es como parece ser... |
#2
|
||||
|
||||
Hola,
A ver si podemos ayudar en algo. Digo yo que, ¿el error que te aparece lo imprime PHP, o, según entiendo, es el navegador (acaso la extensión FireBug) la que te muestra el mensaje de error? Porque la variable "TREE_NODES" es una variable de JavaScript, ¿no? Por otro lado, en el código no veo que hagas uso de ninguna expresión regular... y, si seguimos los mensajes de error y miramos en la línea 22 y 39 del código que muestras, pareciera que ahí no hay ningún error, o que las líneas no coinciden, vaya... La cosa es que te funciona en un sitio y en otro no... ¿se trata de la misma versión de PHP? ¿Qué extensión tiene el Script problemático? A ver si va a ser un archivo ".js" y, en el sistema en que obtienes el error, este tipo de archivos no es procesado como PHP, como por otro lado es lo normal... No sé... a ver si damos con la tecla entre todos. |
#3
|
||||
|
||||
Primero que nada gracias por responder compañero Dec.
Cita:
Cita:
Cita:
ese archivo php lo gatillo de la siguiente forma. Código PHP:
../../jscripts/structure_tree.php y que es el archivo encargado de generar el arbolito dinámico mediante Javascript y PHP en un archivo con extensión PHP. Dec, espero haber aclarado tus dudas y que tengas mas información para ver el problema que tengo, gracias nuevamente. Hasta Luego .-
__________________
No todo es como parece ser... |
#4
|
||||
|
||||
Hola,
Bueno. La expresión regular debe ponerla por su parte el Script que usas para crear el "treeview". Se me ocurren varias cosas, pero, te preguntaría si las pruebas las haces con la misma base de datos, con los mismos datos. Haces una cosa que acaso sea problemática y que tiene que ver con esto último. "Imprimes" los datos que traes de la base de datos "tal cual", cuando, a lo mejor es preciso "escaparlos", para evitar problemas. Más aún si estos datos van a ir dentro de "comillas", por ejemplo. Personalmente uso esta función cuando tengo que imprimir un dato procedente de la base de datos en HTML, para evitar problemas: Código PHP:
|
#5
|
||||
|
||||
Cita:
¿Podrías darme un ejemplo? Gracias. Hasta Luego .-
__________________
No todo es como parece ser... |
#6
|
||||
|
||||
Hola,
Hombre, a cada "echo"... pero sí tienes que hacerlo "a discrección". El segundo parámetro es para indicárselo a la función en que es preciso y tiene que ver con el "charset" que estés utilizando, tanto en la página Web como en la base de datos. Yo tengo por defecto "utf-8", puesto que el "charset" que procuro usar. Respecto del ejemplo. Ahí va uno más bien sencillo, porque, te advierto que yo en esto tampoco me llego a aclarar del todo, si bien es cierto que, efectivamente, intuyo que por ahí pueden ir los tiros en este caso... lo mismo hasta en esto estoy equivocado. Código PHP:
Ahora, si "descomentas" la instrucción en que se hace pasar el "valor" por la función "Str2Htm()" verás que el "alert" de JavaScript funciona como se espera, porque, no se corta la cadena que se supone ha de mostrar. Sin embargo, no nos vamos a engañar, yo esperaba que algo así también funcionase: Código PHP:
No sé. Prueba por ese camino. Sobre esto del escapar cadenas hay que llevar cierto cuidado. Por ejemplo, si la cadena va a mostrarse dentro de un "input" o "textarea" yo, por lo pronto, no las escapo. Si ha de mostrarse en otro lugar sí que lo hago. Y, a la contra pasa lo mismo, me refiero a que cuando guardas valores en la base de datos estos han de ser previamente escapados, pero, no con la función que antes copié aquí. Yo, para estos menesteres, uso esta otra función, que me recomendó un conocido hace bastante tiempo: Código PHP:
Puede parecer "pesado" tener que hacer algo así cuando insertas registros, por un lado, y cuando los muestras, por otro, pero, no queda otra. A no ser que controles absolutamente a los usuarios de la aplicación y estos no vayan a pretender nunca "meter la pata", pero, aún así... Por ejemplo, si vas a imprimir un determinado valor dentro de HTML, como poco, es menester escapar las posibles etiquetas HTML que dicho valor contenga, como, por ejemplo, < script >... que puede estar ahí con mala idea... No sé si te estoy ayudando en algo o no Lúcas, pero, en fin, como he dicho más arriba, a ver si entre todos sacamos algo en claro. |
#7
|
||||
|
||||
Hola Dec,
Pues mi desconcierto es aún mayor cuando empecé hacer pruebas a "locas", pues me encuentro que al sacar el session_start() y reemplazar la variable de session por un valor fijo funciona de maravilla el script, y ojo !!!! que no estoy soñando, vuelvo agregar el session start y deja de funcionar........ Creo que las cosas de ahora en adelante cambian o no dec ?, pero eso de escapear las variables es una muy buena práctica de programación, pero los tiros no van por ahí por lo mencionado mas arriba. Hasta Luego .-
__________________
No todo es como parece ser... |
#8
|
||||
|
||||
Arreglado
Hola Dec
Asunto arreglado el session_start debe estar antes de una salida al navegador, lo puse al comienzo y asunto arreglado, ahora mi pregunta es ¿por qué diablos funciona en la otra máquina.? Hasta Luego .-
__________________
No todo es como parece ser... |
#9
|
||||
|
||||
Hola,
Bueno. Pues las cosas cambian, pero, permíteme insistir en lo dicho de escapar cadenas (de entrada en la base de datos y de salida para imprimir), puesto que, como ves, usas el valor de la variable de la sesión dentro de la consulta SQL sin escaparlo antes: y eso puede traer problemas de seguridad... alguien podría "inyectar" SQL ahí. Pero, dejando este tema aparte y volviendo al asunto primero de este hilo... pues... ¿qué hay exactamente en la variable de la sesión? Yo probaría a dejar el "session_start()", pero, a poner un valor fijo en la variable de marras. No creo que "session_start()" de problemas (vamos, no veo porqué), pero, el valor... quién sabe qué valor es... Yo echaría un vistazo al valor de esa variable, por un lado, y luego a lo que me retorna la consulta SQL, imprimiría lo que me retorna y vería qué puede haber raro ahí. Por otro lado, no has comentado al respecto, pero, ¿se supone que "juegas" con los mismos datos? En donde funciona y en donde no, me refiero, porque el problema podría estar en los datos... unos son problemáticos y los otros no. Y más aún... creo que los tiros siguen siendo por donde he mencionado, porque me ciño al mensaje de error: se encuentra algún carácter no esperado en la expresión regular que usa el Script que utilizas para componer el menú. Ahora bien, ¿de dónde sale ese carácter problemático? No puede ser de otro modo: vienen de la base de datos... Así que, resumiendo, vería qué contiene la variable de sesión. Y luego probaría, como has hecho, los resultados que obtengo con un valor fijo, pero, dicho valor ha de ser el que se supone que debería tener la variable de sesión, con el fin de que los datos que vienen de la base de datos sean los mismos: porque de no ser así, unos pueden contener caracteres "problemáticos", pero, otros no. Vamos... digo yo. |
#10
|
||||
|
||||
Cita:
Cita:
Cita:
Cita:
Seún la web de php dice esto. [quote=sitiophp] Nota: Si está usando sesiones basadas en las cookies, debe llamar a session_start() antes de que haya ninguna salida al navegador. [/sitiophp] Y ahora que recuerdo existe una directiva en php.ini que en estos momentos no recuerdo su nombre que permite sacar salidas al navegador antes de enviar un session_start(). no sé, no sé, yo apuesto a lo que dice la web de php y que el session_start debe ir antes que haya una salida al navegador, ya que la variable que trae la variable de session siempre es 1 o 2, y los registros de la base de datos son los mismos. Gracias por todo.... Espero tu comentario. Nos vemos.
__________________
No todo es como parece ser... Última edición por lucasarts_18 fecha: 24-11-2007 a las 19:57:24. |
#11
|
||||
|
||||
Hola,
Bueno, es que de hecho, ahora que lo mencionas, efectivamente, no se puede (?) iniciar una sesión de usuario si ya se enviaron algunas cabeceras HTTP... y cuando enviamos contenido ya hemos hecho eso. Pues oye, por ahí pueden ir los tiros, sí. Diste en el clavo. Ahora faltaría saber cómo es que un lugar funciona y en otro no, pero, yo creo que el asunto apunta a lo que dices: puede que cierta configuración de PHP (tal vez incluso de Apache) haga que el que no se pueda enviar nada antes de iniciar sesión no sea tan así... De todas formas, es extraño. Porque, si me dijeras, bueno, es que no puedes enviar contenido antes de iniciar sesión, y, si lo haces, los resultados son inesperados... pues vale. Pero, si me dices que la variable de sesión que utilizas trae el valor "correcto" en todo caso... pues chico, no sabe uno qué pensar. En todo caso, efectivamente, no cuesta nada poner ese "session_start()" antes de enviar salida alguna, de modo que comprobemos si así funciona... en ambos sitios. PD. No había visto el mensaje: Cita:
Última edición por dec fecha: 24-11-2007 a las 20:02:37. |
#12
|
||||
|
||||
Hola Dec,
Encontre en la otra máquina porque sí funcionaba el asunto, efectivamente era una directiva del php.ini (no tengo tan mala memoria decía un sabio, jeje ) y la directiva que permite modificar ese comportamiento en php es la siguiente. output_buffering = On Así estaba en la máquina que siempre había funcionado output_buffering = Off Así estaba en la máquina que no funcionaba. Pero vemos que dice esta directiva en el propio comentario del php.ini Código:
; Output buffering allows you to send header lines (including cookies) even ; after you send body content, at the price of slowing PHP's output layer a ; bit. You can enable output buffering during runtime by calling the output ; buffering functions. You can also enable output buffering for all files by ; setting this directive to On. If you wish to limit the size of the buffer ; to a certain size - you can use a maximum number of bytes instead of 'On', as ; a value for this directive (e.g., output_buffering=4096). Hasta Luego .-
__________________
No todo es como parece ser... |
#13
|
||||
|
||||
Hola,
Pues a mí no me queda tan claro... o sea, que sí, que uno puede usar esa directiva en caso de tener la necesidad (podrá darse el caso, digo yo) de enviar cabeceras HTTP incluso luego de haber enviado cierto contenido, pero, ¿y qué más? Porque no veo que diga (pero mi inglés es muy malo) algo así como "y si usted no usa esta directiva y envía contenido y después trata de enviar cabeceras HTTP, entonces los resultados de su script serán pueden ser impredecibles"... ¿O qué? Pero, no te quiero comer el coco Lúcas... me alegro de que dieras con la tecla, incluso si a mí no me queda claro por qué ocurría el error... qué era lo que lo provocaba, al cabo. ¿O es que me estoy perdiendo algo? Mira que no me extrañaría. |
#14
|
||||
|
||||
Dec, yo lo veo así, en la máquina que tiene activado esta directiva permite enviar contenido antes de hacer uso de funciones como session_start, de ahí que el menú siempre funcionaba, hay que mirar que el código del menú al comienzo el solo javascript, por lo tanto se enviaba este código antes del session_start y funcionaba de maravilla porque estaba activada esta directiva en el php.ini.
En la otra máquina pues no estaba activada esa directiva por lo tanto fallaba, de ahí que cambiara el session_start al comienzo del script y funcionó. y sí efectivamente esa directiva al tenerla activada permite enviar salidas al navegar antes que el envío de cabeceras HTTP. Hasta Luego .-
__________________
No todo es como parece ser... |
#15
|
||||
|
||||
Hola,
¿Quieres decir que de ahí que JavaScript no encontrara la variable "TREE_NODES", porque esta, en realidad, no era enviada? Ajá... pues entonces, claro, ahí puede estar la madre del cordero, como suele decirse. |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Combo o menu desplegable dinamico | Andrea Martinez | PHP | 5 | 25-02-2007 00:38:28 |
menú dinámico con eventos dinámicos | mguixot | OOP | 4 | 04-07-2006 16:05:05 |
¿Como crear menu dinamico. | JXJ | Varios | 3 | 10-09-2005 04:50:09 |
Main Menu Dinamico | cahosoft | Varios | 2 | 30-06-2005 09:45:56 |
Menu dinamico | xxxFALKORxxx | OOP | 1 | 23-03-2005 18:06:51 |
|