Lazarus
Home
Help
TinyPortal
Search
Login
Register
Lazarus
»
Forum
»
Programming
»
Networking and Web Programming
»
AES-128 ECB decrypt example
Free Pascal
Website
Downloads
Wiki
Documentation
Bugtracker
Mailing List
Lazarus
Website
Downloads (Laz+FPC)
Packages (OPM)
FAQ
Wiki
Documentation (RTL/FCL/LCL)
Bugtracker
CCR Bugs
IRC channel
GIT
Mailing List
Other languages
Foundation
Website
Useful Wiki Links
Project Roadmap
Getting the Source
Screenshots
How to use the forum
About donations (wiki)
Bookstore
Computer Math and Games in Pascal
(preview)
Lazarus Handbook
Search
Advanced search
Recent
Lazarus features in a non...
by
Lutz Mändle
[
Today
at 05:26:34 pm]
what's difference between...
by
egsuh
[
Today
at 05:24:24 pm]
Compile/Convert Delphi pr...
by
Joseph
[
Today
at 05:17:16 pm]
Lazarus for Windows on aa...
by
msintle
[
Today
at 05:03:57 pm]
splitting an image
by
Thaddy
[
Today
at 04:52:43 pm]
AI, NLP and CAI: Text Gen...
by
indydev
[
Today
at 04:51:00 pm]
Drawing grid lines on a t...
by
KodeZwerg
[
Today
at 04:30:06 pm]
Parameter passing odditie...
by
KodeZwerg
[
Today
at 03:41:49 pm]
How to: create DLL file f...
by
KodeZwerg
[
Today
at 03:24:20 pm]
Web Applications with Pas...
by
Nate897
[
Today
at 03:17:43 pm]
Surf Units in Text Mode I...
by
mosquito
[
Today
at 01:58:21 pm]
Ho Ho Ho IntraWeb in Laza...
by
Thaddy
[
Today
at 01:55:52 pm]
Generics - correct syntax
by
Thaddy
[
Today
at 01:48:32 pm]
FpDebug questions
by
440bx
[
Today
at 01:22:53 pm]
leetcode doesn’t support ...
by
codeninja
[
Today
at 01:16:43 pm]
Can function be used for ...
by
Joanna
[
Today
at 12:48:19 pm]
Access violation when ope...
by
Чебурашка
[
Today
at 12:14:30 pm]
Access violation when re-...
by
Chris Osborne
[
Today
at 11:43:49 am]
how to tweek fpmake to co...
by
marcov
[
Today
at 10:35:11 am]
Why isn't TTIRadioGroup's...
by
egsuh
[
Today
at 08:09:35 am]
(Solved) TIndexedAVLTree ...
by
lainz
[April 23, 2024, 10:49:03 pm]
Demo Scene Picture sinwav...
by
KodeZwerg
[April 23, 2024, 10:26:21 pm]
fkInternalCalc
by
zraja
[April 23, 2024, 09:31:07 pm]
A fairly simple sound sol...
by
KodeZwerg
[April 23, 2024, 09:23:37 pm]
add new targets to make
by
marcov
[April 23, 2024, 08:38:42 pm]
« previous
next »
Print
Pages: [
1
]
Author
Topic: AES-128 ECB decrypt example (Read 1818 times)
CC
Full Member
Posts: 149
AES-128 ECB decrypt example
«
on:
January 29, 2021, 02:27:27 am »
Hi,
as the title says it.
I have looked around but I could not find anything truly useful.
Logged
lainz
Hero Member
Posts: 4473
Re: AES-128 ECB decrypt example
«
Reply #1 on:
January 29, 2021, 03:53:02 am »
In other words Rijndael.
https://wiki.freepascal.org/DCPcrypt
Check that package, it has useful demos.
Logged
https://lainz.github.io/
trev
Global Moderator
Hero Member
Posts: 2023
Former Delphi 1-7, 10.2 user
Re: AES-128 ECB decrypt example
«
Reply #2 on:
January 29, 2021, 03:54:50 am »
You didn't look very far...
this post
for example.
Logged
CC
Full Member
Posts: 149
Re: AES-128 ECB decrypt example
«
Reply #3 on:
January 29, 2021, 12:31:55 pm »
I have spent quite a few hours on this before asking and I did find the exact links provided here. Just figured that copy-pasting an example would be the least time consuming help. Faster then looking at my code. But here it is anyway. I know the format the result should be, but it currently is gibberish.
The input length is 87.
Code: Pascal
[Select]
[+]
[-]
function
TForm1
.
AES128_ECB_Decrypt
(
AString
,
aKey
:
string
)
:
string
;
var
inData
:
TBytes
;
outData
:
TBytes
;
StreamSize
:
Int64
;
KeySizeInBytes
,
BlockSize
:
integer
;
inStream
,
outStream
:
TStringStream
;
//inStream
begin
inStream
:
=
TStringStream
.
Create
(
AString
)
;
StreamSize
:
=
inStream
.
Size
;
outStream
:
=
TStringStream
.
Create
;
try
KeySizeInBytes
:
=
16
;
BlockSize
:
=
KeySizeInBytes
;
SetLength
(
inData
,
BlockSize
)
;
SetLength
(
outData
,
BlockSize
)
;
//AES_Cipher := TDCP_rijndael.Create(nil); // already exists
AES_Cipher
.
Init
(
aKey
,
128
,
nil
)
;
While
StreamSize >
0
do
begin
inStream
.
ReadBuffer
(
inData
[
0
]
,
BlockSize
)
;
AES_Cipher
.
DecryptECB
(
inData
[
0
]
,
outData
[
0
]
)
;
outStream
.
WriteBuffer
(
outData
[
0
]
,
BlockSize
)
;
Log
(
inData
)
;
Log
(
outData
)
;
Dec
(
StreamSize
,
BlockSize
)
;
if
StreamSize < KeySizeInBytes
then
// Last block less then key size
begin
BlockSize
:
=
StreamSize
;
SetLength
(
inData
,
BlockSize
)
;
SetLength
(
outData
,
BlockSize
)
;
end
;
end
;
result
:
=
outStream
.
DataString
;
finally
inStream
.
Free
;
outStream
.
Free
;
end
;
end
;
Result:
Quote
??M??.?I???RM?4?(%?=?6????ro?Id??m
??)\??
NO[??5??.????܊??r>?wxլ?k
«
Last Edit: January 29, 2021, 01:10:13 pm by CC
»
Logged
CC
Full Member
Posts: 149
Re: AES-128 ECB decrypt example
«
Reply #4 on:
January 29, 2021, 08:17:45 pm »
I still do not see what is wrong with the above code, but I got it working with mORMot lib SynCrypto.TAESECB.
It is higher level solution, only few lines of code to use it. Base64 decoding may be necessary first though.
«
Last Edit: January 29, 2021, 11:25:08 pm by CC
»
Logged
Print
Pages: [
1
]
« previous
next »
Lazarus
»
Forum
»
Programming
»
Networking and Web Programming
»
AES-128 ECB decrypt example
TinyPortal
© 2005-2018