2

我想排除我的序列化对象的几个(尤其是密码)字段。

我有一个与以下内容有关的对象:Application\Sonata\UserBundle\Entity\User

当我序列化该对象时,它给了我这样的用户:

id: 1,
username: "bla",
salt: "fvasdfs9h834sgkcwsg808000w08ccwo",
password: "E7Qsfswef9zdwfNvS6TecQraLYlbsefetRy/DPbqXvyknccxisefesefCicl4IxnXgSOnBx29Tgtp9ceUs1hPg=="

如何删除密码和盐字段?

我试图在以下位置更改配置文件:Application/Sonata/UserBundle/Resources/config/serializer/Entity.User.xml但它似乎没有使用该配置,即使我清除了缓存......

4

1 回答 1

4

我的第一个猜测是您的 SonataUserBundle 扩展了 FOSUserBundle,如果您检查 Sonata 的 Model User 则没有密码字段:https ://github.com/sonata-project/SonataUserBundle/blob/master/Model/User.php密码字段位于 FOSUserBundle 的 Model 用户中,因此不使用您的 xml 文件。

您必须设置定义自定义属性的路径:

配置.yml

jms_serializer:
    metadata:
        directories:
            FOSUserBundle:
                path: "@ApplicationSonataUserBundle/Resources/config/serializer/"
                namespace_prefix: "FOS\\UserBundle"

我不习惯 xml 文件,所以这里是停止暴露密码的 yml。

应用程序/奏鸣曲/UserBundle/Resources/config/serializer/Model.user.yml

FOS\UserBundle\Model\User:
    properties:
        password:
            expose: false

相关问题/答案:https ://stackoverflow.com/a/12961994/3726645

于 2015-06-11T11:01:34.830 回答