0

Zendのドキュメントとここにあるいくつかの投稿を読んだ後、ユーザーテーブルからユーザーロールを取得する方法を理解できませんでした。

現時点では、AuthControllerで次のようにZend_Authを使用しています。

// Set authentication adapter and map ID and Cre.
// only admins could log in here
$adapter = new Zend_Auth_Adapter_DbTable($this->db,
            'customers',
            'login',
            'password',
            'MD5(?)');
$adapter->setIdentity($form->getValue('username'))
    ->setCredential($form->getValue('password'));

// Check if authentification is right
$result = Zend_Auth::getInstance()->authenticate($adapter);

if (!$result->isValid()) {
    ..
}

その後、Zend_Controller_Pluginを介してチェックし、結果に応じてルーティングします。

if (Zend_Auth::getInstance()->hasIdentity()) {
        return;
} elseif ($request->getControllerName() == 'auth' || $request->getControllerName() == 'index') {
        return;
} else {
        $request->setControllerName('index');
        $request->setActionName('index');
        return;
}

ここで、ユーザーのロールに応じてルートを変更したいと思います。ユーザーが管理者の場合、AdminControllerにアクセスできますが、ユーザーテーブルからロールを取得するにはどうすればよいですか?この列はタイプと呼ばれ、役割を示す文字列が含まれています。

あなたが私を助けてくれることを願っています。

ご挨拶、

-lony

4

2 に答える 2

1

getResultRowObjectアダプタのメソッドを使用して、認証結果の行をZend_Authに保存します。http://framework.zend.com/manual/en/zend.auth.adapter.dbtable.html#zend.auth.adapter.dbtable.advanced.storing_result_rowを参照してください

于 2010-12-08T00:20:24.077 に答える
1

ありがとうフィル、それはうまくいきます!

私の解決策を完成させるためだけに。これをAuthControllerに追加しました:

// fetches role and login name out of
// user table and store it in auth session
$data = $adapter->getResultRowObject(array(
                    'role',
                    'username'
                ));
Zend_Auth::getInstance()->getStorage()->write($data);

そして今、私は次のように入力することで、どこからでも自分の役割(またはユーザー名)にアクセスできます。

$role = Zend_Auth::getInstance()->getIdentity()->role;
于 2010-12-08T05:49:23.197 に答える