Jump to content

Recommended Posts

Posted (edited)

I had created login form and this form first goes to de-crypting file that encrypted then read the saved credentials by de-cryptied file, but doesn't work properly!

I want just read encrypted data without saving de-crypted file, just read! 

#NoTrayIcon
#include <Crypt.au3>
#include <FileConstants.au3>
#include <MsgBoxConstants.au3>
#include <ButtonConstants.au3>
#include <EditConstants.au3>
#include <GUIConstantsEx.au3>
#include <StaticConstants.au3>
#include <WindowsConstants.au3>
;==================================Variables===================================
   ;Encryption settings
   _Crypt_Startup()
   $PEK = _Crypt_DeriveKey("BS#Password", $CALG_AES_256, $CALG_SHA_512)
   $DefaultCredFile = "[Credentials]" & @CRLF & "BUsername=NoAdmin" & @CRLF & "BPassword=NoAdmin" & @CRLF & "[Process]" & @CRLF & "ProcessKillingTimeout=3600"
   $EncryptDefaultCred = _Crypt_EncryptData($DefaultCredFile, $PEK, $CALG_AES_256)
   $IniReadCredPassword = IniRead(@WindowsDir & "\Config\GUIDecCred.dat", "Credentials", "BPassword", "")
   $IniReadCredUsername = IniRead(@WindowsDir & "\Config\GUIDecCred.dat", "Credentials", "BUsername", "")
;==================================Variables===================================

AuthForm()
Func AuthForm()
Global $LoginForm = GUICreate("Login", 201, 161, -1, -1)
Global $CloseBTN = GUICtrlCreateButton("Close", 23, 126, 75, 25)
Global $SignInBTN = GUICtrlCreateButton("Sign-in", 103, 126, 75, 25)
GUICtrlSetFont(-1, 8, 800, 0, "MS Sans Serif")
Global $PasswordInput = GUICtrlCreateInput("admin", 8, 88, 185, 21, BitOR($GUI_SS_DEFAULT_INPUT,$ES_CENTER,$ES_PASSWORD))
Global $UsernameInput = GUICtrlCreateInput("admin", 8, 40, 185, 21, BitOR($GUI_SS_DEFAULT_INPUT,$ES_CENTER))
Global $UsernameLBL = GUICtrlCreateLabel("Username:", 8, 21, 55, 17)
Global $PasswordLBL = GUICtrlCreateLabel("Password:", 8, 68, 53, 17)
GUISetState(@SW_SHOW)

While 1
    $nMsg = GUIGetMsg()
    Switch $nMsg
         Case $GUI_EVENT_CLOSE
            Exit
         Case $SignInBTN
            AuthProcess()
    EndSwitch
WEnd
EndFunc

AuthProcess()
Func AuthProcess()

   $ReadEnteredUsername = GUICtrlRead($UsernameInput)
   $ReadEnteredPassword = GUICtrlRead($PasswordInput)

   If Not FileExists(@WindowsDir & "\Config\GUIEncCred.dat") Then
      FileDelete(@WindowsDir & "\Config\GUIDecCred.dat") ;Delete previous de-crypted credentials
      FileWrite(@WindowsDir & "\Config\GUIEncCred.dat", $EncryptDefaultCred) ;Write en-crypted credentials as "*.dat" file
      FileClose(@WindowsDir & "\Config\GUIEncCred.dat") ;Close en-crypted credentials file
      _Crypt_DecryptFile(@WindowsDir & "\Config\GUIEncCred.dat", @WindowsDir & "\Config\GUIDecCred.dat", $PEK, $CALG_AES_256) ;Write de-crypted file from an en-crypted file as "*.dat" file
   Else
      _Crypt_DecryptFile(@WindowsDir & "\Config\GUIEncCred.dat", @WindowsDir & "\Config\GUIDecCred.dat", $PEK, $CALG_AES_256) ;Write de-crypted file from an en-crypted file as "*.dat" file
   EndIf

   Sleep(25)

   If $ReadEnteredUsername == $IniReadCredUsername And $ReadEnteredPassword == $IniReadCredPassword Then ;Username and Password verify stage
      MsgBox(64, "", "Welcome!")
      FileDelete(@WindowsDir & "\Config\GUIDecCred.dat")
      Exit
   Else
      MsgBox(14, "", "Incorrect!")
      FileDelete(@WindowsDir & "\Config\GUIDecCred.dat")
      Sleep(25)
   EndIf

EndFunc

How Can i? 

Edited by Colduction
Posted

Do you know encrytion secret key?
Do you know which encryption algorithm was used?

Signature beginning:
Please remember: "AutoIt"..... *  Wondering who uses AutoIt and what it can be used for ? * Forum Rules *
ADO.au3 UDF * POP3.au3 UDF * XML.au3 UDF * IE on Windows 11 * How to ask ChatGPT for AutoIt Codefor other useful stuff click the following button:

  Reveal hidden contents

Signature last update: 2023-04-24

Posted (edited)
  On 3/13/2019 at 11:46 PM, mLipok said:

Do you know encrytion secret key?
Do you know which encryption algorithm was used?

Expand  

Yeah

See this topic's content

I have written 

   $PEK = _Crypt_DeriveKey("BS#Password", $CALG_AES_256, $CALG_SHA_512)
   $DefaultCredFile = "[Credentials]" & @CRLF & "BUsername=NoAdmin" & @CRLF & "BPassword=NoAdmin" & @CRLF & "[Process]" & @CRLF & "ProcessKillingTimeout=3600"
   $EncryptDefaultCred = _Crypt_EncryptData($DefaultCredFile, $PEK, $CALG_AES_256)
Edited by Colduction
Posted (edited)

Store the file into a variable using FileRead and pass that $sData to the function _Crypt_DecryptData ( $vData, $vCryptKey, $iAlgID [, $bFinal = True] )

 

you might need to open the file first with FileOpen and open it as $FO_BINARY

 

PS. you won't be able to use IniRead on the resulting data so you'll need another way to parse your data

 

Edited by Bilgus
Posted
  On 3/14/2019 at 2:37 AM, Bilgus said:

Store the file into a variable using FileRead and pass that $sData to the function _Crypt_DecryptData ( $vData, $vCryptKey, $iAlgID [, $bFinal = True] )

 

you might need to open the file first with FileOpen and open it as $FO_BINARY

 

PS. you won't be able to use IniRead on the resulting data so you'll need another way to parse your data

 

Expand  

Is not there any way to Read results by IniRead? 😢

Because i want to retrieve informations from INI file

Posted

Well which do you want to read from an ini file or a decrypted file that is no longer stored on disk?

I don't see any other way to do it... 

It really isn't that hard to parse the data for an Ini using string functions

Your other option could be to pull out the sensitive data and then write the INI if you are really set on the INI format

Posted

The easiest way to do it would be to use a normal INI file, and then encrypt the whole file instead of just the entries in it.

If I posted any code, assume that code was written using the latest release version unless stated otherwise. Also, if it doesn't work on XP I can't help with that because I don't have access to XP, and I'm not going to.
Give a programmer the correct code and he can do his work for a day. Teach a programmer to debug and he can do his work for a lifetime - by Chirag Gude
How to ask questions the smart way!

  Reveal hidden contents

I hereby grant any person the right to use any code I post, that I am the original author of, on the autoitscript.com forums, unless I've specifically stated otherwise in the code or the thread post. If you do use my code all I ask, as a courtesy, is to make note of where you got it from.

Back up and restore Windows user files _Array.au3 - Modified array functions that include support for 2D arrays.  -  ColorChooser - An add-on for SciTE that pops up a color dialog so you can select and paste a color code into a script.  -  Customizable Splashscreen GUI w/Progress Bar - Create a custom "splash screen" GUI with a progress bar and custom label.  -  _FileGetProperty - Retrieve the properties of a file  -  SciTE Toolbar - A toolbar demo for use with the SciTE editor  -  GUIRegisterMsg demo - Demo script to show how to use the Windows messages to interact with controls and your GUI.  -   Latin Square password generator

Posted
  On 3/14/2019 at 11:06 PM, Bilgus said:

Well which do you want to read from an ini file or a decrypted file that is no longer stored on disk?

I don't see any other way to do it... 

It really isn't that hard to parse the data for an Ini using string functions

Your other option could be to pull out the sensitive data and then write the INI if you are really set on the INI format

Expand  

No, i just want decrypt datas from encrypted INI file without saving...

 

Posted

if you want the data to stay encrypted why can't you just encrypt the data prior to iniWrite and decrypt with iniRead?

;Pseudo Code
Local $Data = _Crypt_EncryptData("PA55W0RD", $g_hKey, $CALG_USERKEY) 
IniWrite ( "filename", "Test", "supersecretkey", $Data )

Local $Decrypted = _Crypt_DecryptData(IniRead ( "filename", "Test", "supersecretkey", "0" ), $g_hKey, $CALG_USERKEY) ; Decrypt the text with the new cryptographic key.

Local $ReadData = BinaryToString($Decrypted)

 

Posted
  On 3/15/2019 at 8:23 PM, Bilgus said:

if you want the data to stay encrypted why can't you just encrypt the data prior to iniWrite and decrypt with iniRead?

;Pseudo Code
Local $Data = _Crypt_EncryptData("PA55W0RD", $g_hKey, $CALG_USERKEY) 
IniWrite ( "filename", "Test", "supersecretkey", $Data )

Local $Decrypted = _Crypt_DecryptData(IniRead ( "filename", "Test", "supersecretkey", "0" ), $g_hKey, $CALG_USERKEY) ; Decrypt the text with the new cryptographic key.

Local $ReadData = BinaryToString($Decrypted)

 

Expand  

Thanks bro❤️❤️

This code is the only way to solve my problem

You were always help me, thanks bro❤️❤️

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
×
×
  • Create New...