Symfony2插件FOSUserBundle的使用说明

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
云防火墙,500元 1000GB
简介:

Provides user persistence for your Symfony2 Project.
为您的Symfony2项目提供用户持久化

Features
功能
========

- Compatible with Doctrine ORM **and** ODM thanks to a generic repository.
- 与Doctrine ORM **和** ODM 兼容,这归功于通用库
- Model is extensible at will
- 模型可随意扩展
- REST-ful authentication
- REST风格的认证
- Current user available in your controllers and views
- 当前用户在您控制器和视图中可用
- Unit tested and functionally tested
- 支持单元测试和功能测试

Warning
警告
=======

The core SecurityBundle is required to use this bundle.
使用该Bundle必须启用核心SecurityBundle。

The supplied Controller and routing configuration files expose as much functionality as possible to illustrate how to use the Bundle. However using these exposes a lot of functionality which requires additional configuration to secure properly (for example delete, list etc). As such its not recommended to ever go into production while using one of the default routing configuration files.
为了说明如何使用该Bundle,其所提供的Controller和路由配置文件都尽可能多地展示功能。然而,展示大量这样的功能是需要额外的配置来确保安全的(如删除和列表等)。因此,并不建议在生产环境中使用某种缺省的路由配置文件。

The implementation of ACL checks via the JMSSecurityExtraBundle is also
currently incomplete (see issue #53) and activation of this Bundle is also
not enforced.
通过JMSSecurityExtraBundle实现ACL检查当前还不完整(参见问题#53),也并不强制激活该Bundle。

Furthermore it may be necessary to extend or even replace the default Controllers
with custom code to achieve the exact desired behavior. Trying to cover every possible use case is not feasible as it would complicate the Bundle to the point of being unmaintainable and impossible to comprehend in a reasonable amount of time.
此外,它也许会用自定义代码去扩展甚至替换缺省的控制器,以实现确实想要的行为。试图涵盖所有可能的用例是不现实的,因为它会使Bundle变得复杂,从而使之在合理的时间内变得不可维护和难以理解。

Installation
安装
============

Add FOSUserBundle to your vendor/bundles/ dir
将FOSUserBundle添加到您的vendor/bundles/目录中
------------------------------------------

Using the vendors script
使用vendors脚本
~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Add the following lines in your ``deps`` file
添加以下语句到您的``deps``文件中

::

[FOSUserBundle]
    git=git://github.com/FriendsOfSymfony/FOSUserBundle.git
    target=bundles/FOS/UserBundle

Run the vendors script
运行vendors脚本

::

    ./bin/vendors install

Using submodules
使用子模块
~~~~~~~~~~~~~~~~

::

    $ git submodule add git://github.com/FriendsOfSymfony/FOSUserBundle.git vendor/bundles/FOS/UserBundle

Add the FOS namespace to your autoloader
将FOS名称空间添加到您的自动加载器中
----------------------------------------

::

    // app/autoload.php
    $loader->registerNamespaces(array(
        'FOS' => __DIR__.'/../vendor/bundles',
        // your other namespaces
    );

Add UserBundle to your application kernel
将UserBundle添加到您的应用程序内核中
-----------------------------------------

::

    // app/AppKernel.php

    public function registerBundles()
    {
        return array(
            new Symfony\Bundle\SecurityBundle\SecurityBundle(),
            // ...
            new FOS\UserBundle\FOSUserBundle(),
            // ...
        );
    }

Create your User class
创建您的User类
----------------------

You must create a User class that extends either the entity or document abstract
User class in UserBundle.  All fields on the base class are mapped, except for
``id``; this is intentional, so you can select the generator that best suits
your application. Feel free to add additional properties and methods to your
custom class.
您必须创建一个User类去扩展UserBundle中的实体或文档抽象User类。除了``id``,基类中的所有字段都被映射;这是故意的,以便您可以选择您应用程序最适用的生成器。您可以向您自定义的类中随意添加额外的属性和方法。

ORM User class
ORM User类
~~~~~~~~~~~~~~

::

    // src/MyProject/MyBundle/Entity/User.php

    <?php
    namespace MyProject\MyBundle\Entity;
    use FOS\UserBundle\Entity\User as BaseUser;
    use Doctrine\ORM\Mapping as ORM;

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

        public function __construct()
        {
            parent::__construct();
            // your own logic
        }
    }

.. note
.. 注意

::

    ``User`` is a reserved keyword in SQL so you cannot use it as table name.
    ``User``是SQL中的保留关键词,因此您不能将其作为数据表名。

MongoDB User class
MongoDB User类
~~~~~~~~~~~~~~~~~~

::

    // src/MyProject/MyBundle/Document/User.php

    <?php
    namespace MyProject\MyBundle\Document;
    use FOS\UserBundle\Document\User as BaseUser;
    use Doctrine\ODM\MongoDB\Mapping\Annotations as MongoDB;

    /**
     * @MongoDB\Document
     */
    class User extends BaseUser
    {
        /** @MongoDB\Id(strategy="auto") */
        protected $id;

        public function __construct()
        {
            parent::__construct();
            // your own logic
        }
    }

.. warning
.. 警告

::
    Take care to call the parent constructor when you overwrite it in your own
    entity as it initializes some fields.
    当您为了初始化某些字段而在您自己的实体类中覆写了构造函数时,请小心调用父类的构造函数。

Configure your project
配置您的项目
----------------------

The UserBundle works with the Symfony Security Component, so make sure that is enabled in your kernel and in your project's configuration. A working security configuration using FOSUserBundle is available at the end of the doc.
UserBundle需要Symfony2的安全组件才能正常工作,因此请确保在您的内核和项目配置中启用了它。在本文档结束时,将向您展示一个可正常工作的使用FOSUserBundle的安全配置。

.. note
.. 注意

::

    You need to activate SwiftmailerBundle to be able to use the functionalities
    using emails (confirmation of the account, resetting of the password).
    See the `Emails` section to know how using another mailer.
    你需要激活SwiftmailerBundle来使用要电子邮件协助的功能(如帐号确认、密码重置等)

The login form and all the routes used to create a user and reset the password
have to be available to unauthenticated users but using the same firewall as
the pages you want to securize with the bundle. Assuming you import the
registration.xml routing file with the ``/register`` prefix and resetting.xml
with the ``/resetting`` prefix they will be
登录表单和所有用于创建用户和重置密码的路由都要向未经认证的用户开放,但使用同一防火墙,因为您要确保整个Bundle页面的安全。假设您准备使用``/register``前缀导入registration.xml路由文件,使用``/register``前缀导入resetting.xml。

::

    /login
    /register/
    /register/check-email
    /register/confirm/{token}
    /register/confirmed
    /resetting/request
    /resetting/send-email
    /resetting/check-email
    /resetting/reset/{token}

The above example assumes an ORM configuration, but the ``mappings``
configuration block would be the same for MongoDB ODM.
上面的例子假设使用的是ORM配置,但对于MongoDB ODM来讲``mappings``配置区块也能达到相同的效果。

Minimal configuration
最小配置
---------------------

At a minimum, your configuration must define your DB driver ("orm" or "mongodb"), a User class and the firewall name. The firewall name matches the key in the firewall configuration that is used for users with the controllers of the
bundle.
至少,您的配置需要定义您的数据库驱动("orm"或"mongodb")、User类和防火墙名。防火墙名匹配防火墙配置中的关键词,该配置用于Bundle控制器的用户。

The firewall name needs to be configured so that the FOSUserBundle can determine against which firewall the user should be authenticated after activating the account for instance. This means that out of the box FOSUserBundle only supports being used for a single firewall, though with a custom Controller this
limitation can be circumvented.
配置防火墙名称是为了让FOSUserBundle可以确定用户帐户实例激活后确定使用哪个防火墙来进行认证。这就意味着FOSUserBundle仅被支持用于单个防火墙,虽然通过自定义控制器可以规避该限制。

For example for a security configuration like the following the firewall_name
would have to be set to "main", as shown in the proceeding examples:
接下来是安全配置的例子,firewall_name必须设为"main",如下所示:

::

    # app/config/config.yml
    security:
        providers:
            fos_userbundle:
                id: fos_user.user_manager

        firewalls:
            main:
                form_login:
                    provider: fos_userbundle

ORM
~~~

In YAML:
YAML格式:

::

    # app/config/config.yml
    fos_user:
        db_driver: orm
        firewall_name: main
        user_class: MyProject\MyBundle\Entity\User

Or if you prefer XML:
如果你喜欢XML格式:

::

    # app/config/config.xml

    <fos_user:config
        db-driver="orm"
        firewall-name="main"
        user-class="MyProject\MyBundle\Entity\User"
    />

ODM
~~~

In YAML:
YAML格式:

::

    # app/config/config.yml
    fos_user:
        db_driver: mongodb
        firewall_name: main
        user_class: MyProject\MyBundle\Document\User

Or if you prefer XML:
如果你喜欢XML格式:

::

    # app/config/config.xml

    <fos_user:config
        db-driver="mongodb"
        firewall-name="main">
        user-class="MyProject\MyBundle\Document\User"
    />


Add authentication routes
添加认证路由
-------------------------

If you want ready to use login and logout pages, include the built-in
routes:
如果你想使用包含内建路由的登录和退出页:

::

    # app/config/routing.yml
    fos_user_security:
        resource: "@FOSUserBundle/Resources/config/routing/security.xml"

    fos_user_profile:
        resource: "@FOSUserBundle/Resources/config/routing/profile.xml"
        prefix: /profile

    fos_user_register:
        resource: "@FOSUserBundle/Resources/config/routing/registration.xml"
        prefix: /register

    fos_user_resetting:
        resource: "@FOSUserBundle/Resources/config/routing/resetting.xml"
        prefix: /resetting

    fos_user_change_password:
        resource: "@FOSUserBundle/Resources/config/routing/change_password.xml"
        prefix: /change-password

::

    # app/config/routing.xml

    <import resource="@FOSUserBundle/Resources/config/routing/security.xml"/>
    <import resource="@FOSUserBundle/Resources/config/routing/profile.xml" prefix="/profile" />
    <import resource="@FOSUserBundle/Resources/config/routing/registration.xml" prefix="/register" />
    <import resource="@FOSUserBundle/Resources/config/routing/resetting.xml" prefix="/resetting" />
    <import resource="@FOSUserBundle/Resources/config/routing/change_password.xml" prefix="/change-password" />

You now can login at http://app.com/app_dev.php/login
现在您可以通过http://app.com/app_dev.php/login登录了。

Command line
命令行
============

FOSUserBundle provides command line utilities to help manage your
application users.
FOSUserBundle提供命令行工具来帮助您管理您的管理程序用户。

Create user
创建用户
-----------

This command creates a new user
该命令新建一个用户

::

    $ php app/console fos:user:create username email password

If you don't provide the required arguments, a interactive prompt will
ask them to you
如果您不能提供所需的参数,将出现询问您的提示

::

    $ php app/console fos:user:create

Promote user as a super administrator
将用户提升为超级管理员
-------------------------------------

This command promotes a user as a super administrator
该命令将用户提升为超级管理员

::

    $ php app/console fos:user:promote

User manager service
用户管理服务
====================

FOSUserBundle works with both ORM and ODM. To make it possible, it wraps
all the operation on users in a UserManager. The user manager is a service
of the container.
FOSUserBundle可以与ORM或ODM一起工作。为了使之成为可能,它在UserManager中封装了与用户相关的所有操作。

If you configure the db_driver to orm, this service is an instance of
``FOS\UserBundle\Entity\UserManager``.
如果您将db_driver配置为orm,该服务是``FOS\UserBundle\Entity\UserManager``的一个实例。

If you configure the db_driver to odm, this service is an instance of
``FOS\UserBundle\Document\UserManager``.
如果您将db_driver配置为odm,该服务就是``FOS\UserBundle\Document\UserManager``的一个实例。

Both these classes implement ``FOS\UserBundle\Model\UserManagerInterface``.
上述两个类都实现了``FOS\UserBundle\Model\UserManagerInterface``接口。

Access the user manager service
访问用户管理服务
-------------------------------

If you want to manipulate users in a way that will work as well with
ORM and ODM, use the fos_user.user_manager service
如果您想用一种方式操作用户,该方式能够使ORM或ODM都良好工作,那么使用fos_user.user_manager服务

::

    $userManager = $container->get('fos_user.user_manager');

That's the way FOSUserBundle's internal controllers are built.
这是创建FOSUserBundle内部控制器的方式。

Access the current user class
访问当前用户类
-----------------------------

A new instance of your User class can be created by the user manager
通过用户管理器创建您User类的新实例

::

    $user = $userManager->createUser();

`$user` is now an Entity or a Document, depending on the configuration.
`$user`现在是一个Entity或Document,这取决于配置。

Updating a User object
更新用户对象
----------------------

When creating or updating a User object you need to update the encoded password and the canonical fields. To make it easier, the bundle comes with a Doctrine listener handling this for you behind the scene.
当创建或更新用户对象时,您需要更新加密的密码和规范的字段。为了使这一切变得容易,该Bundle自带的Doctrine监听器将为您在幕后处理这一切。

If you don't want to use the Doctrine listener, you can disable it. In this case
you will have to call the ``updateUser`` method of the user manager each time
you do a change in your entity.
如果您不想使用Doctrine监听器,您也可以禁用它。在这种情况下,当您每次改变您的实体时,您都将不得不调用用户管理器的``updateUser``方法。

In YAML:
YAML格式:

::

    # app/config/config.yml
    fos_user:
        db_driver: orm
        firewall_name: main
        use_listener: false
        user_class: MyProject\MyBundle\Entity\User

Or if you prefer XML:
如果您喜欢XML格式:

::

    # app/config/config.xml

    <fos_user:config
        db-driver="orm"
        firewall-name="main"
        use-listener="false">
        user-class="MyProject\MyBundle\Entity\User"
    />

.. note
.. 注意

::

    The default behavior is to flush the changes when calling this method. You
    can disable the flush when using the ORM and the MongoDB implementations by
    passing a second argument set to ``false``.
    当调用该方法时,其缺省动作是去"flush"改变。您可以将该方法的第二个参数设为``false``,从而在使用ORM或MongoDB实现时禁用"flush"。

Using groups
使用组
============

The bundle allows to optionnally use groups. You need to explicitly
enable it in your configuration by giving the Group class which must
implement ``FOS\UserBundle\Model\GroupInterface``.
可以让该Bundle选择使用组。您需要通过指定的Group类在您的配置中明确地启用它,Group类必须实现``FOS\UserBundle\Model\GroupInterface``接口。

In YAML:
YAML格式:

::

    # app/config/config.yml
    fos_user:
        db_driver: orm
        firewall_name: main
        user_class: MyProject\MyBundle\Entity\User
        group:
            group_class: MyProject\MyBundle\Entity\Group

Or if you prefer XML:
如果您喜欢XML格式:
::

    # app/config/config.xml

    <fos_user:config
        db-driver="orm"
        firewall-name="main">
        user-class="MyProject\MyBundle\Entity\User"
    >
        <fos_user:group group-class model="MyProject\MyBundle\Entity\Group" />
    </fos_user:config>

The Group class
Group类
---------------

The simpliest way is to extend the mapped superclass provided by the
bundle.
最简单的方式就是扩展由该Bundle提供的映射超类

ORM
~~~

::

    // src/MyProject/MyBundle/Entity/Group.php

    <?php
    namespace MyProject\MyBundle\Entity;
    use FOS\UserBundle\Entity\Group as BaseGroup;
    use Doctrine\ORM\Mapping as ORM;

    /**
     * @ORM\Entity
     * @ORM\Table(name="fos_group")
     */
    class Group extends BaseGroup
    {
        /**
         * @ORM\Id
         * @ORM\Column(type="integer")
         * @ORM\generatedValue(strategy="AUTO")
         */
        protected $id;
    }

.. note
.. 注意

::

    ``Group`` is also a reserved keyword in SQL so it cannot be used either.
    ``Group``也是SQL的保留关键词,因此它也不能使用。

ODM
~~~

::

    // src/MyProject/MyBundle/Document/Group.php

    <?php
    namespace MyProject\MyBundle\Document;
    use FOS\UserBundle\Document\Group as BaseGroup;
    use Doctrine\ODM\MongoDB\Mapping as MongoDB;

    /**
     * @MongoDB\Document
     */
    class Group extends BaseGroup
    {
        /** @MongoDB\Id(strategy="auto") */
        protected $id;
    }

Defining the relation
定义关系
---------------------

The next step is to map the relation in your User class.
下一步就是要映射您User类的关系

ORM
~~~

::

    // src/MyProject/MyBundle/Entity/User.php

    <?php
    namespace MyProject\MyBundle\Entity;
    use FOS\UserBundle\Entity\User as BaseUser;
    use Doctrine\ORM\Mapping as ORM;

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

        /**
         * @ORM\ManyToMany(targetEntity="MyProject\MyBundle\Entity\Group")
         * @ORM\JoinTable(name="fos_user_user_group",
         *      joinColumns={@ORM\JoinColumn(name="user_id", referencedColumnName="id")},
         *      inverseJoinColumns={@ORM\JoinColumn(name="group_id", referencedColumnName="id")}
         * )
         */
        protected $groups;
    }

ODM
~~~

::

    // src/MyProject/MyBundle/Document/User.php

    <?php
    namespace MyProject\MyBundle\Document;
    use FOS\UserBundle\Document\User as BaseUser;
    use Doctrine\ODM\MongoDB\Mapping as MongoDB;

    /**
     * @MongoDB\Document
     */
    class User extends BaseUser
    {
        /** @MongoDB\Id(strategy="auto") */
        protected $id;

        /** @MongoDB\ReferenceMany(targetDocument="MyProject\MyBundle\Document\Group") */
        protected $groups;
    }

Enabling the routing for the GroupController
为GroupController启用路由
--------------------------------------------

You can also the group.xml file to use the builtin controller to manipulate the
groups.
您也可以通过group.xml文件使用内建的控制器来维护组。

Configuration reference
配置参考
=======================

All configuration options are listed below
以下列出所有配置选项

::

    # app/config/config.yml
    fos_user:
        db_driver:      ~ # Required
        firewall_name:  ~ # Required
        user_class:     ~ # Required
        use_listener:   true
        from_email:     { webmaster@example.com: Admin }
        profile:
            form:
                type:               FOS\UserBundle\Form\ProfileFormType
                handler:            FOS\UserBundle\Form\ProfileFormHandler
                name:               fos_user_profile_form
                validation_groups:  [Profile]
        change_password:
            form:
                type:               FOS\UserBundle\Form\ChangePasswordFormType
                handler:            FOS\UserBundle\Form\ChangePasswordFormHandler
                name:               fos_user_change_password_form
                validation_groups:  [ChangePassword]
        registration:
            confirmation:
                from_email: ~
                enabled:    false
                template:   FOSUserBundle:Registration:email.txt.twig
            form:
                type:               FOS\UserBundle\Form\RegistrationFormType
                handler:            FOS\UserBundle\Form\RegistrationFormHandler
                name:               fos_user_registration_form
                validation_groups:  [Registration]
        resetting:
            token_ttl: 86400
            email:
                from_email: ~
                template:   FOSUserBundle:Resetting:email.txt.twig
            form:
                type:               FOS\UserBundle\Form\ResettingFormType
                handler:            FOS\UserBundle\Form\ResettingFormHandler
                name:               fos_user_resetting_form
                validation_groups:  [ResetPassword]
        service:
            mailer:                 fos_user.util.mailer.default
            email_canonicalizer:    fos_user.util.email_canonicalizer.default
            username_canonicalizer: fos_user.util.username_canonicalizer.default
            user_manager:           fos_user.user_manager.default
        encoder:
            algorithm:          sha512
            encode_as_base64:   false
            iterations:         1
        template:
            engine: twig
            theme:  FOSUserBundle::form.html.twig
        group:
            group_class:    ~ # Required when using groups
            form:
                type:               FOS\UserBundle\Form\GroupFormType
                handler:            FOS\UserBundle\Form\GroupHandler
                name:               fos_user_group_form
                validation_groups:  [Registration]

Configuration example
配置示例
=====================

This section provides a working configuration for the bundle and the security.
本段为Bundle和安全提供了一个可正常工作的配置。

FOSUserBundle configuration
FOSUserBundle配置
---------------------------

::

    # app/config/config.yml
    fos_user:
        db_driver:     orm
        firewall_name: main
        user_class:  MyProject\MyBundle\Entity\User

Security configuration
安全配置
----------------------

::

    # app/config/security.yml
    security:
        providers:
            fos_userbundle:
                id: fos_user.user_manager

        firewalls:
            main:
                pattern:      .*
                form_login:
                    provider:       fos_userbundle
                    login_path:     /login
                    use_forward:    false
                    check_path:     /login_check
                    failure_path:   null
                logout:       true
                anonymous:    true

        access_control:
            # The WDT has to be allowed to anonymous users to avoid requiring the login with the AJAX request必须允许匿名用户访问以避免使用AJAX请求时要求登录
            # WDT必须允许匿名用户访问,以避免在使用AJAX请求时被要求登录
            - { path: ^/_wdt/, role: IS_AUTHENTICATED_ANONYMOUSLY }
            - { path: ^/_profiler/, role: IS_AUTHENTICATED_ANONYMOUSLY }
            # AsseticBundle paths used when using the controller for assets
            # 当为assets使用控制器时将AsseticBundle路径
            - { path: ^/js/, role: IS_AUTHENTICATED_ANONYMOUSLY }
            - { path: ^/css/, role: IS_AUTHENTICATED_ANONYMOUSLY }
            # URL of FOSUserBundle which need to be available to anonymous users
            # FOSUserBundle的URL,需要匿名用户可见
            - { path: ^/login$, role: IS_AUTHENTICATED_ANONYMOUSLY }
            - { path: ^/register, role: IS_AUTHENTICATED_ANONYMOUSLY }
            - { path: ^/resetting, role: IS_AUTHENTICATED_ANONYMOUSLY }
            # Secured part of the site
            # 网站安全部分
            # This config requires being logged for the whole site and having the admin role for the admin part.
            # 这个配置要求正在被全站记录,并且对admin部分要求管理角色
            # Change these rules to adapt them to your needs
            # 改变这些角色使它们适应您的需要
            - { path: ^/admin/, role: ROLE_ADMIN }
            - { path: ^/.*, role: ROLE_USER }

        role_hierarchy:
            ROLE_ADMIN:       ROLE_USER
            ROLE_SUPER_ADMIN:  ROLE_ADMIN

Replacing some part by your own implementation
使用您自己的实现替换一些部分
==============================================

Templating
模板
----------

The template names are not configurable, however Symfony2 makes it possible
to extend a bundle by defining a template in the app/ directory.
模板名是不可配置的,然而为了扩展Bundle,Symfony2可以通过在app/目录中定义模板来使之成为可能。

For example ``vendor/bundles/FOS/UserBundle/Resources/views/User/new.twig`` can be
replaced inside an application by putting a file with alternative content in
``app/Resources/FOSUserBundle/views/User/new.twig``.
举个例子,``vendor/bundles/FOS/UserBundle/Resources/views/User/new.twig``可以通过在应用程序中放置的``app/Resources/FOSUserBundle/views/User/new.twig``文件内容所取代。

You could also create a bundle defined as child of FOSUserBundle and placing the
templates in it.
您也可以创建一个FOSUserBundle的子Bundle,并将模板放置其中。

You can use a different templating engine by configuring it but you will have to
create all the needed templates as only twig templates are provided.
通过配置您可以使用不同的模板引擎,但您必须得创建所有需要的模板,而不仅是只提供twig模板。

Controller
控制器
----------

To overwrite a controller, create a bundle defined a child of FOSUserBundle
and create a controller with the same name in this bundle.
要覆写一个控制器,可以创建一个FOSUserBundle的子Bundle,并在该Bundle中创建同名的控制器。

Validation
验证
----------

The ``Resources/config/validation.xml`` file contains definitions for custom
validator rules for various classes. The rules defined by FOSUserBundle are
all in a validation group so you can choose not to use them.
``Resources/config/validation.xml``文件包含了为不同类自定义的验证器规则。这些被FOSUserBundle定义的规则都被放置在一个验证组中,因此您可以选择不使用它们。

Emails
电子邮件
------

The default mailer relies on Swiftmailer to send the mails of the bundle.
If you want to use another mailer in your project you can change it by defining
your own service implementing ``FOS\UserBundle\Mailer\MailerInterface`` and
setting its id in the configuration
缺省邮件系统依赖于Swiftmailer来发送Bundle的邮件。如果您想在您的项目中使用其它的邮件系统,您可以通过定义您自己的服务来改变它。该服务必须要实现 ``FOS\UserBundle\Mailer\MailerInterface``接口,并在配置中设置它的ID。

::

    fos_user:
        # ...
        service:
            mailer: custom_mailer_id

This bundle comes with two mailer implementations.
该Bundle有两个邮件系统实现。

- `fos_user.mailer.default` is the default implementation, and uses swiftmailer to send emails.
- `fos_user.mailer.default` 是缺省实现,它使用swiftmailer来发送邮件。
- `fos_user.mailer.noop` does nothing and can be used if your project does not depend on swiftmailer.
- `fos_user.mailer.noop` 不做任何事,如果您的项目不使用swiftmailer,可以使用它。

Canonicalization
规范
----------------

``Canonicalizer`` services are used to canonicalize the username and the email
fields for database storage. By default, username and email fields are
canonicalized in the same manner using ``mb_convert_case()``. You may configure
your own class for each field provided it implements
``FOS\UserBundle\Util\CanonicalizerInterface``.
``Canonicalizer`` 服务为数据库存储规范用户名和邮件字段。缺省情况下,用户名和邮件字段同样都是使用``mb_convert_case()``来进行规范的。您也许想为每个字段都配置您自己的类,这可以通过实现``FOS\UserBundle\Util\CanonicalizerInterface``接口来提供。

.. note
.. 注意

::

    If you do not have the mbstring extension installed you will need to
    define your own ``canonicalizer``.
    如果您没有安装mbstring扩展,您需要定义您自己的``canonicalizer``



本文转自 firehare 51CTO博客,原文链接:http://blog.51cto.com/firehare/595319,如需转载请自行联系原作者

相关文章
xal
|
JavaScript API
VSCode插件开发全攻略(九)常用API总结
更多文章请戳[VSCode插件开发全攻略系列目录导航](https://www.atatech.org/articles/121864)。 本文提炼一些常见的API使用场景供参考。 # 本文还没写完,有待补充 # 编辑器相关 ## 修改当前激活编辑器内容 替换当前编辑器全部内容: ```js vscode.window.activeTextEditor.e
xal
2687 0
|
3月前
|
缓存 API 网络架构
Nuxt Kit API :路径解析工具
【9月更文挑战第20天】在 Nuxt Kit API 中,路径解析工具如 `resolvePath()`、`joinPaths()` 和 `relativePath()` 帮助开发者高效处理应用路径,确保资源准确加载,并支持动态路由与组件导入。这些工具提升了应用的灵活性和可扩展性,同时需注意路径准确性、跨平台兼容性和性能优化,以提升用户体验。
39 12
|
6月前
|
存储 安全 数据库
Duplicator插件
【6月更文挑战第5天】Duplicator插件
55 2
|
6月前
|
存储 数据库 数据安全/隐私保护
Duplicator插件的主要功能是什么?
【6月更文挑战第4天】Duplicator插件的主要功能是什么?
65 1
CTK框架 - 插件依赖关系 - 给插件加上界面
在第一篇文章中吗,我们提到了MANIFEST.MF中有个字段是依赖关系,这次我们来测试一下这个依赖关系:
201 0
【3款文献阅读的插件】
【3款文献阅读的插件】
736 0
|
前端开发
symfony2框架配置页面
symfony2框架配置页面
139 0
symfony2框架配置页面
openlayers4.6.5官方api、实例、开发包
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/gisdoer/article/details/81454170 openlayers4.6.5官方api、实例、开发包 openlayers更新到了5.0以上版本,github下载速度慢,时常错误,直接点击下载即可。
1417 0