Мне нужна помощь, чтобы напечатать сущность с Rest в сценарии оболочки. Я пробовал несколько способов, но безуспешно.
Вот мой код, он запускается, он возвращает все сущности в моей таблице.
Но мне нужно, чтобы он возвращал только определенное значение, и оно использует только PartitionKey.
#!/bin/bash
# List the tables in an Azure storage container.
storage_account="Secret"
table_name="teste"
access_key="Secret"
table_store_url="table.core.windows.net"
authorization="SharedKey"
request_method="GET"
request_date=$(TZ=GMT LC_ALL=en_US.utf8 date "+%a, %d %h %Y %H:%M:%S %Z")
#request_date="Mon, 18 Apr 2016 05:16:09 GMT"
storage_service_version="2018-03-28"
# HTTP Request headers
x_ms_date_h="x-ms-date:$request_date"
x_ms_version_h="x-ms-version:$storage_service_version"
# Build the signature string
canonicalized_resource="/${storage_account}/${table_name}"
string_to_sign="${request_method}\n\n\n$request_date\n${canonicalized_resource}"
# Decode the Base64 encoded access key, convert to Hex.
decoded_hex_key="$(echo -n $access_key | base64 -d -w0 | xxd -p -c256)"
# Create the HMAC signature for the Authorization header
signature=$(printf "$string_to_sign" | openssl dgst -sha256 -mac HMAC -macopt "hexkey:$decoded_hex_key" -binary | base64 -w0)
authorization_header="Authorization: $authorization $storage_account:$signature"
curl -s \
-H "$authorization_header" \
-H "$x_ms_date_h" \
-H "$x_ms_version_h" \
-H "Content-Length: 0" \
-H "accept: application/json;odata=nometadata" \
"https://${storage_account}.${table_store_url}/${table_name}"
В этом случае мне нужно изменить конец строки "string_to_sign" и последнюю строку Curl.
Если я вставлю в конце (PartitionKey = 'name', RowKey = 'Gabriel') "
Получение двух строк следующим образом:
string_to_sign = "$ {request_method} \ n \ n \ n $ request_date \ n $ {canonicalized_resource} (PartitionKey = 'name', RowKey = Gabriel)"
"https://${storage_account}.${table_store_url}/${table_name}(PartitionKey='nome',RowKey='Gabriel')"
Он вернет только сущность с PartitionKey "name" и Rowkey "Gabriel".
Но, как я уже говорил, я должен использовать только ключ раздела. Если я изменю конец двух строк только на (PartitionKey = 'name'), он вернет следующую ошибку:
The number of keys specified in the URI does not match number of key properties for the resource
Я попытался использовать опцию $ filter, изменив конец двух строк на ()$filter=(PartitionKey%20ge%20'Name')
, однако при прохождении через Printf происходит ошибка.
Если поставить ()$filter=(PartitionKey%%20ge%%20'Name')
, два%, он проходит, но возникает ошибка аутентификации по запросу.
Server failed to authenticate the request. Make sure the value of Authorization header is formed correctly including the signature
Может кто-нибудь мне помочь?
Мне нужно использовать PartitionKey, потому что в этих тестах я использую таблицу, которую я создал, и у меня есть значение RowKey для тестов, но там, где мне нужно реализовать, у меня нет доступа к RowKey, я бы передал значение PartitionKey, который является номером телефона для получения результата RowKey, который является идентификатором.
Использована следующая документация: