trancexx Posted September 25, 2008 Share Posted September 25, 2008 (edited) I guess there is no need to explain what Base64 encoding is and what is used for.What is special about this way. Well, I did some testing and it turns that it's fast. About three times faster than the fastest way posted here on this forum (machine code implementation).It's calling functions "CryptBinaryToString" and "CryptStringToBinary" in Crypt32.dllI'm in the phase when discovering functions DllCall(), DllStructCreate(),... and related, so please be gentle to me, lolThere is no error checking mainly because of the sentence before this one. If someone is willing to add that to the code below (or correct possible mistakes), I'm willing to learn out of that. So, please do.Here's the script:Updated 29th October 2008 - error checking added and some code optimizationexpandcollapse popup$encoded = _Base64Encode("Testing") MsgBox(0, 'Base64 Encoded', $encoded) $decoded = _Base64Decode($encoded) MsgBox(0, 'Base64 Decoded - binary', $decoded) MsgBox(0, 'Base64 Decoded - string', BinaryToString($decoded)) Func _Base64Encode($input) $input = Binary($input) Local $struct = DllStructCreate("byte[" & BinaryLen($input) & "]") DllStructSetData($struct, 1, $input) Local $strc = DllStructCreate("int") Local $a_Call = DllCall("Crypt32.dll", "int", "CryptBinaryToString", _ "ptr", DllStructGetPtr($struct), _ "int", DllStructGetSize($struct), _ "int", 1, _ "ptr", 0, _ "ptr", DllStructGetPtr($strc)) If @error Or Not $a_Call[0] Then Return SetError(1, 0, "") ; error calculating the length of the buffer needed EndIf Local $a = DllStructCreate("char[" & DllStructGetData($strc, 1) & "]") $a_Call = DllCall("Crypt32.dll", "int", "CryptBinaryToString", _ "ptr", DllStructGetPtr($struct), _ "int", DllStructGetSize($struct), _ "int", 1, _ "ptr", DllStructGetPtr($a), _ "ptr", DllStructGetPtr($strc)) If @error Or Not $a_Call[0] Then Return SetError(2, 0, ""); error encoding EndIf Return DllStructGetData($a, 1) EndFunc ;==>_Base64Encode Func _Base64Decode($input_string) Local $struct = DllStructCreate("int") $a_Call = DllCall("Crypt32.dll", "int", "CryptStringToBinary", _ "str", $input_string, _ "int", 0, _ "int", 1, _ "ptr", 0, _ "ptr", DllStructGetPtr($struct, 1), _ "ptr", 0, _ "ptr", 0) If @error Or Not $a_Call[0] Then Return SetError(1, 0, "") ; error calculating the length of the buffer needed EndIf Local $a = DllStructCreate("byte[" & DllStructGetData($struct, 1) & "]") $a_Call = DllCall("Crypt32.dll", "int", "CryptStringToBinary", _ "str", $input_string, _ "int", 0, _ "int", 1, _ "ptr", DllStructGetPtr($a), _ "ptr", DllStructGetPtr($struct, 1), _ "ptr", 0, _ "ptr", 0) If @error Or Not $a_Call[0] Then Return SetError(2, 0, ""); error decoding EndIf Return DllStructGetData($a, 1) EndFunc ;==>_Base64DecodeThere is @CRLF every 64 chars in return of _Base64Encode(). _Base64Decode() will return binary data. That is intentional to avoid Chr(0) issue. Convert it to string using BinaryToString()Microsoft about requirements:Client - Requires Windows Vista or Windows XP.Server - Requires Windows Server 2008 or Windows Server 2003. Edited October 29, 2008 by trancexx Colduction, mLipok and spudw2k 2 1 ♡♡♡ . eMyvnE Link to comment Share on other sites More sharing options...
Moderators SmOke_N Posted September 25, 2008 Moderators Share Posted September 25, 2008 Ha... Nice find. Common sense plays a role in the basics of understanding AutoIt... If you're lacking in that, do us all a favor, and step away from the computer. Link to comment Share on other sites More sharing options...
mikeytown2 Posted September 26, 2008 Share Posted September 26, 2008 LOL, Nice indeed! Post some times so people get an idea of how fast it is. I bet Crypt32.dll goes back to win9x. Anyone know what other potentially useful functions are inside the dll? Email: POP3 & SMTP using SSL/TLS (OpenSSL)Email: IMAPEmail: Base64 & SMTP login & Send email direct to MX Server (thanks blindwig)Win: Hook Registry ChangesWin: Read/Write to Alternate Data Streams (ini example)Utility: GPS Distance Calculations, Vincenty and Haversine formulas; angles and elevationUtility: Dell Laser Printer (3000-5100) - Print LoggerUtility: Reset Router when Wireless Link FailsUtility: ImageMagick Batch jpg ProcessorVideo HCenc Batch FrontendVideo: *DEAD* YouTube Video Encoder (avs/avi to flv)Software On CD's I Like<<back|track3 Ultimate Boot CD for Windows SpinRite Ubuntu ophcrack Link to comment Share on other sites More sharing options...
Moderators SmOke_N Posted September 26, 2008 Moderators Share Posted September 26, 2008 LOL, Nice indeed! Post some times so people get an idea of how fast it is.I bet Crypt32.dll goes back to win9x. Anyone know what other potentially useful functions are inside the dll?http://msdn.microsoft.com/en-us/library/aa...28VS.85%29.aspx mLipok 1 Common sense plays a role in the basics of understanding AutoIt... If you're lacking in that, do us all a favor, and step away from the computer. Link to comment Share on other sites More sharing options...
trancexx Posted September 26, 2008 Author Share Posted September 26, 2008 LOL, Nice indeed! Post some times so people get an idea of how fast it is... Here are some times, but I guess to get it right more tests should be done (and not in one script because of memory allocation... thing). Three ways are compared. Output size is the number of characters in output string (not counting @CRLF) to verify results. I used older version of machine code _Base64Encode() because the new one tend to crash (Ward, do something). expandcollapse popupFile size: 0.00664329528808594 MB Encoding times: Crypt32.dll: 0.669358815156675 ms Output size: 9288 Machine code: 0.57353658076655 ms Output size: 9288 Mikeytown2, blindwig: 89.5381954969137 ms Output size: 9288 --------------------------------------------------------------------------- File size: 0.726992607116699 MB Encoding times: Crypt32.dll: 60.3733156029607 ms Output size: 1016412 Machine code: 107.127302492356 ms Output size: 1016412 Mikeytown2, blindwig: 7199.77846346393 ms Output size: 1016412 --------------------------------------------------------------------------- File size: 5.83719635009766 MB Encoding times: Crypt32.dll: 579.908060940706 ms Output size: 8160992 Machine code: 838.349008044318 ms Output size: 8160992 Mikeytown2, blindwig: 224483.446918533 ms Output size: 8160992 --------------------------------------------------------------------------- File size: 21.3670444488525 MB Encoding times: Crypt32.dll: 8545.42518672066 ms Output size: 29873296 Machine code: 17715.4873035539 ms Output size: 29873296 Mikeytown2, blindwig: ~ Difference is even bigger for larger files but that's too extreme, even to write about. btw, i got this poking dlls (out of curiosity) with this ♡♡♡ . eMyvnE Link to comment Share on other sites More sharing options...
Ward Posted September 26, 2008 Share Posted September 26, 2008 Here are some times, but I guess to get it right more tests should be done (and not in one script because of memory allocation... thing). Three ways are compared. Output size is the number of characters in output string (not counting @CRLF) to verify results. I used older version of machine code _Base64Encode() because the new one tend to crash (Ward, do something). Difference is even bigger for larger files but that's too extreme, even to write about. btw, i got this poking dlls (out of curiosity) with thisOKOK, I will fix it. The newer base64 UDF crash because the formula to count the buffer size is wrong (A stupid bug). Thank you for reminding me. However, your time trial has a little problem. In fact, you are testing the speed of disk reading, autoit string handling, garbage collection and so on. Because the speed of base64 encoding is much faster than these actions. In following code I don't set dllstruct to 0, and then it should run as fast as using crypt32.dll. BTW, a better way to encode a file into base64 is to split it and encode part by part. Handling a huge string in script language is always slow. expandcollapse popupFunc _Base64Decode($Data) Local $Opcode = "0xC81000005356578365F800E8500000003EFFFFFF3F3435363738393A3B3C3DFFFFFF00FFFFFF000102030405060708 090A0B0C0D0E0F10111213141516171819FFFFFFFFFFFF1A1B1C1D1E1F202122232425262728292A2B2C2D2E2F303132338F 45F08B7D0C8B5D0831D2E9910000008365FC00837DFC047D548A034384C0750383EA033C3D75094A803B3D75014AB00084C0 751A837DFC047D0D8B75FCC64435F400FF45FCEBED6A018F45F8EB1F3C2B72193C7A77150FB6F083EE2B0375F08A068B75FC 884435F4FF45FCEBA68D75F4668B06C0E002C0EC0408E08807668B4601C0E004C0EC0208E08847018A4602C0E00624C00A46 038847028D7F038D5203837DF8000F8465FFFFFF89D05F5E5BC9C21000" Local $CodeBuffer = DllStructCreate("byte[" & BinaryLen($Opcode) & "]") DllStructSetData($CodeBuffer, 1, $Opcode) Local $Ouput = DllStructCreate("byte[" & BinaryLen($Data) & "]") Local $Ret = DllCall("user32.dll", "int", "CallWindowProc", "ptr", DllStructGetPtr($CodeBuffer), _ "str", $Data, _ "ptr", DllStructGetPtr($Ouput), _ "int", 0, _ "int", 0) Return BinaryMid(DllStructGetData($Ouput, 1), 1, $Ret[0]) EndFunc Func _Base64Encode($Data, $LineBreak = 76) Local $Opcode = "0x5589E5FF7514535657E8410000004142434445464748494A4B4C4D4E4F505152535455565758595A61626364656667 68696A6B6C6D6E6F707172737475767778797A303132333435363738392B2F005A8B5D088B7D108B4D0CE98F0000000FB633 C1EE0201D68A06880731C083F901760C0FB6430125F0000000C1E8040FB63383E603C1E60409C601D68A0688470183F90176 210FB6430225C0000000C1E8060FB6730183E60FC1E60209C601D68A06884702EB04C647023D83F90276100FB6730283E63F 01D68A06884703EB04C647033D8D5B038D7F0483E903836DFC04750C8B45148945FC66B80D0A66AB85C90F8F69FFFFFFC607 005F5E5BC9C21000" Local $CodeBuffer = DllStructCreate("byte[" & BinaryLen($Opcode) & "]") DllStructSetData($CodeBuffer, 1, $Opcode) $Data = Binary($Data) Local $Input = DllStructCreate("byte[" & BinaryLen($Data) & "]") DllStructSetData($Input, 1, $Data) $LineBreak = Floor($LineBreak / 4) * 4 Local $OputputSize = Ceiling(BinaryLen($Data) * 4 / 3) $OputputSize = $OputputSize + Ceiling($OputputSize / $LineBreak) * 2 + 4 Local $Ouput = DllStructCreate("char[" & $OputputSize & "]") DllCall("user32.dll", "none", "CallWindowProc", "ptr", DllStructGetPtr($CodeBuffer), _ "ptr", DllStructGetPtr($Input), _ "int", BinaryLen($Data), _ "ptr", DllStructGetPtr($Ouput), _ "uint", $LineBreak) Return DllStructGetData($Ouput, 1) EndFunc 新版 _ArrayAdd 的白痴作者,不管是誰,去死一死好了。 Link to comment Share on other sites More sharing options...
trancexx Posted September 27, 2008 Author Share Posted September 27, 2008 (edited) I absolutely love the simplicity of your machine code functions. I found them to be beautiful (like a beautiful woman). Probably I'm crazy and everything, khm, khm... You should make a tutorial on how to get machine code. Don't be lazy, do it. You should find rewarding having people learn of you. Yes, you are right, seems that now they are as fast. Return variable of DllStructCreate() in our case is local and releasing allocated memory by setting this variable to 0 is not needed. That was my thinking. Is this true, but completely true? About splitting... That should be done very consideringly to avoid possible mistakes due to the fact how base64 encoding is done (3 --> 4). Size of the portions would also depend on how long is every line of output sting (@CRLF we add for SMTP servers). So, portion lenght should be (4*3*LINE_BREAK)*n. "n" should be determined experimentally to accomplish best performance. Maybe would be faster, but looping with AutoIt is relatively slow... Someone should do it and test it. I updated first post (still no error checking). This how Wards _Base64Encode() looks with me: Func _Base64Encode($Data, $LineBreak = 76) Local $Opcode = "0x5589E5FF7514535657E8410000004142434445464748494A4B4C4D4E4F505152" _ & "535455565758595A6162636465666768696A6B6C6D6E6F707172737475767778" _ & "797A303132333435363738392B2F005A8B5D088B7D108B4D0CE98F0000000FB6" _ & "33C1EE0201D68A06880731C083F901760C0FB6430125F0000000C1E8040FB633" _ & "83E603C1E60409C601D68A0688470183F90176210FB6430225C0000000C1E806" _ & "0FB6730183E60FC1E60209C601D68A06884702EB04C647023D83F90276100FB6" _ & "730283E63F01D68A06884703EB04C647033D8D5B038D7F0483E903836DFC0475" _ & "0C8B45148945FC66B80D0A66AB85C90F8F69FFFFFFC607005F5E5BC9C21000" Local $CodeBuffer = DllStructCreate("byte[" & BinaryLen($Opcode) & "]") DllStructSetData($CodeBuffer, 1, $Opcode) $Data = Binary($Data) Local $Input = DllStructCreate("byte[" & BinaryLen($Data) & "]") DllStructSetData($Input, 1, $Data) $LineBreak = Floor($LineBreak / 4) * 4 Local $OputputSize = Ceiling(BinaryLen($Data) * 4 / 3) $OputputSize = $OputputSize + Ceiling($OputputSize / $LineBreak) * 2 + 4 Local $Ouput = DllStructCreate("char[" & $OputputSize & "]") DllCall("user32.dll", "none", "CallWindowProc", "ptr", DllStructGetPtr($CodeBuffer), _ "ptr", DllStructGetPtr($Input), _ "int", BinaryLen($Data), _ "ptr", DllStructGetPtr($Ouput), _ "uint", $LineBreak) Return DllStructGetData($Ouput, 1) EndFunc It's beautiful, right? Specially when you think what job it does. ... I'm crazy Edited September 27, 2008 by trancexx Biatu 1 ♡♡♡ . eMyvnE Link to comment Share on other sites More sharing options...
Ward Posted September 27, 2008 Share Posted September 27, 2008 (edited) I absolutely love the simplicity of your machine code functions. I found them to be beautiful (like a beautiful woman). Probably I'm crazy and everything, khm, khm... You should make a tutorial on how to get machine code. Don't be lazy, do it. You should find rewarding having people learn of you.I don't make a tutorial because it has a little complicated. The bigest problem is a machine code function using in AutoiIt can't have a static memory reference. As a result, we can't use windows API, and even a simple string needs special technique to locate. I think a better way is to use MemoryDllCall, because everyone know how to make a DLL. And it is much easier than getting machine code. If you are really interested in it, here is a demo. It is the source of my Base64Encode written in C--. Maybe a little assembly knowledge is necessary to understand it. expandcollapse popup#pragma option dll int _export Base64Encode(dword input, len, buffer, lineBrak) uses ESI EDI EBX { dword newLine = lineBrak; $CALL NEAR START $DB "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; START: $POP EDX EBX = input; EDI = buffer; ECX = len; while(signed ECX > 0) { DSBYTE[EDI] = DSBYTE[DSBYTE[EBX] >> 2 + EDX]; EAX = 0; IF(ECX > 1) EAX = DSBYTE[EBX + 1] & 0xf0 >> 4; DSBYTE[EDI + 1] = DSBYTE[DSBYTE[EBX] & 3 << 4 | EAX + EDX]; IF(ECX > 1) { EAX = DSBYTE[EBX + 2] & 0xc0 >> 6; DSBYTE[EDI + 2] = DSBYTE[DSBYTE[EBX + 1] & 0xf << 2 | EAX + EDX]; } ELSE DSBYTE[EDI + 2] = '='; IF(ECX > 2) DSBYTE[EDI + 3] = DSBYTE[DSBYTE[EBX + 2] & 0x3f + EDX]; ELSE DSBYTE[EDI + 3] = '='; EBX += 3; EDI += 4; ECX -= 3; newLine -= 4; IF(ZEROFLAG) { newLine = lineBrak; AX = 0x0A0D; $stosw } } DSBYTE[EDI] = 0; return; } Yes, you are right, seems that now they are as fast. Return variable of DllStructCreate() in our case is local and releasing allocated memory by setting this variable to 0 is not needed. That was my thinking. Is this true, but completely true?Yes, it is true, I had tested it. But I still don't know why setting it to 0 is so slow. Edited September 27, 2008 by Ward 新版 _ArrayAdd 的白痴作者,不管是誰,去死一死好了。 Link to comment Share on other sites More sharing options...
trancexx Posted September 28, 2008 Author Share Posted September 28, 2008 I don't make a tutorial because it has a little complicated. The bigest problem is a machine code function using in AutoiIt can't have a static memory reference. As a result, we can't use windows API, and even a simple string needs special technique to locate. I think a better way is to use MemoryDllCall, because everyone know how to make a DLL. And it is much easier than getting machine code. If you are really interested in it, here is a demo. It is the source of my Base64Encode written in C--. Maybe a little assembly knowledge is necessary to understand it. expandcollapse popup#pragma option dll int _export Base64Encode(dword input, len, buffer, lineBrak) uses ESI EDI EBX { dword newLine = lineBrak; $CALL NEAR START $DB "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; START: $POP EDX EBX = input; EDI = buffer; ECX = len; while(signed ECX > 0) { DSBYTE[EDI] = DSBYTE[DSBYTE[EBX] >> 2 + EDX]; EAX = 0; IF(ECX > 1) EAX = DSBYTE[EBX + 1] & 0xf0 >> 4; DSBYTE[EDI + 1] = DSBYTE[DSBYTE[EBX] & 3 << 4 | EAX + EDX]; IF(ECX > 1) { EAX = DSBYTE[EBX + 2] & 0xc0 >> 6; DSBYTE[EDI + 2] = DSBYTE[DSBYTE[EBX + 1] & 0xf << 2 | EAX + EDX]; } ELSE DSBYTE[EDI + 2] = '='; IF(ECX > 2) DSBYTE[EDI + 3] = DSBYTE[DSBYTE[EBX + 2] & 0x3f + EDX]; ELSE DSBYTE[EDI + 3] = '='; EBX += 3; EDI += 4; ECX -= 3; newLine -= 4; IF(ZEROFLAG) { newLine = lineBrak; AX = 0x0A0D; $stosw } } DSBYTE[EDI] = 0; return; } This actually helps a lot. Can you please post some simpler example (adding two numbers). Original language source and complete function in AutoIt using machine code. That would help me with patterns. I will try to comprehend. Biatu 1 ♡♡♡ . eMyvnE Link to comment Share on other sites More sharing options...
everseeker Posted October 20, 2014 Share Posted October 20, 2014 Is there a COMPLETED UDF for this anywhere? Everseeker Link to comment Share on other sites More sharing options...
LarsJ Posted October 21, 2014 Share Posted October 21, 2014 The code in first post is a complete UDF.Since the code is only implementing wrapper functions for CryptBinaryToString and CryptStringToBinary in crypt32.dll, the code should be working, if the functions in the DLL are working (provided that the wrapper functions are coded correctly, but I think they are).Although this seems to be an old example, the age really has no meaning, since it's only wrapper functions. What has meaning in terms of age, is the age of the DLL. Even on my old XP crypt32.dll is dated 2013-10-07. Controls, File Explorer, ROT objects, UI Automation, Windows Message MonitorCompiled code: Accessing AutoIt variables, DotNet.au3 UDF, Using C# and VB codeShell menus: The Context menu, The Favorites menu. Shell related: Control Panel, System Image ListsGraphics related: Rubik's Cube, OpenGL without external libraries, Navigating in an image, Non-rectangular selectionsListView controls: Colors and fonts, Multi-line header, Multi-line items, Checkboxes and icons, Incremental searchListView controls: Virtual ListViews, Editing cells, Data display functions Link to comment Share on other sites More sharing options...
mLipok Posted September 27, 2018 Share Posted September 27, 2018 On 26.09.2008 at 7:10 PM, trancexx said: Here are some times, but I guess to get it right more tests should be done (and not in one script because of memory allocation... thing)...... Do you still have the same testing snippet ? Could you post them here ? 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 Code * for other useful stuff click the following button: Spoiler Any of my own code posted anywhere on the forum is available for use by others without any restriction of any kind. My contribution (my own projects): * Debenu Quick PDF Library - UDF * Debenu PDF Viewer SDK - UDF * Acrobat Reader - ActiveX Viewer * UDF for PDFCreator v1.x.x * XZip - UDF * AppCompatFlags UDF * CrowdinAPI UDF * _WinMergeCompare2Files() * _JavaExceptionAdd() * _IsBeta() * Writing DPI Awareness App - workaround * _AutoIt_RequiredVersion() * Chilkatsoft.au3 UDF * TeamViewer.au3 UDF * JavaManagement UDF * VIES over SOAP * WinSCP UDF * GHAPI UDF - modest begining - comunication with GitHub REST API * ErrorLog.au3 UDF - A logging Library * Include Dependency Tree (Tool for analyzing script relations) * Show_Macro_Values.au3 * My contribution to others projects or UDF based on others projects: * _sql.au3 UDF * POP3.au3 UDF * RTF Printer - UDF * XML.au3 UDF * ADO.au3 UDF * SMTP Mailer UDF * Dual Monitor resolution detection * * 2GUI on Dual Monitor System * _SciLexer.au3 UDF * SciTE - Lexer for console pane * Useful links: * Forum Rules * Forum etiquette * Forum Information and FAQs * How to post code on the forum * AutoIt Online Documentation * AutoIt Online Beta Documentation * SciTE4AutoIt3 getting started * Convert text blocks to AutoIt code * Games made in Autoit * Programming related sites * Polish AutoIt Tutorial * DllCall Code Generator * Wiki: * Expand your knowledge - AutoIt Wiki * Collection of User Defined Functions * How to use HelpFile * Good coding practices in AutoIt * OpenOffice/LibreOffice/XLS Related: WriterDemo.au3 * XLS/MDB from scratch with ADOX IE Related: * How to use IE.au3 UDF with AutoIt v3.3.14.x * Why isn't Autoit able to click a Javascript Dialog? * Clicking javascript button with no ID * IE document >> save as MHT file * IETab Switcher (by LarsJ ) * HTML Entities * _IEquerySelectorAll() (by uncommon) * IE in TaskScheduler * IE Embedded Control Versioning (use IE9+ and HTML5 in a GUI) * PDF Related: * How to get reference to PDF object embeded in IE * IE on Windows 11 * I encourage you to read: * Global Vars * Best Coding Practices * Please explain code used in Help file for several File functions * OOP-like approach in AutoIt * UDF-Spec Questions * EXAMPLE: How To Catch ConsoleWrite() output to a file or to CMD *I also encourage you to check awesome @trancexx code: * Create COM objects from modules without any demand on user to register anything. * Another COM object registering stuff * OnHungApp handler * Avoid "AutoIt Error" message box in unknown errors * HTML editor * winhttp.au3 related : * https://www.autoitscript.com/forum/topic/206771-winhttpau3-download-problem-youre-speaking-plain-http-to-an-ssl-enabled-server-port/ "Homo sum; humani nil a me alienum puto" - Publius Terentius Afer"Program are meant to be read by humans and only incidentally for computers and execute" - Donald Knuth, "The Art of Computer Programming" , be and \\//_. Anticipating Errors : "Any program that accepts data from a user must include code to validate that data before sending it to the data store. You cannot rely on the data store, ...., or even your programming language to notify you of problems. You must check every byte entered by your users, making sure that data is the correct type for its field and that required fields are not empty." Signature last update: 2023-04-24 Link to comment Share on other sites More sharing options...
mLipok Posted September 27, 2018 Share Posted September 27, 2018 added to WIKI here: https://www.autoitscript.com/wiki/User_Defined_Functions#Encryption_and_hash 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 Code * for other useful stuff click the following button: Spoiler Any of my own code posted anywhere on the forum is available for use by others without any restriction of any kind. My contribution (my own projects): * Debenu Quick PDF Library - UDF * Debenu PDF Viewer SDK - UDF * Acrobat Reader - ActiveX Viewer * UDF for PDFCreator v1.x.x * XZip - UDF * AppCompatFlags UDF * CrowdinAPI UDF * _WinMergeCompare2Files() * _JavaExceptionAdd() * _IsBeta() * Writing DPI Awareness App - workaround * _AutoIt_RequiredVersion() * Chilkatsoft.au3 UDF * TeamViewer.au3 UDF * JavaManagement UDF * VIES over SOAP * WinSCP UDF * GHAPI UDF - modest begining - comunication with GitHub REST API * ErrorLog.au3 UDF - A logging Library * Include Dependency Tree (Tool for analyzing script relations) * Show_Macro_Values.au3 * My contribution to others projects or UDF based on others projects: * _sql.au3 UDF * POP3.au3 UDF * RTF Printer - UDF * XML.au3 UDF * ADO.au3 UDF * SMTP Mailer UDF * Dual Monitor resolution detection * * 2GUI on Dual Monitor System * _SciLexer.au3 UDF * SciTE - Lexer for console pane * Useful links: * Forum Rules * Forum etiquette * Forum Information and FAQs * How to post code on the forum * AutoIt Online Documentation * AutoIt Online Beta Documentation * SciTE4AutoIt3 getting started * Convert text blocks to AutoIt code * Games made in Autoit * Programming related sites * Polish AutoIt Tutorial * DllCall Code Generator * Wiki: * Expand your knowledge - AutoIt Wiki * Collection of User Defined Functions * How to use HelpFile * Good coding practices in AutoIt * OpenOffice/LibreOffice/XLS Related: WriterDemo.au3 * XLS/MDB from scratch with ADOX IE Related: * How to use IE.au3 UDF with AutoIt v3.3.14.x * Why isn't Autoit able to click a Javascript Dialog? * Clicking javascript button with no ID * IE document >> save as MHT file * IETab Switcher (by LarsJ ) * HTML Entities * _IEquerySelectorAll() (by uncommon) * IE in TaskScheduler * IE Embedded Control Versioning (use IE9+ and HTML5 in a GUI) * PDF Related: * How to get reference to PDF object embeded in IE * IE on Windows 11 * I encourage you to read: * Global Vars * Best Coding Practices * Please explain code used in Help file for several File functions * OOP-like approach in AutoIt * UDF-Spec Questions * EXAMPLE: How To Catch ConsoleWrite() output to a file or to CMD *I also encourage you to check awesome @trancexx code: * Create COM objects from modules without any demand on user to register anything. * Another COM object registering stuff * OnHungApp handler * Avoid "AutoIt Error" message box in unknown errors * HTML editor * winhttp.au3 related : * https://www.autoitscript.com/forum/topic/206771-winhttpau3-download-problem-youre-speaking-plain-http-to-an-ssl-enabled-server-port/ "Homo sum; humani nil a me alienum puto" - Publius Terentius Afer"Program are meant to be read by humans and only incidentally for computers and execute" - Donald Knuth, "The Art of Computer Programming" , be and \\//_. Anticipating Errors : "Any program that accepts data from a user must include code to validate that data before sending it to the data store. You cannot rely on the data store, ...., or even your programming language to notify you of problems. You must check every byte entered by your users, making sure that data is the correct type for its field and that required fields are not empty." Signature last update: 2023-04-24 Link to comment Share on other sites More sharing options...
AXLE Posted April 28, 2019 Share Posted April 28, 2019 (edited) Hi trancexx, is it OK if I use this routine in my scripts? If yes do you have a preferred credits/attribution name? or is trancexx acceptable attribute.. For example: About my App Info etc Third party libraries and code: AutoIt UDFs 2019 Base64 Enc/Dec trancexx 2008 Other devs And in source: ; #FUNCTION# ==================================================================================================================== ; Title .........: Base64 UDF (MSCrypt32.dll CryptBinaryToString) ; AutoIt Version : 3.3.0.0 ; Language ......: English ; Description ...: Base64 Encoding and Decoding with padding. ; There is @CRLF every 64 chars in return of _Base64Encode(). ; _Base64Decode() will return binary data. That is intentional to avoid Chr(0) issue. ; Convert it to string using BinaryToString(). ; Author ........: trancexx ; Modified.......: 2008 ; =============================================================================================================================== ; #EXAMPLE# ==================================================================================================================== ; $encoded = _Base64Encode("Testing") ; MsgBox(0, 'Base64 Encoded', $encoded) ; ; $decoded = _Base64Decode($encoded) ; MsgBox(0, 'Base64 Decoded - binary', $decoded) ; MsgBox(0, 'Base64 Decoded - string', BinaryToString($decoded)) ; =============================================================================================================================== Func _Base64Encode($input) ... What you think ? Edited April 28, 2019 by AXLE Update information "Writing code to carry out an intended set of tasks is relatively easy. Writing code to carry out ONLY an intended set of tasks, well that can be a little more challenging." Alex Maddern Link to comment Share on other sites More sharing options...
AXLE Posted April 29, 2019 Share Posted April 29, 2019 Also trancexx, separate question, I am adding some commenting to explain the CryptBinaryToString step by step etc (as commented UDF). In the https://www.autoitscript.com/autoit3/docs/functions/DllStructCreate.htm Example: ... ; Release the resources used by the structure. $tSTRUCT1 = 0 Should we release $struct = 0, $strc = 0, $a = 0 within the two Functions, or by the caller after the Func returns, or will the structures be automatically released in the same way as a Local $variable would be when the Func Returns? Just noticed that most other examples in the Help document don't seam to worry about releasing the structure after DllStructCreate, what do you think? "Writing code to carry out an intended set of tasks is relatively easy. Writing code to carry out ONLY an intended set of tasks, well that can be a little more challenging." Alex Maddern Link to comment Share on other sites More sharing options...
trancexx Posted May 1, 2019 Author Share Posted May 1, 2019 On 4/29/2019 at 12:30 AM, AXLE said: Hi trancexx, is it OK if I use this routine in my scripts? If yes do you have a preferred credits/attribution name? or is trancexx acceptable attribute.. For example: About my App Info etc Third party libraries and code: AutoIt UDFs 2019 Base64 Enc/Dec trancexx 2008 Other devs And in source: ; #FUNCTION# ==================================================================================================================== ; Title .........: Base64 UDF (MSCrypt32.dll CryptBinaryToString) ; AutoIt Version : 3.3.0.0 ; Language ......: English ; Description ...: Base64 Encoding and Decoding with padding. ; There is @CRLF every 64 chars in return of _Base64Encode(). ; _Base64Decode() will return binary data. That is intentional to avoid Chr(0) issue. ; Convert it to string using BinaryToString(). ; Author ........: trancexx ; Modified.......: 2008 ; =============================================================================================================================== ; #EXAMPLE# ==================================================================================================================== ; $encoded = _Base64Encode("Testing") ; MsgBox(0, 'Base64 Encoded', $encoded) ; ; $decoded = _Base64Decode($encoded) ; MsgBox(0, 'Base64 Decoded - binary', $decoded) ; MsgBox(0, 'Base64 Decoded - string', BinaryToString($decoded)) ; =============================================================================================================================== Func _Base64Encode($input) ... What you think ? Of course you can use it, that goes without saying. Crediting is a matter of courtesy, but don't worry too much about it. Destroying dllstruct is handled internally when variable that holds it goes out of the scope. There are rarely any need to release it manually. ♡♡♡ . eMyvnE Link to comment Share on other sites More sharing options...
AXLE Posted May 7, 2019 Share Posted May 7, 2019 Thank you trancexx, That's just me, I prefer to ask and attribute 😃 Also, I made some slight change with a flag for Binary|Textual inputs for _Base64Encode(...). I will send you a working copy when I am done 😃 Thanks for the heads up on the dllstuct release. Bit used to C where I need to be carefully about releasing resources and reading from ghost memory blocks. "Writing code to carry out an intended set of tasks is relatively easy. Writing code to carry out ONLY an intended set of tasks, well that can be a little more challenging." Alex Maddern Link to comment Share on other sites More sharing options...
garbb Posted November 20, 2022 Share Posted November 20, 2022 (edited) From https://learn.microsoft.com/en-us/windows/win32/api/wincrypt/nf-wincrypt-cryptbinarytostringa If you want, you can add CRYPT_STRING_NOCRLF (0x40000000) to the flags parameter to prevent the CRLF's in the output. Like this: expandcollapse popupFunc _Base64Encode($input) $input = Binary($input) Local $struct = DllStructCreate("byte[" & BinaryLen($input) & "]") DllStructSetData($struct, 1, $input) Local $strc = DllStructCreate("int") Local $a_Call = DllCall("Crypt32.dll", "int", "CryptBinaryToString", _ "ptr", DllStructGetPtr($struct), _ "int", DllStructGetSize($struct), _ "int", 1 + 0x40000000, _ "ptr", 0, _ "ptr", DllStructGetPtr($strc)) If @error Or Not $a_Call[0] Then Return SetError(1, 0, "") ; error calculating the length of the buffer needed EndIf Local $a = DllStructCreate("char[" & DllStructGetData($strc, 1) & "]") $a_Call = DllCall("Crypt32.dll", "int", "CryptBinaryToString", _ "ptr", DllStructGetPtr($struct), _ "int", DllStructGetSize($struct), _ "int", 1 + 0x40000000, _ "ptr", DllStructGetPtr($a), _ "ptr", DllStructGetPtr($strc)) If @error Or Not $a_Call[0] Then Return SetError(2, 0, ""); error encoding EndIf Return DllStructGetData($a, 1) EndFunc ;==>_Base64Encode Edited November 20, 2022 by garbb argumentum 1 Link to comment Share on other sites More sharing options...
Recommended Posts
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 accountSign in
Already have an account? Sign in here.
Sign In Now