API-интерфейс таблицы хранения Azure REST с Curl - PullRequest
0 голосов
/ 28 июня 2018

Мне нужна помощь, чтобы напечатать сущность с 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, который является идентификатором.

Использована следующая документация:

1 Ответ

0 голосов
/ 29 июня 2018

Нет необходимости изменять string_to_sign при запросе объекта, см. Заголовок авторизации .

Строка запроса должна включать знак вопроса и параметр comp (например,? Comp = metadata). Никакие другие параметры не должны быть включены в строку запроса.

Если вы хотите получить всю сущность, используя PartitionKey, измените URL-адрес на ($ need encoding на% 24)

https://${storage_account}.${table_store_url}/${table_name}?%24filter=PartitionKey%20eq%20'YourPartitionKey'

Или, если вы хотите получить только RowKey, добавьте &%24select=RowKey после этого.

Также -H "Content-Length: 0" бесполезен, просто удалите его.

...