Доктрина MongoDB ODM: как получить версию @Id bin_md5 - PullRequest
0 голосов
/ 10 апреля 2019

В Doctrine ODM (MongoDB) можно использовать аннотацию Doctrine\ODM\MongoDB\Mapping\Annotations\Id для установки идентификатора документа.

Поскольку я хочу использовать хэш в качестве идентификатора, я установил свой документ такпуть:

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

Эта конфигурация преобразует хеш, например 774a0f33ede410cde2d785e2d9e52561, в _id: 'Nzc0YTBmMzNlZGU0MTBjZGUyZDc4NWUyZDllNTI1NjE='.

Теперь, когда я получаю $hash из документа, я получаю значение 774a0f33ede410cde2d785e2d9e52561.

Это делает для меня невозможным использование такого запроса в MongoDB Compass:

{"_id": "774a0f33ede410cde2d785e2d9e52561"}

Этот запрос, фактически, всегда не будет возвращать никакого значения, поскольку фактический идентификатор равен Nzc0YTBmMzNlZGU0MTBjZGUyZDc4NWUyZDllNTI1NjE=.

Как найти документ по его идентификатору, при этом только его хеш-код не преобразован?

Я пробовал много подходов:

  1. Использование md5() функция php;
  2. Использование (new Binary($resource->getHash(), Binary::TYPE_MD5))->getData()
  3. Использование new \MongoBinData($resource->getHash(), \MongoBinData::MD5)

Кажется, ничего из этих попыток не работает.

Есть идеи?

1 Ответ

0 голосов
/ 10 апреля 2019

Nzc0YTBmMzNlZGU0MTBjZGUyZDc4NWUyZDllNTI1NjE= просто закодировано в base64 774a0f33ede410cde2d785e2d9e52561

echo -n '774a0f33ede410cde2d785e2d9e52561' | base64

и использовать результат в compas

...