Doctrine MongoDB ODM:如何获取@Id的bin_md5版本

时间:2019-04-10 10:26:18

标签: php mongodb doctrine doctrine-odm

使用Doctrine ODM(MongoDB),可以使用注释Doctrine\ODM\MongoDB\Mapping\Annotations\Id来设置文档的ID。

由于我想使用哈希作为ID,因此我以这种方式设置了文档:

class WebResource
{
    /**
     * @ODM\Id(strategy="NONE", type="bin_md5")
     *
     * @var string
     */
    private $hash;
    ...
}

此配置将774a0f33ede410cde2d785e2d9e52561之类的哈希转换为_id: 'Nzc0YTBmMzNlZGU0MTBjZGUyZDc4NWUyZDllNTI1NjE='

现在,当我从文档中获得$hash时,我得到的值是774a0f33ede410cde2d785e2d9e52561

这使我无法在MongoDB Compass中使用这样的查询:

{"_id": "774a0f33ede410cde2d785e2d9e52561"}

实际上,此查询将始终不返回任何值,因为实际ID为Nzc0YTBmMzNlZGU0MTBjZGUyZDc4NWUyZDllNTI1NjE=

我如何通过其ID来查找文档,而其哈希值仍未转换?

我尝试了很多方法:

  1. 使用md5() php函数;
  2. 使用(new Binary($resource->getHash(), Binary::TYPE_MD5))->getData()
  3. 使用new \MongoBinData($resource->getHash(), \MongoBinData::MD5)

这些尝试似乎都没有。

有什么想法吗?

1 个答案:

答案 0 :(得分:1)

Nzc0YTBmMzNlZGU0MTBjZGUyZDc4NWUyZDllNTI1NjE=只是base64编码的774a0f33ede410cde2d785e2d9e52561

echo -n '774a0f33ede410cde2d785e2d9e52561' | base64

并在compas中使用结果