• 批量解密SQLSERVER数据库中的各种对象的工具dbForge SQL Decryptor


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

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

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

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

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

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

    官网:http://www.devart.com/

    软件下载地址:

    http://www.devart.com/dbforge/sql/sqldecryptor/download.html

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

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

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

    http://www.devart.com/dbforge/sql/


    介绍

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

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

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

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

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

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

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

    就三个功能

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

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

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

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

    把脚本拖到SSMS

     1 USE pratice
     2 GO
     3 
     4 SET ANSI_NULLS, QUOTED_IDENTIFIER ON
     5 GO
     6 /***************创建加密的存储过程*******************/
     7 Create Procedure CPP_test_Encryption 
     8 with encryption
     9 AS
    10 ----可以换成任意的逻辑
    11 execute CPP_test_Original
    12 GO
    13 
    14 SET ANSI_NULLS, QUOTED_IDENTIFIER ON
    15 GO
    16 CREATE FUNCTION [dbo].f_get_page(@page_num BINARY(6))
    17 RETURNS VARCHAR(11)
    18 WITH ENCRYPTION
    19 AS
    20 BEGIN
    21 RETURN(CONVERT(VARCHAR(2),(CONVERT(INT,SUBSTRING(@page_num,6,1))*POWER(2,8))+
    22         (CONVERT(INT,SUBSTRING(@page_num,5,1))))+':'+
    23         CONVERT(VARCHAR(11),
    24         (CONVERT(INT,SUBSTRING(@page_num,4,1))*POWER(2,24))+
    25         (CONVERT(INT,SUBSTRING(@page_num,3,1))*POWER(2,16))+
    26         (CONVERT(INT,SUBSTRING(@page_num,2,1))*POWER(2,8))+
    27         (CONVERT(INT,SUBSTRING(@page_num,1,1)))))
    28 END
    29 GO
    30 
    31 SET ANSI_NULLS, QUOTED_IDENTIFIER ON
    32 GO
    33 CREATE VIEW aa
    34 WITH ENCRYPTION
    35 AS
    36 SELECT * FROM [dbo].[Users]
    37 GO
    38 
    39 SET ANSI_NULLS, QUOTED_IDENTIFIER ON
    40 GO
    41 CREATE TRIGGER cc
    42 ON [dbo].[Users]
    43 WITH ENCRYPTION
    44 FOR INSERT
    45 AS RAISERROR(500001,16,10)
    46 GO
    47 
    48 SET ANSI_NULLS, QUOTED_IDENTIFIER ON
    49 GO
    50 Create Procedure creat_test_Encryption 
    51 with encryption
    52 AS
    53 SELECT TOP 100 * FROM [dbo].[test13]
    54 
    55 GO

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

    执行Decrypt in-place(alter objects)前

    1 SET ANSI_NULLS, QUOTED_IDENTIFIER ON
    2 GO
    3 ALTER Procedure creat_test_Encryption 
    4 with encryption
    5 AS
    6 SELECT TOP 100 * FROM [dbo].[test13]
    7 GO

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

    1 SET ANSI_NULLS, QUOTED_IDENTIFIER ON
    2 GO
    3 ALTER Procedure creat_test_Encryption 
    4 AS
    5 SELECT TOP 100 * FROM [dbo].[test13]
    6 GO

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

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

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


    其他功能

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

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


    总结

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

    也能减轻DBA的负担

    如有不对的地方,欢迎大家拍砖o(∩_∩)o

  • 相关阅读:
    《JAVA多线程编程核心技术》 笔记:第四章、Lock的使用
    服务器负载粗略估算
    spring事务传播性理解
    BlockingQueue 阻塞队列2
    六大原则
    mycat之schema.xml理解
    mycat分库读写分离原理
    sqlservere连接问题
    java代码添加mysql存储过程,触发器
    Amoeba+Mysql实现读写分离+java连接amoeba
  • 原文地址:https://www.cnblogs.com/lyhabc/p/3505677.html
Copyright © 2020-2023  润新知