elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.

 

 


Tema destacado:


  Mostrar Mensajes
Páginas: 1 2 3 [4] 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 ... 51
31  Programación / PHP / Re: regex para protegerse de varios ataques en: 19 Abril 2016, 16:44 pm
Respecto a los enlaces que me pasas, comentan que htmlspecialchars no es suficiente si se imprimen cosas que vengan del usuario en atributos de algún elemento HTML, por el tema de poder usar los eventos onclick, etc. Por eso en mi anterior post puse como restricción no imprimir nada en atributos, porque además de crear un código sucio (a mi gusto), puede plantear problemas de seguridad.

En cuanto a otro tipo de ataques, si tienes cubierto el lado del cliente por el tema de los XSS, y tienes cubierto el lado de la BBDD usando sentencias preparadas para evitar SQL injections entonces no deberías tener más problemas. Bueno, podrías capar el número de intentos de login para imposibilitar ataques por fuerza bruta, validar siempre el tipo de archivos subidos a tu servidor y nunca darles permisos de ejecución, usar algún hash que identifique el navegador del usuario y/o su IP para intentar hacer que sea más difícil el robo de sesiones (aunque no imposible), restringir el acceso a ciertos directorios mediante los archivos .htaccess... Y ahora mismo no se me ocurre ninguna medida más.

Respecto a lo de la codificación UTF-16, ni idea, yo lo he usado en algún proyecto para validar los inputs de los formularios con regex unicodes pero nunca me he planteado si eso presentaba algún problema de seguridad. A ver si alguien con más conocimiento nos saca de la duda.

Saludos!
32  Programación / Programación C/C++ / Re: copiar ciertos valores de una variable en otra variable en lenguaje C. en: 19 Abril 2016, 16:34 pm
Compañero @xiruko : te consulto por el uso de sscanf() con "%d"

Tu sabras si es mas eficiente que usar atoi() ?

Hola,

Es más eficiente atoi debido a que se ahorra parsear la cadena buscando los especificadores como hace sscanf. Usé sscanf para aportar otras funciones distintas a las que ya habían en el tema.

Aquí puedes encontrar una comparación muy buena entre ambas funciones:

http://stackoverflow.com/questions/3420629/convert-string-to-integer-sscanf-or-atoi

Saludos!
33  Programación / PHP / Re: regex para protegerse de varios ataques en: 19 Abril 2016, 05:26 am
Citar
He leido que si está malformado se ejecuta el código, por eso no me he querido arriesgar. Tambien he leido que hacer una lista blanca con los carácteres permitidos es más seguro. Prefiero ir a lo seguro.

Podrías poner algún ejemplo de un código malformado?

Ahora mismo no se me ocurre ningún ataque XSS posible si:

1. Usas la función que he puesto para imprimir todo lo que venga del usuario.
2. No imprimes nada que venga del usuario dentro de un bloque <script>.
3. No imprimes nada que venga del usuario en atributos en un elemento de HTML. Esto no me preocupa ya que nunca mezclo JS y HTML, me parece una práctica bastante sucia y prefiero tener el código bien ordenado.

Respecto a lo de la expresión regular, no soy moderador pero creo que sería mejor que abrieras otro tema con ello.

Saludos!
34  Programación / Programación C/C++ / Re: copiar ciertos valores de una variable en otra variable en lenguaje C. en: 19 Abril 2016, 05:17 am
Hola,

Como en programación hay mil maneras de hacer una misma cosa, te dejo otra opción para juntar un array de enteros en uno solo. Ten cuidado con el valor máximo que puede tomar un entero, ya que con esta función es muy fácil pasarlo si se utiliza mal, y ahora mismo no hace ningún tipo de verificación.

Código
  1. #include <stdio.h>
  2. #include <string.h>
  3.  
  4. int join(int *arr, size_t arr_size)
  5. {
  6. int result, i;
  7. char aux[256];
  8. for (i=0; i<arr_size; i++) {
  9. sprintf(aux + strlen(aux), "%d", arr[i]);
  10. }
  11. sscanf(aux, "%d", &result);
  12. return result;
  13. }
  14.  
  15. int main(void)
  16. {
  17. int arr[4] = {1, 2, 3, 4};
  18. int result = join(arr, 4);
  19. printf("%d\n", result);
  20. return 0;
  21. }

Saludos!
35  Programación / PHP / Re: regex para protegerse de varios ataques en: 19 Abril 2016, 03:57 am
Hola,

Para evitar ataques XSS yo utilizo la función htmlspecialchars. Básicamente sustituye los carácteres peligrosos como >, <, ' y " por sus códigos HTML.

Se puede crear una función para hacer un echo seguro muy fácilmente:

Código
  1. function safe_echo($msg, $return=false)
  2. {
  3.    $msg = htmlspecialchars($msg, ENT_QUOTES, 'UTF-8');
  4.    if ($return) return $msg;
  5.    echo $msg;
  6. }

Saludos!
36  Informática / Electrónica / Re: que signfica este simbolo en: 17 Abril 2016, 04:16 am
Hola,

Como dato a añadir, los pads que son cuadrados en las PCB suelen indicar el voltaje positivo. Digo suelen porque no sé si hay un estándar que así lo marque, o por si es una convención no escrita que la gente normalmente sigue. Pero bueno, por norma general suele ser así.

Saludos!
37  Programación / Desarrollo Web / Re: Disenar para Firefox, Chrome e Internet Explore en: 16 Abril 2016, 00:49 am
Hola,

Cada navegador usa su propio motor de renderizado y cada uno tiene sus peculiaridades. Sí, es una faena, y sería todo mucho más sencillo si se renderizara el código HTML y CSS de una manera estandarizada, pero supongo que todo no se puede tener...

Si quieres que en todos se vea casi, casi, igual, deberías como mínimo hacer un reset en CSS antes de cargar tus estilos. Esto puedes buscarlo en Google ya que ya hay varios archivos CSS por ahí que hacen esto por ti.

Otra opción es usar algún framework de frontend, como por ejemplo Bootstrap, el cual se ve casi igual en todos los navegadores. Es bastante sencillo de aprender, y después de pelearte con él varias horas ya podrás hacer una web bastante decente.

Saludos!
38  Programación / Desarrollo Web / Re: Estoy desarrollando un sitio web que trata de rellenar un test... en: 14 Abril 2016, 04:37 am
Hola,

Más que hacer una petición AJAX por cada pregunta, yo escondería y mostraría las distintas preguntas con JQuery, así le quitarías carga al servidor y además el cambio de preguntas sería instantáneo de cara al usuario.

Puedes hacer que en el archivo PHP se escriban todas las preguntas de tu test, luego con CSS dales un display: none, y ya luego con JQuery muestras la primera, y cada vez que contesten a una, escondes la actual y muestras la siguiente. Esto puede hacerse fácilmente con los métodos hide y show, o si quieres darle efectos con los métodos fadeIn, fadeOut, slideUp o slideDown.

Saludos!
39  Programación / Desarrollo Web / Re: Teoria basica de XML en Jcarousel en: 13 Abril 2016, 01:26 am
Usar javascript y/o PHP no implica tener que usar o no usar XML. XML solo es un formato que le das a una información, no es un lenguaje de programación.

Si dices que tienes artículos guardados en formato XML, y que esos artículos no los quieres para nada, y que en su lugar quieres usar los posts de Wordpress entonces que le den a los archivos XML que tienes.

Ahora bien, Wordpress cómo guarda los posts? En una base de datos MySQL? O los guarda en formato XML en el servidor? Dudo que lo haga guardándolos en archivos XML pero ni idea de cómo funciona Wordpress.

Respecto a si habría algún problema, bueno, ahora mismo tu javascript recoge por AJAX los datos de los archivos XML. Si cambias eso para que haga la petición a un PHP donde cojas la información de los posts de la base de datos no debería haber ningún problema. Para evitarte tener que cambiarlo todo, podrías hacer que este PHP devolviera la información en formato XML, así lo demás que tienes de javascript te serviría tal cual.

Saludos!
40  Programación / Desarrollo Web / Re: Teoria basica de XML en Jcarousel en: 13 Abril 2016, 00:42 am
Hola,

Comparar PHP con XML es como comparar tomates con aviones. XML simplemente es un lenguaje de etiquetas personalizado para la aplicación. Se usa para almacenar valores de configuración, datos que serán mostrados más adelante como es tu caso, o para enviar datos por internet.

Por ejemplo, imagina que tu aplicación envía ante una petición los datos de 2 coches que han satisfecho una búsqueda. Desde PHP construyes la cadena XML que sería algo como esto:

Código
  1. <busqueda>
  2.   <coche>
  3.      <marca>Seat</marca>
  4.      <color>Negro</color>
  5.   </coche>
  6.   <coche>
  7.      <marca>Renault</marca>
  8.      <color>Rojo</color>
  9.   </coche>
  10. </busqueda>

Y luego con javascript, recogerías esos datos mediante una petición AJAX y harías algo con ellos.

Esto es solo un ejemplo. Otro podría ser guardar valores de configuración de tu programa. PHP ya tiene funciones predefinidas para tratar con archivos XML, así que imagínate que guardaras toda la configuración de tu aplicación web en un archivo XML. Podría ser algo como esto:

Código
  1. <configuracion>
  2.   <rootpath>/path/to/root/</rootpath>
  3.   <db_user>UsuarioBBDD</db_user>
  4.   <db_password>12345678</db_password>
  5.   etc.
  6. </configuracion>

Saludos!
Páginas: 1 2 3 [4] 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 ... 51
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines