使用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 | |
+----------------+------------------+------+-----+---------+----------------+
答案 0 :(得分:0)
您无法对其进行配置,因为username_post_key
用于POST字段名称,而不是表列名称。表列名称没有配置。
您必须自定义SimpleAuth,或创建自己的驱动程序。