Google plus devuelve las solicitudes ajax con )]}'
en primera línea. Escuché que es protección contra XSS. ¿Hay algún ejemplo de qué y cómo podría alguien hacer con esto sin esa protección?"Protección Anti-XSS" al agregar)]} 'antes de la respuesta ajax
Respuesta
Aquí está mi mejor versión de lo que está pasando aquí.
En primer lugar, hay otros aspectos del formato de google json que no son completamente válidos json. Entonces, además de cualquier propósito de protección, pueden estar usando esta cadena específica para indicar que el resto del archivo está en formato google-json y debe interpretarse en consecuencia.
El uso de esta convención también significa que la alimentación de datos no se ejecutará a partir de una llamada de una etiqueta de secuencia de comandos ni interpretará la javascript directamente desde una evaluación(). Esto garantiza que los desarrolladores de front-end pasen el contenido a través de un analizador sintáctico, lo que evitará que se ejecute cualquier código implantado.
Para responder a su pregunta, existen dos ataques plausibles que esto evita, un sitio cruzado a través de una etiqueta de secuencia de comandos, pero el más interesante es dentro del sitio. Ambos ataques suponen que: existe
- un error en cómo se escapó de datos de usuario y
- se explota de una manera que permite a un atacante inyectar código en uno de alimenta los datos.
Como un simple ejemplo, digamos un usuario descubierto la manera de tomar una cadena como ejemplo
["example"]
y lo cambió a "]; alert ('ejemplo');
[""];alert('example');"]
Ahora, si cuando los datos se muestran en el feed de otro usuario, el atacante puede ejecutar código arbitrario en el navegador del usuario. Dado que está dentro del sitio, las cookies son ser enviado al servidor y el atacante podría automatizar cosas como compartir publicaciones o enviar mensajes a personas desde la cuenta del usuario.
En el escenario de Google, estos ataques no funcionarán por una serie de razones. Los primeros 5 caracteres provocarán un error de javascript antes de que se ejecute el código de ataque. Además, dado que los desarrolladores se ven obligados a analizar el código en lugar de ejecutarlo accidentalmente a través de una evaluación, esta práctica evitará que el código se ejecute de todos modos.
Como otros han dicho, es una protección contra Cruz de letra Inclusión (XSSI)
Nos explicó en Gruyere como:
En tercer lugar, usted debe asegurarse de que el guión no es ejecutable . La forma estándar de hacer esto es agregar un prefijo no ejecutable a , como])} while (1) ;. Un script que se ejecuta en el mismo dominio puede leer el contenido de la respuesta y quitar el prefijo, pero los scripts que se ejecutan en otros dominios no pueden.
- 1. Espacio antes de Respuesta Ajax (jQuery, PHP)
- 2. Cómo esperar la respuesta antes de elegir JQUERY AJAX condición
- 3. Enviar respuesta php al Ajax
- 4. Sanitize HTML antes de almacenar en la base de datos o antes de la representación? (Biblioteca AntiXSS en ASP.NET)
- 5. ¿Persona perdida en la respuesta de Ajax?
- 6. Microsoft AntiXSS Alternativa
- 7. Protección CSRF en solicitudes AJAX usando MVC2
- 8. Agregar demora antes de enviar nueva solicitud ajax usando jquery
- 9. Respuesta múltiple Solicitud AJAX
- 10. jQuery: Evaluar script en la respuesta ajax
- 11. Código de respuesta 401 activando la autenticación básica antes del controlador de error jquery ajax
- 12. Obtenga la longitud de jQquery Respuesta Ajax
- 13. jQuery/AJAX - formato de respuesta
- 14. TinyMCE, AntiXSS, MVC3 y GetSafeHtmlFragment
- 15. Esperando respuesta (s) de jQuery AJAX
- 16. jQuery Ajax: respuesta en pdf
- 17. Symfony 2 Desactivar la protección CSRF ficha en ajax presentar
- 18. Cómo leer el flujo de respuesta antes de que se complete la respuesta Http
- 19. Carriles 3 - AJAX, la respuesta JS - cómo controlar los errores
- 20. (Wicket) Cambiar la visibilidad durante la respuesta de ajax
- 21. AJAX Límite de tamaño de respuesta
- 22. $ .parseJSON en $ .ajax - problema en la respuesta de análisis
- 23. cosa extraña, la respuesta ajax incluye espacios en blanco
- 24. encabezado de respuesta jQuery y AJAX
- 25. Lectura de una parte de la respuesta de ajax html
- 26. Protección XSRF en una aplicación de estilo AJAX
- 27. Variables de contexto Django y respuesta ajax
- 28. Respuesta Ajax dentro de un div
- 29. Cómo devolver el texto de respuesta AJAX?
- 30. JQuery ajax congela ui cuando la respuesta es muy grande
Relacionado: [Extraña respuesta JSON en Google Plus] (http: // stackoverflow.com/questions/6618441/strange-json-response-in-google-plus) – dtb
Esa es exactamente la pregunta de la que estaba hablando "Escuché que es protección contra XSS" – genesis
¿Debería ser esta una nueva pregunta? Puede obtener más información en la otra pregunta ... –