php - Symfony 2.6 FR3DLdapBundle。由于系统原因,无法处理身份验证请求

标签 php symfony ldap fosuserbundle fr3dldapbundle

大家好,如果这个问题很愚蠢,我很抱歉。我是 Symfony (2.6) 的新手,我的第一个项目要求用户从 AD 进行身份验证。

无论我做什么,我都会收到:由于系统问题,无法处理身份验证请求。

安全.yml

encoders:
    FOS\UserBundle\Model\UserInterface: sha512


role_hierarchy:
    ROLE_ADMIN:       ROLE_USER
    ROLE_SUPER_ADMIN: [ROLE_USER, ROLE_ADMIN, ROLE_ALLOWED_TO_SWITCH]

providers:
    chain_provider:
        chain:
            providers: [fos_userbundle, fr3d_ldapbundle]

    fr3d_ldapbundle:
        id: fr3d_ldap.security.user.provider

    fos_userbundle:
        id: fos_user.user_provider.username

firewalls:
main:

    pattern:    ^/
    fr3d_ldap:  ~
    form_login:
#         check_path: fos_user_security_check
#         login_path: fos_user_security_login
        always_use_default_target_path: true
        default_target_path: /main
        provider: chain_provider
    logout:
        path:   fos_user_security_logout
        target: /login
    anonymous: ~

access_control:
   - { path: ^/login, roles: IS_AUTHENTICATED_ANONYMOUSLY }

config.yml

fr3d_ldap:
 driver:
  host:                192.168.137.200
  port:                50000
  username:            DOMAIN\Admnistrator    # Optional
  password:            pass_here    # Optional

user:
 baseDn: OU=HP,OU=MANA,DC=DOMAIN,DC=com
 filter: (&(ObjectClass=Person))
 attributes:          # Specify ldap attributes mapping [ldap attribute, user object method]
       - { ldap_attr: uid,  user_method: setUsername }
       - { ldap_attr: mail, user_method: setEmail }

实体/用户类

/**
* @ORM\Entity
* @ORM\Table(name="mdr_user")
*/
class User extends BaseUser implements LdapUserInterface
{
/**
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;

/**
* @ORM\Column(type="string", nullable=true)
*/
protected $name;

/**
* Ldap Object Distinguished Name
* @ORM\Column(type="string", length=128)
* @var string $dn
*/
private $dn;

public function __construct()
{
parent::__construct();
if (empty($this->roles)) {
    $this->roles[] = 'ROLE_USER';
}
}

public function setName($name) {
$this->name = $name;
}

/**
* {@inheritDoc}
*/
public function setDn($dn)
{
$this->dn = $dn;
}

/**
* {@inheritDoc}
*/
public function getDn()
{
return $this->dn;
}
}

如果我不实现 LdapUserInterface,DB 可以很好地进行身份验证,但如果我使用 mysql 条目以外的任何其他内容,我总是会收到该错误。你能帮我吗? 欣赏它。

最佳答案

尝试在您的 loginAction() 上执行此操作

\Doctrine\Common\Util\Debug::dump($this->getDoctrine()->getEntityManager()->find('AppBundle:User', 1));

您可能会看到一个错误。这对我有用。

关于php - Symfony 2.6 FR3DLdapBundle。由于系统原因,无法处理身份验证请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30026449/

相关文章:

php - 如何从 Controller 创建文件

c# - 获取用户所属的所有父AD组

security - Grails:实现 SSO

PHPExcel:如何设置单元格的日期格式

php - 如何使用php将一列的单行中的多个值添加到mysql中

php - 使用 symfony2 使用 GET 方法从表单中检索数据

php - Symfony 后台进程 FFmpeg 视频转换

java - Java 类可以模拟另一个 Windows 用户吗?

php - 在注册表中显示自定义字段 Prestashop 1.6.x

php - Laravel 4.x,CLI已停止工作