Сведения о том, как передать ключ удаленному пользователю, см. В этом сообщении Стек информационной безопасности .
Ошибка связана с тем, что saveRDS
не возвращает значение , И вы ничего не сохранили в файл, эта строка кода выдает ошибку. Правильный способ шифрования и для сохранения в файл:
key <- cyphr::key_sodium(sodium::keygen())
saveRDS(cyphr::encrypt_string("my secret string", key),
file = "test.rds")
secret <- readRDS("test.rds")
secret
# [1] 75 fc bb fd e3 07 66 3e 9b 72 ac ca c7 f5 3a ed 7c d7 e0 b0 ad 3e 53 ba
#[25] e7 dd 14 5e 64 0f 06 51 17 fe e1 f3 aa b9 27 7c 6e 8e 02 55 ae 68 0a 0f
#[49] 89 6c 17 b0 4f 83 3d ea
cyphr::decrypt_string(secret, key)
#[1] "my secret string"
Что касается проблемы сохранения ключа в файле, это обычный вызов saveRDS
, за которым следует readRDS
звонок.
Посмотрите, что такое ключ.
class(key)
#[1] "cyphr_key"
str(key)
#List of 4
# $ type : chr "sodium"
# $ key :function ()
# $ encrypt:function (msg)
# $ decrypt:function (msg)
# - attr(*, "class")= chr "cyphr_key"
Теперь сохраните его в файл "key.rds"
, удалите объект key
из .GlobalEnv
и прочитайте его из файла.
saveRDS(key, "key.rds")
rm(key)
key <- readRDS("key.rds")
Это сработало?
class(key)
#[1] "cyphr_key"
str(key)
#List of 4
# $ type : chr "sodium"
# $ key :function ()
# $ encrypt:function (msg)
# $ decrypt:function (msg)
# - attr(*, "class")= chr "cyphr_key"
По-видимому, так и было, проверьте, правильно ли оно расшифровывает строку.
cyphr::decrypt_string(secret, key)
#[1] "my secret string"
Окончательная очистка.
unlink("test.rds")
unlink("key.rds")