SQL2005 存储过程解密方法
SQL2005 存储过程解密方法,需要的朋友可以参考下。
一 什么是DACSQL Server 2005 为管理员提供了一种特殊的诊断连接,以供在无法与服务器建立标准连接时使用。即使在 SQL Server 不响应标准连接请求时,管理员也可以使用这种连接访问 SQL Server,以便执行诊断查询并解决问题。命令行界面 (sqlcmd) 通过使用特殊的管理员开关 (-A),提供并支持这种专用管理员连接 (DAC)。
二如何使用DAC登录到服务器
1 本机DAC登录
命令行方式下执行 sqlcmd -A -S sql服务器名
2 远程DAC登录
1) 打开远程DAC选项
'程序'->'Sql Server2005'-> '配置工具'-> 'Sql Server 外围应用配置器'-> '功能的外围应用配置器'-> 'DataBase Engine'-> 'DAC' -> '启用远程DAC'
2) 登录到远程服务器
sqlcmd -A -S 192.168.0.1 -U sa -P 123456
3 登录后, 可以通过查询动态管理视图来诊断问题
1.使用 DAC 与服务器连接
在 SQL Server Management Studio 中,不打开其他 DAC,单击工具栏上的“数据库引擎查询”。
在“连接到数据库引擎”对话框的“服务器名称”框中,键入 ADMIN:,并在其后继续键入服务器实例的名称。例如,若要连接到名为 ACCT\PAYABLE 的服务器实例,请键入 ADMIN:ACCT\PAYABLE。
完成“身份验证”部分(提供 sysadmin 组成员的凭据),然后单击“连接”。将建立连接。
2.DAC设置可以连接,
0 - 指明仅允许本地连接使用 DAC
1 - 指明允许远程连接使用 DAC
sp_configure 'remote admin connections', 1;
GO
RECONFIGURE;
GO
在STUDIO DAC模试下执行或在sqlcmd -A -o c:\1.txt模式下执行,输出文件
代码如下:
DECLARE @return_value int
EXEC @return_value = [dbo].[sp_undecrypt]
@procedure = testencry,
@revfl = 0
SELECT 'Return Value' = @return_value
GO
解密存储过程如下:
代码如下:
1 Create PROCEDURE [dbo].[sp_undecrypt]
2 (@procedure sysname = NULL, @revfl int = 1)
3 AS
4 /**//*
5 王成辉翻译整理,转贴请注明出自微软BI开拓者www.windbi.com
6 调用形式为:
7 exec dbo.sp__windbi$decrypt @procedure,0
8 如果第二个参数使用1的话,会给出该存储过程的一些提示。
9 --版本4.0 修正存储过程过长解密出来是空白的问题
*/
SET NOCOUNT ON
IF @revfl = 1
BEGIN
PRINT '警告:该存储过程会删除并重建原始的存储过程。'
PRINT ' 在运行该存储过程之前确保你的数据库有一个备份。'
PRINT ' 该存储过程通常应该运行在产品环境的一个备份的非产品环境下。'
PRINT ' 为了运行这个存储过程,将参数@refl的值更改为0。'
RETURN 0
END
DECLARE @intProcSpace bigint, @t bigint, @maxColID smallint,@procNameLength int
select @maxColID = max(subobjid) FROM
sys.sysobjvalues WHERE objid = object_id(@procedure)
--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)
declare @objtype varchar(2),@ParentName nvarchar(max)
select @real_decrypt_01a = ''
--提取对象的类型如是存储过程还是函数,如果是触发器,还要得到其父对象的名称
select @objtype=type,@parentname=object_name(parent_object_id)
from sys.objects where [object_id]=object_id(@procedure)
-- 从sys.sysobjvalues里提出加密的imageval记录
SET @real_01=(SELECT top 1 imageval FROM sys.sysobjvalues WHERE objid =
object_id(@procedure) and valclass = 1 order by subobjid)
--创建一个临时表
create table #output ( [ident] [int] IDENTITY (1, 1) NOT NULL ,
[real_decrypt] NVARCHAR(MAX) )
--开始一个事务,稍后回滚
BEGIN TRAN
--更改原始的存储过程,用短横线替换
if @objtype='P'
SET @fake_01='ALTER PROCEDURE '+ @procedure +' WITH ENCRYPTION AS select 1
/**//*'+REPLICATE(cast('*'as nvarchar(max)), datalength(@real_01) /2 - @procNameLength)+'*/'
else if @objtype='FN'
SET @fake_01='ALTER FUNCTION '+ @procedure +'() RETURNS INT WITH ENCRYPTION AS BEGIN RETURN 1
/**//*'+REPLICATE(cast('*'as nvarchar(max)), datalength(@real_01) /2 - @procNameLength)+'*/ END'
else if @objtype='V'
SET @fake_01='ALTER view '+ @procedure +' WITH ENCRYPTION AS select 1 as col
/**//*'+REPLICATE(cast('*'as nvarchar(max)), datalength(@real_01) /2 - @procNameLength)+'*/'
else if @objtype='TR'
SET @fake_01='ALTER trigger '+ @procedure +' ON '+@parentname+'WITH ENCRYPTION AFTER INSERT AS RAISERROR (''N'',16,10)
/**//*'+REPLICATE(cast('*'as nvarchar(max)), datalength(@real_01) /2 - @procNameLength)+'*/'
EXECUTE (@fake_01)
--从sys.sysobjvalues里提出加密的假的
SET @fake_encrypt_01=(SELECT top 1 imageval FROM sys.sysobjvalues WHERE objid =
object_id(@procedure) and valclass = 1 order by subobjid )
if @objtype='P'
SET @fake_01='Create PROCEDURE '+ @procedure +' WITH ENCRYPTION AS select 1
/**//*'+REPLICATE(cast('*'as nvarchar(max)), datalength(@real_01) /2 - @procNameLength)+'*/'
else if @objtype='FN'
SET @fake_01='CREATE FUNCTION '+ @procedure +'() RETURNS INT WITH ENCRYPTION AS BEGIN RETURN 1
/**//*'+REPLICATE(cast('*'as nvarchar(max)), datalength(@real_01) /2 - @procNameLength)+'*/ END'
else if @objtype='V'
SET @fake_01='Create view '+ @procedure +' WITH ENCRYPTION AS select 1 as col
/**//*'+REPLICATE(cast('*'as nvarchar(max)), datalength(@real_01) /2 - @procNameLength)+'*/'
else if @objtype='TR'
SET @fake_01='Create trigger '+ @procedure +' ON '+@parentname+'WITH ENCRYPTION AFTER INSERT AS RAISERROR (''N'',16,10)
/**//*'+REPLICATE(cast('*'as nvarchar(max)), datalength(@real_01) /2 - @procNameLength)+'*/'
--开始计数
SET @intProcSpace=1
--使用字符填充临时变量
SET @real_decrypt_01 = replicate(cast('A'as nvarchar(max)), (datalength(@real_01) /2 ))
--循环设置每一个变量,创建真正的变量
--每次一个字节
SET @intProcSpace=1
--如有必要,遍历每个@real_xx变量并解密
WHILE @intProcSpaceBEGIN
--真的和假的和加密的假的进行异或处理
SET @real_decrypt_01 = stuff(@real_decrypt_01, @intProcSpace, 1,
NCHAR(UNICODE(substring(@real_01, @intProcSpace, 1)) ^
(UNICODE(substring(@fake_01, @intProcSpace, 1)) ^
UNICODE(substring(@fake_encrypt_01, @intProcSpace, 1)))))
SET @intProcSpace=@intProcSpace+1
END
--通过sp_helptext逻辑向表#output里插入变量
insert #output (real_decrypt) select @real_decrypt_01
--select real_decrypt AS '#output chek' from #output --测试
-- -------------------------------------
--开始从sp_helptext提取
-- -------------------------------------
declare @dbname sysname
,@BlankSpaceAdded int
,@BasePos int
,@CurrentPos int
,@TextLength int
,@LineId int
,@AddOnLen int
,@LFCR int --回车换行的长度
,@DefinedLength int
,@SyscomText nvarchar(max)
,@Line nvarchar(255)
Select @DefinedLength = 255
SELECT @BlankSpaceAdded = 0 --跟踪行结束的空格。注意Len函数忽略了多余的空格
CREATE TABLE #CommentText
(LineId int
,Text nvarchar(255) collate database_default)
--使用#output代替sys.sysobjvalues
DECLARE ms_crs_syscom CURSOR LOCAL
FOR SELECT real_decrypt from #output
ORDER BY ident
FOR READ ONLY
--获取文本
SELECT @LFCR = 2
SELECT @LineId = 1
OPEN ms_crs_syscom
FETCH NEXT FROM ms_crs_syscom into @SyscomText
WHILE @@fetch_status >= 0
BEGIN
SELECT @BasePos = 1
SELECT @CurrentPos = 1
SELECT @TextLength = LEN(@SyscomText)
WHILE @CurrentPos != 0
BEGIN
--通过回车查找行的结束
SELECT @CurrentPos = CHARINDEX(char(13)+char(10), @SyscomText,
@BasePos)
--如果找到回车
IF @CurrentPos != 0
BEGIN
--如果@Lines的长度的新值比设置的大就插入@Lines目前的内容并继续
While (isnull(LEN(@Line),0) + @BlankSpaceAdded +
@CurrentPos-@BasePos + @LFCR) > @DefinedLength
BEGIN
SELECT @AddOnLen = @DefinedLength-(isnull(LEN(@Line),0) +
@BlankSpaceAdded)
INSERT #CommentText VALUES
( @LineId,
isnull(@Line, N'') + isnull(SUBSTRING(@SyscomText,
@BasePos, @AddOnLen), N''))
SELECT @Line = NULL, @LineId = @LineId + 1,
@BasePos = @BasePos + @AddOnLen, @BlankSpaceAdded = 0
END
SELECT @Line = isnull(@Line, N'') +
isnull(SUBSTRING(@SyscomText, @BasePos, @CurrentPos-@BasePos + @LFCR), N'')
SELECT @BasePos = @CurrentPos+2
INSERT #CommentText VALUES( @LineId, @Line )
SELECT @LineId = @LineId + 1
SELECT @Line = NULL
END
ELSE
--如果回车没找到
BEGIN
IF @BasePos BEGIN
--如果@Lines长度的新值大于定义的长度
While (isnull(LEN(@Line),0) + @BlankSpaceAdded +
@TextLength-@BasePos+1 ) > @DefinedLength
BEGIN
SELECT @AddOnLen = @DefinedLength -
(isnull(LEN(@Line),0) + @BlankSpaceAdded)
INSERT #CommentText VALUES
( @LineId,
isnull(@Line, N'') + isnull(SUBSTRING(@SyscomText,
@BasePos, @AddOnLen), N''))
SELECT @Line = NULL, @LineId = @LineId + 1,
@BasePos = @BasePos + @AddOnLen, @BlankSpaceAdded =
0
END
SELECT @Line = isnull(@Line, N'') +
isnull(SUBSTRING(@SyscomText, @BasePos, @TextLength-@BasePos+1 ), N'')
if LEN(@Line) @SyscomText, @TextLength+1 ) > 0
BEGIN
SELECT @Line = @Line + ' ', @BlankSpaceAdded = 1
END
END
END
END
FETCH NEXT FROM ms_crs_syscom into @SyscomText
END
IF @Line is NOT NULL
INSERT #CommentText VALUES( @LineId, @Line )
select Text from #CommentText order by LineId
CLOSE ms_crs_syscom
DEALLOCATE ms_crs_syscom
DROP TABLE #CommentText
-- -------------------------------------
--结束从sp_helptext提取
-- -------------------------------------
--删除用短横线创建的存储过程并重建原始的存储过程
ROLLBACK TRAN
DROP TABLE #output

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











HTTP 상태 코드 460 해독: 이 오류가 발생하는 이유는 무엇입니까? 소개: 일상적인 네트워크 사용 중에 HTTP 상태 코드를 포함한 다양한 오류 메시지가 나타나는 경우가 많습니다. 이러한 상태 코드는 요청 처리를 나타내기 위해 HTTP 프로토콜에 의해 정의된 메커니즘입니다. 이러한 상태 코드 중에는 비교적 드문 오류 코드, 즉 460이 있습니다. 이 문서에서는 이 오류 코드를 자세히 살펴보고 이 오류가 발생하는 이유를 설명합니다. HTTP 상태 코드 460의 정의: 먼저 HTTP 상태 코드의 기본을 이해해야 합니다.

제목: Oracle 저장 프로시저에 의한 일괄 업데이트 구현을 위한 단계 및 주의 사항 Oracle 데이터베이스에서 저장 프로시저는 데이터베이스 성능을 향상하고 코드를 재사용하며 보안을 강화하기 위해 설계된 SQL 문 집합입니다. 저장 프로시저는 데이터를 일괄 업데이트하는 데 사용할 수 있습니다. 이 문서에서는 Oracle 저장 프로시저를 사용하여 일괄 업데이트를 구현하고 특정 코드 예제를 제공하는 방법을 소개합니다. 1단계: 저장 프로시저 만들기 먼저 일괄 업데이트 작업을 구현하기 위한 저장 프로시저를 만들어야 합니다. 저장 프로시저를 생성하는 방법은 다음과 같습니다.

저장 프로시저를 삭제하는 MySQL 방법에는 DROP PROCEDURE 문 사용, MySQL Workbench 사용 및 명령줄 도구 사용이 포함됩니다. 자세한 소개: 1. DROP PROCEDURE 문 사용 단계는 먼저 MySQL 클라이언트를 열거나 MySQL을 지원하는 도구를 사용한 다음 MySQL 데이터베이스에 연결하고 마지막으로 다음 SQL 문을 실행하여 저장 프로시저를 삭제하는 것입니다. MySQL Workbench를 사용하여 저장 프로시저 등을 삭제합니다.

Oracle 데이터베이스의 저장 프로시저는 데이터베이스에서 일련의 SQL 문과 데이터 작업을 실행하는 데 사용되는 특정 유형의 저장 프로시저입니다. 실제 데이터베이스 개발 작업에서는 저장 프로세스에서 판단과 논리적 처리를 수행하기 위해 데이터베이스에 특정 테이블이 존재하는지 확인해야 하는 경우가 있습니다. 아래에서는 Oracle 데이터베이스에 테이블이 존재하는지 확인하는 방법을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 먼저 시스템 테이블 user_tables 또는 all_t를 사용할 수 있습니다.

오늘날의 업무 환경에서는 모든 사람의 기밀성에 대한 인식이 점점 더 강해지고 있으며, 소프트웨어 사용 시 파일을 보호하기 위해 암호화 작업을 수행하는 경우가 많습니다. 특히 핵심문서에 대해서는 비밀유지의식을 높이고 문서의 보안을 항상 최우선으로 삼아야 한다. 그래서 모두가 단어 해독을 얼마나 잘 이해하고 있는지 모르겠습니다. 구체적으로 어떻게 작동합니까? 오늘은 아래 설명을 통해 실제로 단어암호화 과정을 보여드리겠습니다. 단어암호화 지식이 필요한 친구들은 오늘 강좌를 놓치지 마세요. 파일을 보호하려면 먼저 복호화 작업이 필요합니다. 이는 파일이 문서로 보호된다는 의미입니다. 파일에 이 작업을 수행한 후 파일을 다시 열면 프롬프트가 나타납니다. 파일을 복호화하는 방법은 비밀번호를 입력하는 것이므로 직접 복호화할 수 있습니다.

ThinkPHP6 데이터 암호화 및 복호화: 민감한 데이터 보안 보호 개요: 인터넷의 급속한 발전으로 인해 데이터 보안 문제가 점점 더 중요해지고 있습니다. 특히 네트워크 애플리케이션 개발에서는 일부 민감한 데이터를 보호하는 것이 중요합니다. ThinkPHP6 프레임워크는 중요한 데이터를 암호화하여 데이터 보안을 효과적으로 향상시킬 수 있는 강력한 데이터 암호화 및 암호 해독 메커니즘을 제공합니다. ThinkPHP6의 암호화 기능 사용 ThinkPHP6 프레임워크에는 필요에 따라 사용할 수 있는 다양한 암호화 기능이 내장되어 있습니다.

공개된 Java 개발 기술: 데이터 암호화 및 복호화 기능 구현 현재 정보화 시대에 데이터 보안은 매우 중요한 문제가 되었습니다. 민감한 데이터의 보안을 보호하기 위해 많은 애플리케이션에서는 암호화 알고리즘을 사용하여 데이터를 암호화합니다. 매우 널리 사용되는 프로그래밍 언어인 Java는 풍부한 암호화 기술 및 도구 라이브러리도 제공합니다. 이 기사에서는 개발자가 데이터 보안을 더욱 효과적으로 보호할 수 있도록 Java 개발에서 데이터 암호화 및 암호 해독 기능을 구현하는 몇 가지 기술을 소개합니다. 1. 데이터 암호화 알고리즘 선택 Java는 다양한 지원

Golang 저장 프로시저의 구현 원리 및 응용 저장 프로시저는 관계형 데이터베이스에 저장되고 애플리케이션에서 호출할 수 있는 미리 컴파일된 프로그램입니다. 이는 네트워크 데이터 전송 비용을 효과적으로 줄이고 데이터베이스의 실행 효율성을 향상시킬 수 있습니다. Golang은 저장 프로시저를 직접 지원하지 않지만 SQL 문을 사용하여 저장 프로시저의 기능을 시뮬레이션할 수 있습니다. 이 기사에서는 Golang에서 저장 프로시저를 구현하는 원리와 응용 프로그램을 소개하고 구체적인 코드 예제를 제공합니다. 1. Golang 저장 프로시저의 구현 원리는 Gol에 있습니다.
