0

私は新しいZend開発者であり、いくつかの概念の問題があります(特に教義に関して)。

MyAuthenticationProcessというクラスがあります。このクラスは、データベースでユーザーのIDを確認することにより、ユーザーを認証しようとしています。

インターネットで見たように、データベースと通信するには3つのことを実装する必要があります。

まず、module.config.phpにこれらの行を追加する必要があります

'doctrine' => array(
    'driver' => array(
            __NAMESPACE__. '_driver' => array(
                    'class' => 'Doctrine\ORM\Mapping\Driver\AnnotationDriver',
                    'cache' => 'array',
                    'paths' => array(__DIR__ . '/../src/' . __NAMESPACE__ . '/Entity')
            ),
            'orm_default' => array(
                'drivers' => array(
                    __NAMESPACE__.'\Entity' => __NAMESPACE__.'_driver'      
                )       
            )   
    )       
),  

次に、エンティティを含むファイルを作成する必要があります。このファイルをAuthentification/Entity/User.phpに作成しました

このファイルのコードは次のとおりです。

<?php
namespace Authentification\Entity;

use Doctrine\ORM\Mapping as ORM;
use Zend\InputFilter\InputFilter;
use Zend\InputFilter\Factory as InputFactory;
use Zend\InputFilter\InputFilterAwareInterface;
use Zend\InputFilter\InputFilterInterface;


   /**
 * A User table.
 *
 * @ORM\Entity
 * @ORM\Table(name="user")
 * @property string $login
 * @property string $password
 * @property int $id
 */

class User {

/**
 * @ORM\Id
 * @ORM\Column(type="integer");
 * @ORM\GeneratedValue(strategy="AUTO")
 */
protected $id;
/**
 * @ORM\Column(type="string")
 */
protected $login;

/**
 * @ORM\Column(type="string")
 */
protected $password;


/**
 * Magic getter to expose protected properties.
 *
 * @param string $property
 * @return mixed
 */
public function __get($property)
{
    return $this->$property;
}

/**
 * Magic setter to save protected properties.
 *
 * @param string $property
 * @param mixed $value
 */
public function __set($property, $value)
{
    $this->$property = $value;
}


}
?>

そして最後に、この構成を次のファイルに追加しました:config / autoload / local.php

    <?php

return array(


    'doctrine' => array(
        'connection' => array(
            'orm_default' => array(
                'driverClass' => 'Doctrine\DBAL\Driver\PDOMySql\Driver',
                'params' => array(
                    'host' => 'localhost',
                    'port' => '3306',
                    'user' => 'root',
                    'password' => '',
                    'dbname' => 'zf2tutorial',
                )
            )
        )
    ),
);

私が今抱えている問題は、データベースにアクセスすることです。設定の問題だと思います。

私のクラスMyAuthenticationProcessで、テーブル「User」のすべてのエントリを取得しようとしています。しかし、私はできません。

これが私がそうするために使用したコードです:

    $users = $this->getEntityManager()->getRepository('Authentification\Entity\User')->findAll()   ;
    var_dump($users) ;

そして、これが私が得るエラーです:

<br />
<b>Fatal error</b>:  Uncaught exception 'Zend\View\Exception\RuntimeException' with message 'Zend\View\Renderer\PhpRenderer::render: Unable to render template &quot;layout/layout&quot;; resolver could not resolve to a file' in xampp\htdocs\kjsencha\vendor\zendframework\zendframework\library\Zend\View\Renderer\PhpRenderer.php:457
Stack trace:
#0 xampp\htdocs\kjsencha\vendor\zendframework\zendframework\library\Zend\View\View.php(201): Zend\View\Renderer\PhpRenderer-&gt;render(Object(Zend\View\Model\ViewModel))
#1 xampp\htdocs\kjsencha\vendor\zendframework\zendframework\library\Zend\Mvc\View\Http\DefaultRenderingStrategy.php(126): Zend\View\View-&gt;render(Object(Zend\View\Model\ViewModel))
#2 [internal function]: Zend\Mvc\View\Http\DefaultRenderingStrategy-&gt;render(Object(Zend\Mvc\MvcEvent))
#3 xampp\htdocs\kjsencha\vendor\zendframework\zendframework\library\Zend\EventManager\EventManager.php(460): call_user_func(Array, Object(Zend\Mvc\MvcEvent)) in <b>\xampp\htdocs\kjsencha\vendor\zendframework\zendframework\library\Zend\View\Renderer\PhpRenderer.php</b> on line <b>457</b><br />

これが構成の問題であることを確認するために、これを使用して接続が確立されたかどうかを確認しようとしました。

    $users = $this->getEntityManager()->getConnection()   ;
    var_dump($users) ;

ユーザーがNULLに等しいのを見て驚いた。

問題がどこから来たのか分かりますか?

ご協力ありがとうございました。

4

1 に答える 1

1

私はついに私の問題がどこから来たのかを見つけました=D

それは私のデータベースのテーブル構造でした。エンティティファイルとは似ていなかったので、変更して動作します。

私の投稿が同じ問題を抱えている他の誰かを助けることを願っています。

于 2013-02-08T09:14:57.100 に答える