易截截图软件、单文件、免安装、纯绿色、仅160KB

怎样对SQL Server 2005加密的存储过程进行解密

 SQLServer2005里使用with encryption选项创建的存储过程仍然和sqlserver2000里一样,都是使用XOR进行了的加密。和2000不一样的是,在2005的系统 表syscomments里已经查不到加密过的密文了。要查密文必须使用DAC(专用管理员连接)连接到数据库后,在系统表 sys.sysobjvalues查询,该表的列imageval存储了相应的密文。具体可以使用下面的查询:
  SELECT imageval from sys.sysobjvalues WHERE objid = object_id(@procedure) AND
  valclass = 1 AND subobjid = 1
  一 下面是解密的存储过程,具体代码如下:
  CREATE PROCEDURE dbo.sp__procedure$decrypt
  (@procedure sysname = NULL, @revfl int = 1)
  AS
  /*
  目前这个存储过程只能解密存储过程,至于解密函数、触发器、视图的存储过程本网站会进一步关注,调用形式为:
  exec dbo.sp__procedure$decrypt @procedure,0
  如果第二个参数使用1的话,会给出该存储过程的一些提示。
  */
  SET NOCOUNT ON
  IF @revfl = 1
  BEGIN
  PRINT '警告:该存储过程会删除并重建原始的存储过程。'
  PRINT ' 在运行该存储过程之前确保你的数据库有一个备份。'
  PRINT ' 该存储过程通常应该运行在产品环境的一个备份的非产品环境下。'
  PRINT ' 为了运行这个存储过程,将参数@refl的值更改为0。'
  RETURN 0
  END
  DECLARE @intProcSpace bigint, @t bigint, @maxColID smallint,@intEncrypted
  tinyint,@procNameLength int
  select @maxColID = max(subobjid),@intEncrypted = imageval from
  sys.sysobjvalues WHERE objid = object_id(@procedure)
  GROUP BY imageval
  --select @maxColID as 'Rows in sys.sysobjvalues'
  select @procNameLength = datalength(@procedure) + 29
  DECLARE @real_01 nvarchar(max)
  DECLARE @fake_01 nvarchar(max)
  DECLARE @fake_encrypt_01 nvarchar(max)
  DECLARE @real_decrypt_01 nvarchar(max),@real_decrypt_01a nvarchar(max)
  select @real_decrypt_01a = ''
  -- 从sys.sysobjvalues里提出加密的imageval记录
  SET @real_01=(SELECT imageval from sys.sysobjvalues WHERE objid =
  object_id(@procedure) and valclass = 1 and subobjid = 1 )
  --创建一个临时表
  create table #output ( [ident] [int] ID


相关文档:

ORACLEPL/SQL基础

 ORACLEPL/SQL基础--游标的学习来源:
    游标字面理解就是游动的光标。
    用数据库语言来描述:游标是映射在结果集中一行数据上的位置实体,有了游标用户就可以访问结果集中的任意一行数据了,将游标放置到某行后,即可对该行数据进行操作,例如提取当前行的数据等等。
  ......

Java数据库包java.sql.*详解(jdk1.6)

1:应用程序不再需要使用 Class.forName() 显式地加载 JDBC 驱动程序。当前使用 Class.forName() 加载 JDBC 驱动程序的现有程序将在不作修改的情况下继续工作。
2:需要注意以下命令:
executeUpdate:是最基础的数据库的更新、插入和删除操作。效率低下。   
executeQuery:是最基础的执行查询语句,同样 ......

Oracle的SQL*PLUS命令的使用大全

 Oracle的sql*plus是与oracle进行交互的客户端工具。在sql*plus中,可以运行sql*plus命令与sql*plus语句。
  
  我们通常所说的DML、DDL、DCL语句都是sql*plus语句,它们执行完后,都可以保存在一个被称为sql buffer的内存区域中,并且只能保存一条最近执行的sql语句,我们可以对保存在sql buffer中的sql 语句进 ......

SQL面试

1.一道SQL语句面试题,关于group by
表内容:
2005-05-09 胜
2005-05-09 胜
2005-05-09 负
2005-05-09 负
2005-05-10 胜
2005-05-10 负
2005-05-10 负
如果要生成下列结果, 该如何写sql语句?
            胜 负
2005-05-09 2 2
2005-05-10 ......

SQL数据库设计技巧浅谈

数据库设计经验谈
 
一个成功的管理系统,是由:[50% 的业务 + 50% 的软件] 所组成,而 50% 的成功软件又有 [25% 的数据库 + 25% 的程序] 所组成,数据库设计的好坏是一个关键。如果把企业的数据比做生命所必需的血液,那么数据库的设计就是应用中最重要的一部分。有关数据库设计的材料汗牛充栋,大学学位课程里也有 ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号