博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
批量解密SQLSERVER数据库中的各种对象的工具dbForge SQL Decryptor
阅读量:6808 次
发布时间:2019-06-26

本文共 2700 字,大约阅读时间需要 9 分钟。

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

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

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

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

官网:

软件下载地址:

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

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


介绍

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

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

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

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

 

我们按照这篇文章创建好各种加密对象:

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

功能比较简单,界面跟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 AS10 ----可以换成任意的逻辑11 execute CPP_test_Original12 GO13 14 SET ANSI_NULLS, QUOTED_IDENTIFIER ON15 GO16 CREATE FUNCTION [dbo].f_get_page(@page_num BINARY(6))17 RETURNS VARCHAR(11)18 WITH ENCRYPTION19 AS20 BEGIN21 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 END29 GO30 31 SET ANSI_NULLS, QUOTED_IDENTIFIER ON32 GO33 CREATE VIEW aa34 WITH ENCRYPTION35 AS36 SELECT * FROM [dbo].[Users]37 GO38 39 SET ANSI_NULLS, QUOTED_IDENTIFIER ON40 GO41 CREATE TRIGGER cc42 ON [dbo].[Users]43 WITH ENCRYPTION44 FOR INSERT45 AS RAISERROR(500001,16,10)46 GO47 48 SET ANSI_NULLS, QUOTED_IDENTIFIER ON49 GO50 Create Procedure creat_test_Encryption 51 with encryption52 AS53 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 ON2 GO3 ALTER Procedure creat_test_Encryption 4 with encryption5 AS6 SELECT TOP 100 * FROM [dbo].[test13]7 GO

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

1 SET ANSI_NULLS, QUOTED_IDENTIFIER ON2 GO3 ALTER Procedure creat_test_Encryption 4 AS5 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

转载地址:http://lvtwl.baihongyu.com/

你可能感兴趣的文章
零跑C-more收获更多期待,而零跑S01还在追求更多的订单 | 2019 上海车展 ...
查看>>
想成长为一名年薪50万+的实战型架构师?必掌握这7大实战技能经验
查看>>
百行征信出首招,发布授信 反欺诈 核验三款测试产品
查看>>
日志服务Python消费组实战(三):实时跨域监测多日志库数据
查看>>
操作数据库表
查看>>
王传福:电动汽车开始由政策与市场双轮驱动|电动车百人会2019
查看>>
(十四)Java springcloud B2B2C o2o多用户商城 springcloud架构- Spring Cloud构建分布式电子商务平台...
查看>>
Ansible 常用
查看>>
解决yum安装mysql时Requires: libc.so.6(GLIBC_2.17)(64bit)
查看>>
阿里云ECS云服务器规格如何选择?根据使用场景选择规格
查看>>
深入理解uwsgi和gunicorn网络模型
查看>>
Trapcode套装插件原创图文/视频安装教程
查看>>
flowable实现多实例节点的自由跳转
查看>>
算法偏见侦探
查看>>
信用体系,生态之魂!——保险科技生态建设
查看>>
彩铅,梦境
查看>>
亮风台AR眼镜震撼发布 HiAR 产品全面升级
查看>>
WPF Binding学习(三)
查看>>
File API文件操作之FileReader二
查看>>
java基础学习_GUI_如何让Netbeans的东西Eclipse能访问、GUI(图形用户接口)_day25总结...
查看>>