Tài liệu SQL Server 2005 – Hack dữ liệu đã mã hoá bởi mật khẩu - Pdf 97

SQL Server 2005 – Hack dữ liệu đã mã hoá bởi mật khẩu

Như bạn đã biết, mã hoá bằng mật khẩu là một phương pháp mã hoá dữ liệu cơ bản chỉ sử dụng
đến mật khẩu và có thể giải mã với cùng mật khẩu đó. Giờ hãy giả dụ chúng ta quên mất mật
khẩu đã đặt và cần phải khôi phục lại dữ liệu như ban đầu.
phần 1 của loạt bài này, chúng tôi đã giới thiệu phương pháp mã hoá và giả
i mã bằng mật
khẩu. Phần 2 này sẽ đi vào cách hack lại dữ liệu đó.

Như bạn đã biết, mã hoá bằng mật khẩu là một phương pháp mã hoá dữ liệu cơ bản chỉ sử dụng
đến mật khẩu và có thể giải mã với cùng mật khẩu đó. Giờ hãy giả dụ chúng ta quên mất mật
khẩu đã đặt và cần phải khôi phục lại dữ li
ệu như ban đầu.

Bước 1

Mã hoá dữ liệu theo phương pháp mã hoá bằng mật khẩu
select EncryptedData = EncryptByPassPhrase('MAK', '123456789' )
Kết quả
EncryptedData

0x01000000F75D553409C74570F6DDBCADA53FD489DDD52D9277010050565ADF30F244F8CC

Bước 2

Tạo thủ tục sử dụng để khôi phục lại dữ liệu đã má hoá. Thủ tục này sẽ sử dụng hàm
DecryptByPassPhrase để giải mã dữ liệu và hiển thị lên mật khẩu.
USE [Master]
GO

/****** Object: StoredProcedure [dbo].[hack_encryption] Script Date:


set @i=-1
set @j=-1
set @k=-1
set @l=-1
set @m=-1
set @n=-1
set @password =''

while @i<255
begin
while @j<255
begin
while @k<255
begin
while @l<255
begin
while @m<255
begin
while @n<=255
begin
set @password=isnull(char(@i),'')
+ isnull(char(@j),'')
+isnull(char(@k),'')+ isnull(char(@l),'')
+isnull(char(@m),'') + isnull(char(@n),'')
if convert(varchar(100), DecryptByPassPhrase(ltrim(rtrim(@password)),
@encryptedtext)) is not null
begin
print 'This is the Encrypted text:' +@password
set @i=256;set @j=256;set @k=256;set @l=256;set @m=256;set @n=256;

“0x01000000F75D553409C74570F6DDBCADA53FD489DDD52D9277010050565ADF30F244
F8CC”. Chúng ta có thể truy tìm lại được mật khẩu và dữ liệu đã bị mã hoá bằng thủ tục sau
use master
go
select getdate() as StartingTime
go
declare @myencryptedtext varbinary(max)
set
@myencryptedtext=0x01000000F75D553409C74570F6DDBCADA53FD489DDD52D927701005056
5ADF30F244F8CC
print @myencryptedtext
exec hack_encryption @encryptedtext=@myencryptedtext
go
select getdate() as EndingTime
go

Kết quả
StartingTime

2007-12-18 18:24:10.843

0x01000000F75D553409C74570F6DDBCADA53FD489DDD52D9277010050565ADF30F244F8CC
This is the Encrypted text: MAK
The actual data is :123456789

EndingTime

2007-12-18 18:26:36.080
declare @password varchar(6)
declare @i int
declare @j int
declare @k int
declare @l int
declare @m int
declare @n int set @i=-1
set @j=-1
set @k=-1
set @l=-1
set @m=-1
set @n=-1
set @password =''

while @i<255
begin
while @j<255
begin
while @k<255
begin
while @l<255
begin
while @m<255
begin
while @n<=255
begin
set @password=isnull(char(@i),'') + isnull(char(@j),'')

end

return @password
END

Bước 2

Tạo một bảng với dữ liệu được mã hoá
USE [tempdb]
GO
/****** Object: Table [dbo].[MyTable] Script Date: 12/18/2007 18:44:40
******/
IF EXISTS (SELECT * FROM sys.objects WHERE object_id =
OBJECT_ID(N'[dbo].[MyTable]') AND type in (N'U'))
DROP TABLE [dbo].[MyTable]
GO
create table MyTable(id int, encrypteddata varbinary(max))
go
insert into MyTable select 1, EncryptByPassPhrase('Do', '1112228333')
insert into MyTable select 2, EncryptByPassPhrase('Re', '1212223833')
insert into MyTable select 3, EncryptByPassPhrase('Me', '1132223393')
insert into MyTable select 4, EncryptByPassPhrase('Fa', '1114223383')
insert into MyTable select 5, EncryptByPassPhrase('So', '1112523333')
insert into MyTable select 6, EncryptByPassPhrase('La', '1112263373')
insert into MyTable select 7, EncryptByPassPhrase('Si', '1112227338')
go

Bước 3

Truy vấn dữ liệu sử dụng câu lệnh SQL sau

Hàm trên có thê được chỉnh sửa để trả về cả dữ liệu đã được mã hoá, thực hiện như sau

Bước 1

Tạo hàm sau
USE [master]
GO

/****** Object: UserDefinedFunction [dbo].[hack_encryption_password] Script
Date: 12/18/2007 18:36:29 ******/
IF EXISTS (SELECT * FROM sys.objects WHERE object_id =
OBJECT_ID(N'[dbo].[hack_encryption_data]')
AND type in (N'FN', N'IF', N'TF', N'FS', N'FT'))
DROP FUNCTION [dbo].[hack_encryption_data]
GO
use [Master]
go

CREATE function [dbo].[hack_encryption_data] (@encryptedtext varbinary(max))
returns varchar(8000)
with execute as caller
as
begin
declare @data varchar(8000)
declare @password varchar(6)
declare @i int
declare @j int
declare @k int
declare @l int
declare @m int

set @data = convert(varchar(100),
DecryptByPassPhrase(ltrim(rtrim(@password)),@encryptedtext))
end
print 'A'+ltrim(rtrim(@password))+'B'
print convert(varchar(100),
DecryptByPassPhrase(ltrim(rtrim(@password)),@encryptedtext))
set @n=@n+1
end
set @n=0
set @m=@m+1
end
set @m=0
set @l=@l+1
end
set @l=0
set @k=@k+1
end
set @k=0
set @j=@j+1
end
set @j=0
set @i=@i+1
end

return @data
END

Bước 2

Giải mã dữ liệu sử dụng hàm đã tạo


Nhờ tải bản gốc

Tài liệu, ebook tham khảo khác

Music ♫

Copyright: Tài liệu đại học © DMCA.com Protection Status