SqlServer存储过程/函数加/解密

来源:网络 责任编辑:栏目编辑 发表时间:2013-07-01 09:22 点击:

存储过程、存储函数的加密:WITH ENCRYPTION

<!--[if !supportLineBreakNewLine]-->
<!--[endif]-->

CREATE procedure dbo.sp_XML_main

@table_name nvarchar(260)=,

@dirname nvarchar(20)=

WITH ENCRYPTION

as

begin

....................

end

go

 

  存储过程、存储函数的解密(以下是一位绝世高人编写的代码)

 

if exists (select * from dbo.sysobjects where id = object_id(N[dbo].[sp_decrypt]) and OBJECTPROPERTY(id, NIsProcedure) = 1)

drop procedure [dbo].[sp_decrypt]

GO

/*--破解函数,过程,触发器,视图.仅限于SQLSERVER2000

--作者:J9988-- All rights reserved*/

/*--调用示例

--解密指定存储过程

exec sp_decrypt AppSP_test

--对所有的存储过程解密

declare tb cursor for

select name from sysobjects where xtype=P and status>0 and name<>sp_decrypt


declare @name sysname

open tb

fetch next from tb into @name

while @@fetch_status=0

begin

print /*-------存储过程 [+@name+] -----------*/

exec sp_decrypt @name

fetch next from tb into @name

end

close tb

deallocate tb

--*/


if exists (select * from dbo.sysobjects where id = object_id(N[dbo].[SP_DECRYPT]) and OBJECTPROPERTY(id, NIsProcedure) = 1)

drop procedure [dbo].[SP_DECRYPT]

GO

CREATE PROCEDURE sp_decrypt(@objectName varchar(50))

AS

begin

set nocount on

--破解字节不受限制,适用于SQLSERVER2000存储过程,函数,视图,触发器

--修正上一版视图触发器不能正确解密错误

begin tran

declare @objectname1 varchar(100),@orgvarbin varbinary(8000)

declare @sql1 nvarchar(4000),@sql2 varchar(8000),@sql3 nvarchar(4000),@sql4 nvarchar(4000)

DECLARE @OrigSpText1 nvarchar(4000), @OrigSpText2 nvarchar(4000) , @OrigSpText3 nvarchar(4000), @resultsp nvarchar(4000)

declare @i int,@status int,@type varchar(10),@parentid int

declare @colid int,@n int,@q int,@j int,@k int,@encrypted int,@number int

select @type=xtype,@parentid=parent_obj from sysobjects where id=object_id(@ObjectName)

 

create table #temp(number int,colid int,ctext varbinary(8000),encrypted int,status int)

insert #temp SELECT number,colid,ctext,encrypted,status FROM syscomments WHERE id = object_id(@objectName)

select @number=max(number) from #temp

set @k=0

 

while @k<=@number

begin

if exists(select 1 from syscomments where id=object_id(@objectname) and number=@k)

begin

if @type=P

set @sql1=(case when @number>1 then ALTER PROCEDURE + @objectName +;+rtrim(@k)+ WITH ENCRYPTION AS

else ALTER PROCEDURE + @objectName+ WITH ENCRYPTION AS

end)

 

if @type=TR

begin

declare @parent_obj varchar(255),@tr_parent_xtype varchar(10)

select @parent_obj=parent_obj from sysobjects where id=object_id(@objectName)

select @tr_parent_xtype=xtype from sysobjects where id=@parent_obj

if @tr_parent_xtype=V

begin

set @sql1=ALTER TRIGGER +@objectname+ ON +OBJECT_NAME(@parentid)+ WITH ENCRYPTION INSTERD OF INSERT AS PRINT 1

end

else

begin

set @sql1=ALTER TRIGGER +@objectname+ ON +OBJECT_NAME(@parentid)+ WITH ENCRYPTION FOR INSERT AS PRINT 1

end

 

end

if @type=FN or @type=TF or @type=IF

set @sql1=(case @type when TF then

ALTER FUNCTION + @objectName+(@a char(1)) returns @b table(a varchar(10)) with encryption as begin insert @b select @a return end

when FN then

ALTER FUNCTION + @objectName+(@a char(1)) returns char(1) with encryption as begin return @a end

when IF then

ALTER FUNCTION + @objectName+(@a char(1)) returns table with encryption as return select @a as a

end)

 

if @type=V

set @sql1=ALTER VIEW +@objectname+ WITH ENCRYPTION AS SELECT 1 as f

 

set @q=len(@sql

    相关新闻>>

      发表评论
      请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
      用户名: 验证码:点击我更换图片
      最新评论 更多>>

      推荐热点

      • sql常见面试题
      • SQL SERVER 2005性能之跟踪
      • SQL编程(一)
      • LINUX上RMAN自动备份脚本
      • sql server面试题
      • 如何将多个SQL查询统计结果一次显示出来
      • 浅谈SQL Server中的事务日志(三)----在简单恢复模式下日志的角色
      • sql server 列转行
      • SQL小技巧系列 --- 行转列合并
      网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
      Copyright © 2008-2015 计算机技术学习交流网. 版权所有

      豫ICP备11007008号-1