Я пытаюсь загрузить add an assembly в базу данных в SQL2008 с помощью asymmetric key.создание асимметричного ключа по сети
Мы добавляем сборку с помощью шестнадцатеричной строки (добавление сборок серверов только через SQL запросов)
USE [master]
GO
IF NOT EXISTS (SELECT * from sys.asymmetric_keys where name = 'ManagedAsymmetricKey')
BEGIN
CREATE ASYMMETRIC KEY ManagedAsymmetricKey FROM FILE = 'C:\Managed.dll'
CREATE LOGIN CLRLogin FROM ASYMMETRIC KEY ManagedAsymmetricKey
GRANT UNSAFE ASSEMBLY TO CLRLogin
END
GO
USE [$dbName]
GO
CREATE ASSEMBLY [Managed]
AUTHORIZATION [dbo]
FROM 0x4D5A....
WITH PERMISSION_SET = UNSAFE
GO
Это будет работать на локальном экземпляре, однако в сети мы получаем; The certificate, asymmetric key, or private key file does not exist or has invalid format.
Возможно, я ошибаюсь, что сначала должен добавить ключ, должен ли я добавлять сборку, а затем делать что-то по линиям CREATE ASYMMETRIC KEY ManagedAsymmetricKey FROM ASSEMBLY [workingDB].[dbo].[Managed]
?
Для временного монтажа, вам не нужно устанавливать '' PERMISSION_SET' к UNSAFE', потому что вам не нужно выполнять код из сборки для создания ключа. Это также означает, что вам не нужно устанавливать 'TRUSTWORTHY' в любом месте. Кроме того, спасибо за умный взлом! –
Я ставил небезопасно, потому что сборка в вопросе небезопасна. если у вас есть безопасная сборка, это действительно не нужно. –
Я не на это 100%, но я не думаю, что сборки неотъемлемо (un) безопасны. Моя сборка содержит код, который работает только с разрешениями UNSAFE, но SQL Server не жалуется, когда я создаю сборку с помощью 'PERMISSION_SET = SAFE'. –