| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 912 人关注过本帖
标题:SQLserver报错的解释
只看楼主 加入收藏
9sex0
Rank: 1
等 级:新手上路
帖 子:79
专家分:0
注 册:2004-12-31
收藏
 问题点数:0 回复次数:4 
SQLserver报错的解释
我是用SA帐户进入SQLSERVER的,有最高权限.
但是我在查看存储过程的时候,报错,内容如下,请高手帮忙解释,为什么会这样?

错误 20585:[SQL-DMO]/******Encrypted object is not transferable,and script can not be generated.******/
搜索更多相关主题的帖子: SQLserver 解释 not object script 
2005-01-27 15:02
regedit
Rank: 5Rank: 5
等 级:贵宾
威 望:19
帖 子:950
专家分:0
注 册:2004-6-8
收藏
得分:0 
是加密过的存储过程!

最新作品:百货品牌商品资讯第一门户([url]http://www./[/url]),欢迎交流
2005-01-27 15:14
9sex0
Rank: 1
等 级:新手上路
帖 子:79
专家分:0
注 册:2004-12-31
收藏
得分:0 
恩,
但是有办法解密吗?
2005-01-27 16:22
9sex0
Rank: 1
等 级:新手上路
帖 子:79
专家分:0
注 册:2004-12-31
收藏
得分:0 
找到一个:但没研究究竟该怎么用
[转帖]SqlServer存储过程解密
CREATE  PROCEDURE  sp_decrypt(@objectName  varchar(50))
AS
begin
set  nocount  on
--CSDN:j9988  copyright:2004.04.15  
--V3.1  
--破解字节不受限制,适用于SQLSERVER2000存储过程,函数,视图,触发器
--修正上一版视图触发器不能正确解密错误
--发现有错,请E_MAIL:CSDNj9988@
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(@sql1)
set  @sql1=@sql1+REPLICATE('-',4000-@q)
select  @sql2=REPLICATE('-',8000)
set  @sql3='exec(@sql1'
select  @colid=max(colid)  from  #temp  where  number=@k  
set  @n=1
while  @n<=CEILING(1.0*(@colid-1)/2)  and  len(@sQL3)<=3996
begin  
set  @sql3=@sql3+'+@'
set  @n=@n+1
end
set  @sql3=@sql3+')'
exec  sp_executesql  @sql3,N'@Sql1  nvarchar(4000),@  varchar(8000)',@sql1=@sql1,@=@sql2

end
set  @k=@k+1
end

set  @k=0
while  @k<=@number  
begin

if  exists(select  1  from  syscomments  where  id=object_id(@objectname)  and  number=@k)
begin
select  @colid=max(colid)  from  #temp  where  number=@k  
set  @n=1

while  @n<=@colid
begin
select  @OrigSpText1=ctext,@encrypted=encrypted,@status=status  FROM  #temp  WHERE  colid=@n  and  number=@k

SET  @OrigSpText3=(SELECT  ctext  FROM  syscomments  WHERE  id=object_id(@objectName)  and  colid=@n  and  number=@k)
if  @n=1
begin
if  @type='P'
SET  @OrigSpText2=(case  when  @number>1  then  'CREATE  PROCEDURE  '+  @objectName  +';'+rtrim(@k)+'  WITH  ENCRYPTION  AS  '
else  'CREATE  PROCEDURE  '+  @objectName  +'  WITH  ENCRYPTION  AS  '
end)


if  @type='FN'  or  @type='TF'  or  @type='IF'
SET  @OrigSpText2=(case  @type  when  'TF'  then  
'CREATE  FUNCTION  '+  @objectName+'(@a  char(1))  returns  @b  table(a  varchar(10))  with  encryption  as  begin  insert  @b  select  @a  return  end  '
when  'FN'  then
'CREATE  FUNCTION  '+  @objectName+'(@a  char(1))  returns  char(1)  with  encryption  as  begin  return  @a  end'
when  'IF'  then
'CREATE  FUNCTION  '+  @objectName+'(@a  char(1))  returns  table  with  encryption  as  return  select  @a  as  a'
end)

if  @type='TR'  
begin

if  @tr_parent_xtype='V'
begin
set  @OrigSpText2='CREATE  TRIGGER  '+@objectname+'  ON  '+OBJECT_NAME(@parentid)+'  WITH  ENCRYPTION  INSTEAD  OF  INSERT  AS  PRINT  1  '
end
else
begin
set  @OrigSpText2='CREATE  TRIGGER  '+@objectname+'  ON  '+OBJECT_NAME(@parentid)+'  WITH  ENCRYPTION  FOR  INSERT  AS  PRINT  1  '
end

end

if  @type='V'
set  @OrigSpText2='CREATE  VIEW  '+@objectname+'  WITH  ENCRYPTION  AS  SELECT  1  as  f'

set  @q=4000-len(@OrigSpText2)
set  @OrigSpText2=@OrigSpText2+REPLICATE('-',@q)
end
else
begin
SET  @OrigSpText2=REPLICATE('-',  4000)
end
SET  @i=1

SET  @resultsp  =  replicate(N'A',  (datalength(@OrigSpText1)  /  2))

WHILE  @i<=datalength(@OrigSpText1)/2
BEGIN

SET  @resultsp  =  stuff(@resultsp,  @i,  1,  NCHAR(UNICODE(substring(@OrigSpText1,  @i,  1))  ^
(UNICODE(substring(@OrigSpText2,  @i,  1))  ^
UNICODE(substring(@OrigSpText3,  @i,  1)))))
SET  @i=@i+1
END
set  @orgvarbin=cast(@OrigSpText1  as  varbinary(8000))
set  @resultsp=(case  when  @encrypted=1  
then  @resultsp  
else  convert(nvarchar(4000),case  when  @status&2=2  then  uncompress(@orgvarbin)  else  @orgvarbin  end)
end)
print  @resultsp

set  @n=@n+1

end

end
set  @k=@k+1
end

drop  table  #temp
rollback  tran
end
2005-01-27 16:42
9sex0
Rank: 1
等 级:新手上路
帖 子:79
专家分:0
注 册:2004-12-31
收藏
得分:0 
有没有高手研究一下,再通告通告!!??
2005-01-27 16:46
快速回复:SQLserver报错的解释
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.021821 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved