HashInfo plugin for NSIS provides several cryptographic functions that allow you to generate hash values for a given string or file. Installer creator (NSIS based) can use one of the many hash algorithms.
Current version of plugin allows you to get data for several categories. Below, you can find all functions supported by plugin with description and example usage. More information about HashInfo plugin can be found in the file "HashInfoDemo.nsi", which is attached to the archive file of the HashInfo plugin.
The plugin is based on the HashLib4Pascal library, which provides an easy-to-use interface for calculating hashes and checksums.
Function .onInit HashInfo::FunctionName "PARAM1" "PARAM2" ; Function can take parameters ; Parameters usage depends on given function (always required) Pop $0 ; The function returns the retrieved value in the variable $0 ; The function returns "error" if there is an error FunctionEnd
A checksum is a small-sized block of data derived from another block of digital data for the purpose of detecting errors that may have been introduced during its transmission or storage. By themselves, checksums are often used to verify data integrity but are not relied upon to verify data authenticity.
Available Hash Algorithms: Adler-32
1a. Compute the checksum value for a given STRING ; Usage ; HashInfo::FunctionName "PARAM1" "PARAM2" ; PARAM1 -> Hash Algorithm (Obligatory) ; PARAM2 -> String (Obligatory) ; Notes: ; - Function returns "error" if something goes wrong StrCpy $R0 "Adler-32" ; PARAM1 StrCpy $R1 "Hello World" ; PARAM2 HashInfo::GetStrCRCHash "$R0" "$R1" Pop $0 DetailPrint " Hash Alghoritm: $R0" DetailPrint " Input String: $R1" DetailPrint " Output Hash: $0"
1b. Compute the checksum value for a given FILE ; Usage ; HashInfo::FunctionName "PARAM1" "PARAM2" ; PARAM1 -> Hash Algorithm (Obligatory) ; PARAM2 -> Full Path to File (Obligatory) ; Notes: ; - Function returns "error" if something goes wrong StrCpy $R0 "Adler-32" ; PARAM1 StrCpy $R1 "$EXEPATH" ; PARAM2 HashInfo::GetFileCRCHash "$R0" "$R1" Pop $0 DetailPrint " Hash Alghoritm: $R0" DetailPrint " Input File: $R1" DetailPrint " Output Hash: $0"
A cyclic redundancy check (CRC)is an error-detecting code commonly used in digital networks and storage devices to detect accidental changes to digital data. Blocks of data entering these systems get a short check value attached, based on the remainder of a polynomial division of their contents. On retrieval, the calculation is repeated and, in the event the check values do not match, corrective action can be taken against data corruption. CRCs can be used for error correction. CRCs are so called because the check (data verification) value is a redundancy (it expands the message without adding information) and the algorithm is based on cyclic codes.
Available Hash Algorithms:
CRC-3/GSM, CRC-3/ROHC, CRC-4/INTERLAKEN, CRC-4/ITU, CRC-4/G-704, CRC-5/EPC, CRC-5/EPC-C1G2, CRC-5/ITU, CRC-5/G-704, CRC-5/USB, CRC-6/CDMA2000-A, CRC-6/CDMA2000-B, CRC-6/DARC, CRC-6/GSM, CRC-6/ITU, CRC-6/G-704, CRC-7, CRC-7/MMC, CRC-7/ROHC, CRC-7/UMTS, CRC-8, CRC-8/SMBUS, CRC-8/AUTOSAR, CRC-8/BLUETOOTH, CRC-8/CDMA2000, CRC-8/DARC, CRC-8/DVB-S2, CRC-8/EBU, CRC-8/AES, CRC-8/TECH-3250, CRC-8/GSM-A, CRC-8/GSM-B, CRC-8/I-CODE, CRC-8/ITU, CRC-8/I-432-1, CRC-8/LTE, CRC-8/MAXIM, DOW-CRC, CRC-8/MAXIM-DOW, CRC-8/OPENSAFETY, CRC-8/ROHC, CRC-8/SAE-J1850, CRC-8/WCDMA, CRC-8/MIFARE-MAD, CRC-8/NRSC-5, CRC-10, CRC-10/ATM, CRC-10/I-610, CRC-10/CDMA2000, CRC-10/GSM, CRC-11, CRC-11/FLEXRAY, CRC-11/UMTS, CRC-12/CDMA2000, CRC-12/DECT, X-CRC-12, CRC-12/GSM, CRC-12/UMTS, CRC-12/3GPP, CRC-13/BBC, CRC-14/DARC, CRC-14/GSM, CRC-15, CRC-15/CAN, CRC-15/MPT1327, CRC-16, ARC, CRC-IBM, CRC-16/ARC, CRC-16/LHA, CRC-16/AUG-CCITT, CRC-16/SPI-FUJITSU, CRC-16/BUYPASS, CRC-16/VERIFONE, CRC-16/UMTS, CRC-16/CCITT-FALSE, CRC-16/AUTOSAR, CRC-16/IBM-3740, CRC-16/CDMA2000, CRC-16/CMS, CRC-16/DDS-110, CRC-16/DECT-R, R-CRC-16, CRC-16/DECT-X, X-CRC-16, CRC-16/DNP, CRC-16/EN13757, CRC-16/GENIBUS, CRC-16/EPC, CRC-16/I-CODE, CRC-16/DARC, CRC-16/EPC-C1G2, CRC-16/GSM, CRC-16/LJ1200, CRC-16/MAXIM, CRC-16/MAXIM-DOW, CRC-16/MCRF4XX, CRC-16/OPENSAFETY-A, CRC-16/OPENSAFETY-B, CRC-16/PROFIBUS, CRC-16/IEC-61158-2, CRC-16/RIELLO, CRC-16/T10-DIF, CRC-16/TELEDISK, CRC-16/TMS37157, CRC-16/USB, CRC-A, CRC-16/ISO-IEC-14443-3-A, KERMIT, CRC-16/CCITT, CRC-16/CCITT-TRUE, CRC-CCITT, CRC-16/KERMIT, CRC-16/V-41-LSB, MODBUS, CRC-16/MODBUS, X-25, CRC-16/IBM-SDLC, CRC-16/ISO-HDLC, CRC-16/ISO-IEC-14443-3-B, CRC-B, CRC-16/X-25, XMODEM, ZMODEM, CRC-16/ACORN, CRC-16/XMODEM, CRC-16/V-41-MSB, CRC-16/NRSC-5, CRC-17/CAN-FD, CRC-21/CAN-FD, CRC-24, CRC-24/OPENPGP, CRC-24/BLE, CRC-24/FLEXRAY-A, CRC-24/FLEXRAY-B, CRC-24/INTERLAKEN, CRC-24/LTE-A, CRC-24/LTE-B, CRC-24/OS-9, CRC-30/CDMA, CRC-31/PHILLIPS, CRC-32, CRC-32/ADCCP, CRC-32/V-42, CRC-32/XZ, PKZIP, CRC-32/ISO-HDLC, CRC-32/AUTOSAR, CRC-32/BZIP2, CRC-32/AAL5, CRC-32/DECT-B, B-CRC-32, CRC-32C, CRC-32/BASE91-C, CRC-32/CASTAGNOLI, CRC-32/INTERLAKEN, CRC-32/ISCSI, CRC-32D, CRC-32/BASE91-D, CRC-32/MPEG-2, CRC-32/POSIX, CKSUM, CRC-32Q, CRC-32/AIXM, JAMCRC, CRC-32/JAMCRC, XFER, CRC-32/XFER, CRC-32/CD-ROM-EDC, CRC-40/GSM, CRC-64, CRC-64/ECMA-182, CRC-64/GO-ISO, CRC-64/WE, CRC-64/XZ, CRC-64/GO-ECMA, CRC-64/1B, CRC-64/Jones
1a. Compute the CRC Hash value for a given STRING ; Usage ; HashInfo::FunctionName "PARAM1" "PARAM2" ; PARAM1 -> CRC Hash Algorithm (Obligatory) ; PARAM2 -> String (Obligatory) ; Notes: ; - Function returns "error" if something goes wrong StrCpy $R0 "CRC-32" ; PARAM1 StrCpy $R1 "Hello World" ; PARAM2 HashInfo::GetStrCRCHash "$R0" "$R1" Pop $0 DetailPrint " Hash Alghoritm: $R0" DetailPrint " Input String: $R1" DetailPrint " Output Hash: $0"
1b. Compute the CRC Hash value for a given FILE ; Usage ; HashInfo::FunctionName "PARAM1" "PARAM2" ; PARAM1 -> CRC Hash Algorithm (Obligatory) ; PARAM2 -> Full Path to File (Obligatory) ; Notes: ; - Function returns "error" if something goes wrong StrCpy $R0 "CRC-32" ; PARAM1 StrCpy $R1 "$EXEPATH" ; PARAM2 HashInfo::GetFileCRCHash "$R0" "$R1" Pop $0 DetailPrint " Hash Alghoritm: $R0" DetailPrint " Input File: $R1" DetailPrint " Output Hash: $0"
Non-cryptographic hash functions provide weaker guarantees in exchange for performance improvements (don't provide certain security guarantees). They just try to avoid collisions for non malicious input. An example would be to detect data corruption due to an unstable network.
Available Hash Algorithms:
AP, Bernstein, Bernstein1, BKDR, DEK, DJB, ELF, FNV, FNV1a, Jenkins3, JS, Murmur2, MurmurHash3_x86_32, OneAtTime, PJW, Rotating, RS, SDBM, ShiftAndXor, SuperFast, XXHash32, FNV_64, FNV1a_64, Murmur2_64, SipHash2_4, XXHash64, SipHash128_2_4, MurmurHash3_x86_128, MurmurHash3_x64_128
1a. Compute the Non-Cryptographic Hash value for a given STRING ; Usage ; HashInfo::FunctionName "PARAM1" "PARAM2" ; PARAM1 -> Hash Algorithm (Obligatory) ; PARAM2 -> String (Obligatory) ; Notes: ; - Function returns "error" if something goes wrong StrCpy $R0 "Bernstein" ; PARAM1 StrCpy $R1 "Hello World" ; PARAM2 HashInfo::GetStrNonCryptoHash "$R0" "$R1" Pop $0 DetailPrint " Hash Alghoritm: $R0" DetailPrint " Input String: $R1" DetailPrint " Output Hash: $0"
1b. Compute the Non-Cryptographic Hash value for a given FILE ; Usage ; HashInfo::FunctionName "PARAM1" "PARAM2" ; PARAM1 -> Hash Algorithm (Obligatory) ; PARAM2 -> Full Path to File (Obligatory) ; Notes: ; - Function returns "error" if something goes wrong StrCpy $R0 "Bernstein" ; PARAM1 StrCpy $R1 "$EXEPATH" ; PARAM2 HashInfo::GetFileNonCryptoHash "$R0" "$R1" Pop $0 DetailPrint " Hash Alghoritm: $R0" DetailPrint " Input File: $R1" DetailPrint " Output Hash: $0"
Cryptographic hash functions are a special class among hash functions that aim to provide certain security guarantees. For example, when obtaining a device fingerprinting, you should use a cryptographic hash function to have more guarantees of its output uniqueness. The ideal cryptographic hash function has six main properties:
Available Hash Algorithms:
MD2, MD4, MD5, SHA0, SHA1, SHA2-224, SHA2-256, SHA2-384, SHA2-512, SHA2-512/224, SHA2-512/256, SHA3-224, SHA3-256, SHA3-384, SHA3-512, Blake2B-160, Blake2B-256, Blake2B-384, Blake2B-512, Blake2BP, Blake2S-128, Blake2S-160, Blake2S-224, Blake2S-256, Blake2SP, Blake3, GOST 34.11-94, GOST R 34.11-2012-256, GOST R 34.11-2012-512, Grindahl-256, Grindahl-512, Has160, RIPEMD, RIPEMD-128, RIPEMD-160, RIPEMD-256, RIPEMD-320, Snefru-128, Snefru-256, Panama, RadioGatun32, RadioGatun64, Keccak-224, Keccak-256, Keccak-288, Keccak-384, Keccak-512, WhirlPool
1a. Compute the Cryptographic Hash value for a given STRING ; Usage ; HashInfo::FunctionName "PARAM1" "PARAM2" ; PARAM1 -> Hash Algorithm (Obligatory) ; PARAM2 -> String (Obligatory) ; Notes: ; - Function returns "error" if something goes wrong StrCpy $R0 "MD5" ; PARAM1 StrCpy $R1 "Hello World" ; PARAM2 HashInfo::GetStrCryptoHash "$R0" "$R1" Pop $0 DetailPrint " Hash Alghoritm: $R0" DetailPrint " Input String: $R1" DetailPrint " Output Hash: $0"
1b. Compute the Cryptographic Hash value for a given FILE ; Usage ; HashInfo::FunctionName "PARAM1" "PARAM2" ; PARAM1 -> Hash Algorithm (Obligatory) ; PARAM2 -> Full Path to File (Obligatory) ; Notes: ; - Function returns "error" if something goes wrong StrCpy $R0 "MD5" ; PARAM1 StrCpy $R1 "$EXEPATH" ; PARAM2 HashInfo::GetFileCryptoHash "$R0" "$R1" Pop $0 DetailPrint " Hash Alghoritm: $R0" DetailPrint " Input File: $R1" DetailPrint " Output Hash: $0"
Release Date: | November 4, 2022 (Downloaded: 336 times) |
Version: | 2.0.0.0 |
Architecture: | Windows (NSIS 32/64-Bit Unicode) |
License: | Freeware |
Copyright: | Copyright © 2016 - 2025 Paweł Porwisz |
File Size: | 1,10 MB (1161145 bytes) |
Hash (SHA256): | 6d0413a4269db52fef7b20fcf66590618b4536090bdddbcbd588490559ae7a5d |
NSIS HashInfo Plugin
Copyright © 2016 - 2025 Paweł Porwisz
All rights reserved
INSTALLATION OR USE OF THE NSIS PLUGIN INDICATES YOUR ASSENT TO THE FOLLOWING LICENSE AGREEMENT.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.