Cómo puedo cifrar y descifrar tarde un valor de una cookie en PHP (qué tan seguro será el cifrado)galletas Cifrado en PHP
Respuesta
No puedo simplemente pensar en una situación donde el cifrado de datos en la cookie es útil. Si desea conservar datos secretos sobre el usuario o sus preferencias, información, lo que sea, guárdelo en el servidor en archivos, en la sesión o en la base de datos, pero no en la computadora del cliente.
Por otro lado, si crea una autenticación, entonces debe usar sesiones en lugar de crear valores secretos de cookies cifradas. Las sesiones no se implementaron por nada, son el camino a seguir.
¿No es una gran parte de una apatía de API RESTful? En ese caso, almacenar datos confidenciales a través de cookies cifradas con clave secreta es bastante fundamental.¿O me estoy perdiendo algo? – PandemoniumSyndicate
Si su API es realmente sin estado, no hay sesión. Debe ser el cliente responsable de la información de la tienda desde la solicitud. – TlmaK0
"No puedo simplemente pensar en una situación donde el cifrado de datos en la cookie es útil". El OP no preguntó si podía o no; presumiblemente, el OP sabe "por qué" y preguntó "cómo". No respondiste esa pregunta. –
una variedad de maneras diferentes para cifrar la información en las cookies y otros lugares. La fuerza del cifrado variará según el método que elija para hacer el cifrado real. mycrypt
es un buen lugar para comenzar. See this answer para ver un ejemplo del uso de mcrypt.
No recomiendo poner nada sensible en una cookie, incluso si va a ser encriptada. Demasiado tentador para que alguien se agriete. Intenta seguir las sesiones si puedes.
"Demasiado tentador para que alguien se rompa" Pero ... presumiblemente ... si usas criptografía fuerte, sin la clave, no pueden descifrarla. Y si tienen la clave, eso significa que ya han descifrado su servidor (en cierta medida dañina), por lo que tiene problemas más grandes de los que preocuparse. El tiempo de caducidad de la cookie, por ejemplo, podría considerarse confidencial para la tienda. en el cliente, pero la ventaja de almacenarla cifrada en el lado del cliente es clara: puede verificar inmediatamente si una sesión sigue siendo válida y, a menos que hayan descifrado su casilla, no pueden configurarla de todos modos. –
Estoy totalmente de acuerdo con las otras respuestas: si los datos son realmente delicados, se deben almacenar en el servidor en una sesión, no en una cookie.
En cuanto a las formas de encriptar los contenidos de la cookie, la extensión de PHP Suhosin proporciona la capacidad de transparently encrypt all cookies. Si tiene la capacidad de instalar extensiones de PHp, esto puede o no ser más fácil para usted que escribir su propio esquema de cifrado.
Si la cookie está cifrada de forma segura (por ejemplo, con un secreto almacenado en el servidor que cambia periódicamente), no veo ningún problema para almacenar datos útiles en la cookie. ¿Por qué almacenarlo en el servidor? Haga que el cliente trabaje para un cambio, especialmente si se trata de preferencias. ¿Por qué el servidor debe almacenar y recuperar constantemente datos de un archivo de sesión? ¿Qué sucede si tiene cientos de miles de usuarios golpeando su sitio? Ahora debe mantener cientos de miles de archivos de sesión.
La pregunta del OP fue "¿Cómo puedo cifrar las cookies en PHP, y qué tan seguro sería?", Y su respuesta fue "Pude ver que ser una persona útil quiero hacer". Ninguna parte de la pregunta del OP fue respondida, aquí. –
Puedo pensar en un uso razonable para esto. Supongamos que tiene una granja de servidores grande, va a tener un cuello de botella en la base de datos y/o servidor de memoria para gestionar las solicitudes de sesión ... "¿este usuario está conectado?"
Si almacenara los datos de sesión de los usuarios como un valor encriptado en la cookie, puede evitar tener que hacer bastantes lecturas/escrituras y permitir un almacenamiento de cookies de tamaño ilimitado ya que hay 0 impacto en su lado que no sea la CPU vinculada para el cifrado/descifrado de los datos de la cookie.
Ruby on Rails lo hace de forma predeterminada, aunque solo firma los datos y no los encripta. Existe una implementación alternativa que encripta los datos con su propia clave y firma para que el usuario no pueda ver qué datos almacena en su sesión.
La pregunta del OP era "¿Cómo puedo cifrar las cookies en PHP, y qué tan seguro sería?", Y su respuesta fue "Pude ver que ser una cosa útil una persona querría hacer". Ninguna parte de la pregunta del OP fue respondida, aquí. –
- 1. galletas Unset php
- 2. jQuery y PHP Galletas
- 3. cifrado con php
- 4. Galletas asegurar y Sesiones
- 5. Cifrado PHP y descifrado VB.net
- 6. C# Cifrado para descifrado PHP
- 7. galletas valor para varios subdominios
- 8. Cifrado RSA: Java a PHP
- 9. PHP CURL parece ignorar tarro de galletas/archivo
- 10. ¿Cómo puedo descifrar un valor cifrado MCRYPT_RIJNDAEL_256 en C#, cifrado por mcrypt en PHP?
- 11. cifrado php más corto que md5?
- 12. Cifrado de fuente PHP - Eficacia y desventajas
- 13. Crear un archivo comprimido cifrado con PHP
- 14. Diferencia entre cifrado .NET y PHP
- 15. métodos apropiados de cifrado mcrypt de PHP?
- 16. PHP Secure Login - cifrado de la contraseña
- 17. fácil Cifrado y descifrado con PHP
- 18. C# WebRequest usar WebBrowser, galletas
- 19. "$" dólar carácter prefijo galletas nombres
- 20. cifrado en nodejs
- 21. cifrado TripleDES no ceder mismos resultados en PHP y C#
- 22. Reescribir Rijndael 256 C# Código de cifrado en PHP
- 23. ¿Cifrado y cifrado son diferentes?
- 24. Galletas - establecer a través de múltiples dominios
- 25. IE no elimina realmente las galletas
- 26. Capybara & Cucumber | Obtención de las galletas
- 27. HtmlUnit y galletas manipulación ("ADVERTENCIA: Galleta rechazada")
- 28. Galletas de trabajo en Flex, pero no en Aire
- 29. Contraseñas de cifrado
- 30. Cifrado multipartita en .NET?
No veo cómo esto es útil, debe usar $ _SESSION [] para obtener información confidencial. – rook