FuelPHP SimpleAuth自定义列名?

时间:2015-03-14 00:22:45

标签: fuelphp

使用SimpleAuth包,我正在处理登录功能。 默认情况下,用户表应该有一个“用户名”列。 但是我的系统有一个用户表,其中包含“login_id”而不是“username”。

Fuel\Core\Database_Exception [ 1054 ]:
Unknown column 'username' in 'where clause' 
[ SELECT * FROM `m_user` WHERE (`username` = 'admin' OR `email` = 'admin') 
AND `password` = 'mIIMXQgANGZ21XHRTpI2Krpla9yx3UwEw0PCNfjAN4I=' ]

我无法弄清楚它如何处理自定义字段名称。 我尝试使用“'username_post_key'=>'login_id'”在APPPATH / config / simpleauth.php上进行配置,但这不起作用..

提前致谢。

### APPPATH/config/auth.php ###
return array(
    'driver' => 'SimpleAuth',
    'verify_multiple_logins' => false,
    'salt' => 'techtech',
    'iterations' => 10000,
);

### APPPATH/config/simpleauth.php ###
<?php
    return array(

    'db_connection' => null,

    'table_name' => 'm_user',

    'table_columns' => array('*'),

    'guest_login' => true,

    'multiple_logins' => false,

    'remember_me' => array(

      'enabled' => false,

      'cookie_name' => 'rmcookie',

      'expiration' => 86400 * 31,
    ),

    'groups' => array(
    ),

    'roles' => array(
    ),

    'login_hash_salt' => 'tech_login',

    'username_post_key' => 'login_id',

    'password_post_key' => 'password',
    );


### user table ###
+----------------+------------------+------+-----+---------+----------------+
| Field          | Type             | Null | Key | Default | Extra          |
+----------------+------------------+------+-----+---------+----------------+
| id             | int(11) unsigned | NO   | PRI | NULL    | auto_increment |
| login_id       | varchar(100)     | NO   |     | NULL    |                |
| first_name     | varchar(20)      | NO   |     | NULL    |                |
| last_name      | varchar(20)      | NO   |     | NULL    |                |
| password       | varchar(255)     | NO   |     | NULL    |                |
| last_login_at  | timestamp        | YES  |     | NULL    |                |
| created_at     | timestamp        | YES  |     | NULL    |                |
| updated_at     | timestamp        | YES  |     | NULL    |                |
| deleted_at     | timestamp        | YES  |     | NULL    |                |
+----------------+------------------+------+-----+---------+----------------+

1 个答案:

答案 0 :(得分:0)

您无法对其进行配置,因为username_post_key用于POST字段名称,而不是表列名称。表列名称没有配置。

您必须自定义SimpleAuth,或创建自己的驱动程序。