sql-server-2005 – 提取SQLCLR程序集

前端之家收集整理的这篇文章主要介绍了sql-server-2005 – 提取SQLCLR程序集前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我们的一个内部应用程序有一个sqlCLR程序集,目前遇到问题.开发人员在使用存储在我们的源代码管理系统中的版本重新创建问题时遇到问题,因此他怀疑某些代码可能已经发布但未上传到源代码控制.有没有办法将sqlCLR程序集提取到.dll文件中,以便他可以对其进行反向工程以进行分析?

解决方法

确实有一种方法 – 程序集存储在数据库的sys.assembly_files表中.从sys.assembly_files中选择所有内容并找到assembly_id,然后运行以下代码(首先更改assembly_id和SaveToFile路径):
DECLARE @IMG_PATH VARBINARY(MAX)
DECLARE @ObjectToken INT

SELECT @IMG_PATH = content FROM sys.assembly_files WHERE assembly_id = 65536

EXEC sp_OACreate 'ADODB.Stream',@ObjectToken OUTPUT
        EXEC sp_OASetProperty @ObjectToken,'Type',1
        EXEC sp_OAMethod @ObjectToken,'Open'
        EXEC sp_OAMethod @ObjectToken,'Write',NULL,@IMG_PATH
        EXEC sp_OAMethod @ObjectToken,'SaveToFile','D:\sqlServerProject1.dll',2
        EXEC sp_OAMethod @ObjectToken,'Close'
        EXEC sp_OADestroy @ObjectToken

为了使其工作,您需要在sql实例的功能的Surface Area Configuration中启用OLE自动功能.

我从这里提取了这段代码
http://social.msdn.microsoft.com/Forums/en/sqlnetfx/thread/1e00e656-f322-45ec-b4e0-83db748fa97a

猜你在找的MsSQL相关文章