[转-记] 批量解密SQLSERVER数据库中的各种对象的工具dbForge SQL Decryptor2.1.11

原文链接:批量解密SQLSERVER数据库中的各种对象的工具dbForge SQL Decryptor - 桦仔 - 博客园

-----------------------------------------------------------------------------------------------------------------------------

问题:在处理报表数据时,发现有一个处理过程被加密了,试了一些方法都没能解决,直到遇到这篇大作,感谢大佬的分享,记录学习一下;

之前写过一篇文章,使用redgate公司的SQL PROMPT工具,但是不太方便

SQLPROMPT5.3对各种加密对象的解密测试

SQL2005解密已经被加密的存储过程

昨天ahdung 童鞋介绍了这个工具给我,非常感谢他

dbForge SQL Decryptor这个工具的软件公司是devart,也是跟redgate公司一样,制作各种数据库辅助工具和编程工具的一家比较出名的软件公司

官网:Devart: Database Management Software and Developer Tools

软件下载地址:

Download dbForge SQL Decryptor

https://files.cnblogs.com/lyhabc/sqldecryptor.rar

这个工具是免费的,不用破解,安装完毕,立刻可以用

在SQLSERVER数据库工具当中还提供了另外一个免费工具:dbForge SQL Azure Backup

SQL Server Tools | SQL Database Management Software


介绍

先说题外话:大家可以把这些第三方的工具放到外部工具里,这样只要打开SSMS,就不用在桌面找这些工具的图标再打开

相应工具了,速度可以快一倍,我就是这样做的,打开了SSMS就不用到桌面找这个软件,找那个软件

界面使用WPF编写,还是挺好的

登录界面做得挺有意思,可以使用传统的连接方式,也可以使用DAC连接或者自己写连接字符串

我们按照这篇文章创建好各种加密对象:SQLPROMPT5.3对各种加密对象的解密测试

包括视图,存储过程,函数,触发器

功能比较简单,界面跟SSMS差不多

就三个功能

选中你的数据库,然后右键-》Decryption Wizard..

他会列出你所选择要显示的解密对象类型,分别有:存储过程、用户定义函数、视图、表触发器、数据库触发器

你可以将解密的各种对象的脚本保存到同一个脚本中或者每个对象一个脚本,我这里选择都保存在同一个脚本中

点击Execute之后,在桌面就会生成一个脚本.sql文件

把脚本拖到SSMS

USE pratice
GO

SET ANSI_NULLS, QUOTED_IDENTIFIER ON
GO
/***************创建加密的存储过程*******************/
Create Procedure CPP_test_Encryption
with encryption
AS
----可以换成任意的逻辑
execute CPP_test_Original
GO

SET ANSI_NULLS, QUOTED_IDENTIFIER ON
GO
CREATE FUNCTION [dbo].f_get_page(@page_num BINARY(6))
RETURNS VARCHAR(11)
WITH ENCRYPTION
AS
BEGIN
RETURN(CONVERT(VARCHAR(2),(CONVERT(INT,SUBSTRING(@page_num,6,1))*POWER(2,8))+
        (CONVERT(INT,SUBSTRING(@page_num,5,1))))+':'+
        CONVERT(VARCHAR(11),
        (CONVERT(INT,SUBSTRING(@page_num,4,1))*POWER(2,24))+
        (CONVERT(INT,SUBSTRING(@page_num,3,1))*POWER(2,16))+
        (CONVERT(INT,SUBSTRING(@page_num,2,1))*POWER(2,8))+
        (CONVERT(INT,SUBSTRING(@page_num,1,1)))))
END
GO

SET ANSI_NULLS, QUOTED_IDENTIFIER ON
GO
CREATE VIEW aa
WITH ENCRYPTION
AS
SELECT * FROM [dbo].[Users]
GO

SET ANSI_NULLS, QUOTED_IDENTIFIER ON
GO
CREATE TRIGGER cc
ON [dbo].[Users]
WITH ENCRYPTION
FOR INSERT
AS RAISERROR(500001,16,10)
GO

SET ANSI_NULLS, QUOTED_IDENTIFIER ON
GO
Create Procedure creat_test_Encryption
with encryption
AS
SELECT TOP 100 * FROM [dbo].[test13]

GO
 

而Decrypt in-place(alter objects)就是把各种对象中的with encryption去掉,不知道f_get_page这个函数会失败

执行Decrypt in-place(alter objects)前

SET ANSI_NULLS, QUOTED_IDENTIFIER ON
GO
ALTER Procedure creat_test_Encryption
with encryption
AS
SELECT TOP 100 * FROM [dbo].[test13]
GO

执行执行Decrypt in-place(alter objects)后

SET ANSI_NULLS, QUOTED_IDENTIFIER ON
GO
ALTER Procedure creat_test_Encryption
AS
SELECT TOP 100 * FROM [dbo].[test13]
GO

你会看到执行Decrypt in-place(alter objects)后,相当于去掉了with encryption

除了那个用户定义函数之后其他的解密出来了,其实你可以drop掉那个函数,然后用解密出来的脚本重新创建函数就可以了

视图,触发器都没有锁小图标了


其他功能

Show  DDL script就是把对象的创建脚本显示出来,而Decrypt in-place我就不说了

注意,下面的界面是在dbForge SQL Decryptor工具中的界面,不是在SSMS中的界面,虽然这个工具的界面跟SQL2012 的SSMS界面很像


总结

DBA有了这个工具之后,就不怕开发人员随意加密他们自己写的函数、存储过程、触发器了

也能减轻DBA的负担

------

感谢以上大佬的内容分享,完美解决问题!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值