2009-07-20 16 views
8

Estoy usando PHP y el framework codeigniter para un proyecto en el que estoy trabajando, y necesito un sistema de autenticación/inicio de sesión de usuario.bibliotecas/marcos de autenticación de usuario php ... ¿cuáles son las opciones?

Por el momento prefiero no usar SSL (podría ser excesivo y el hecho de que estoy usando alojamiento compartido desalienta esto). Consideré usar openID pero decidí que dado que mi audiencia objetivo generalmente no es técnica, podría asustar a los usuarios (sin mencionar que requiere la duplicación de la información de inicio de sesión, etc.). Sé que podría escribir una autenticación basada en hash (como sha1) ya que no se pasan datos sensibles (compararía el nivel de sensibilidad con el de stackoverflow).

Dicho esto, antes de hacer una solución personalizada, sería bueno saber si hay algunas bibliotecas o paquetes buenos que haya utilizado para proporcionar una autenticación semiasegura. Soy nuevo en codeigniter, pero algo que se integre bien con él sería preferible. ¿Algunas ideas? (Estoy abierto a las críticas sobre mi enfoque y abierto a sugerencias sobre por qué podría estar loco no solo para usar ssl). Gracias por adelantado.

Actualización: He examinado algunas de las sugerencias. Tengo curiosidad por probar zend-auth ya que parece bien soportado y bien construido. ¿Alguien tiene experiencia con el uso de zend-auth en codeigniter (¿es demasiado voluminoso?) Y ¿tiene una buena referencia para integrarlo con CI? No necesito ningún esquema de autenticación complejo ... simplemente un sistema de autorización de inicio de sesión/cierre de sesión/gestión de contraseñas.

Además, dx_auth parece interesante también, sin embargo, me preocupa que sea demasiado problemático. ¿Alguien más ha tenido éxito con esto?

me di cuenta de que yo también me gustaría para gestionar usuarios invitados (es decir, los usuarios que no login/registro) de una manera similar a stackoverflow..so cualquier sugerencia que tengan esta funcionalidad sería grande

+0

verificación de la respuesta: http://stackoverflow.com/questions/1106604/framework-for-administrating-users/1116855#1116855 –

+0

también hay componente de autenticación de PERA – kguest

+0

Es posible que desee echar un vistazo a https: // github.com/delight-im/PHP-Auth, que es tanto agnóstico como agnóstico de la base de datos. – caw

Respuesta

2

He encontrado dx_auth para ser bastante bueno en Codeigniter, y lo he usado antes. Sin duda, es la biblioteca de autenticación con más funciones para Codeigniter.

Hubo algunas cosas que tuve que hacer para cambiarlo, por lo que amplié su clase de usuario con algunas funciones para mis propósitos (algunas de sus funciones no hacen exactamente lo que cabría esperar). Aquí es un segmento de algunas de las personalizaciones que hice:

 $CI = &get_instance(); 
    $CI->load->model("dx_auth/users"); 
    /** 
    * For most things, try and use the dx_auth models, 
    * because it's already done, and some stuff is more 
    * annoying to figure out than might be expected. 
    * 
    * For anything site-specific, use this model instead. 
    * 
    */ 

    class UserModel extends Users { 
     /** 
     * Sometimes when dx_auth sucks, you have to compensate 
     * functions that return useful results. 
     * 
     * @param int $id id of user to check if banned 
     * @return int $banned returns the result (0 or 1) 
     */ 
     public function is_banned($id) { 
      $query = "SELECT banned FROM users WHERE id=".(int)$id; 
      $result=$this->db->query($query); 
      $row = $result->row_array(); 
      return $row['banned']; 
     } 


    } 
+0

Lo he usado también para numerosos proyectos y he tenido éxito con él. Es sencillo y hace prácticamente todo lo que necesita. – ryeguy

4

que utilizo Zend_Auth . Pero trabajo con Zend Framework en general. Por lo que he escuchado, se integra bien con CI. Con Zend_Auth uso un adaptador Db_Table y SHA1 con una sal global. Eso es suficiente para muchos propósitos, creo.

+0

Un par de años de experiencia más tarde, y ahora sé que Codeigniter está muy anticuado. Uso ZF para todo ahora y necesito aprender Doctrine. –

2

Parece que this podría ser exactamente lo que está buscando, si desea obtener Zend-auth trabajando en CodeIgniter. Por favor, actualice su pregunta nuevamente si encuentra que zend-auth & codeigniter es una buena combinación ..

He encontrado personalmente que hackear dx_auth es un verdadero dolor, especialmente por su falta de documentación, y me encantaría dar una oportunidad a algo más si suena prometedor.

+0

gracias, puedo darle una oportunidad – oym

Cuestiones relacionadas