begin process at 2010 02 10 09:47:17
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Sécurité & Cryptage

 > SHAMAN LIBRAIRIE DE HASH SUPPORTANT SHA1 SHA256 SHA384 SHA512 MD5 BASE64

SHAMAN LIBRAIRIE DE HASH SUPPORTANT SHA1 SHA256 SHA384 SHA512 MD5 BASE64


 Information sur la source

Note :
Aucune note
Catégorie :Sécurité & Cryptage Classé sous :hash, dll, sha, md5, base64 Niveau :Initié Date de création :07/08/2007 Vu / téléchargé :8 926 / 423

Auteur : xtremejames183

Ecrire un message privé
Commentaire sur cette source (0)
Ajouter un commentaire et/ou une note

 Description

Cliquez pour voir la capture en taille normale
Shaman une DLL/SO(pour POSIX) que j'ai ecrit en C pour un autre projet en fac , qui permet de hasher && crypter vos donnes  && checksum vos fichiers selon les algorithmes suivant :
* SHA1 (MD5 Killer)
* SHA256
* SHA384
* SHA512 ==> pour les paranoid comme moi
* MD5 RFC 1321 ( ca craint il parait)
* Base64 (Apache project)

en plus ca inclut quelque fonction utiles comme la genration de RANDOM String && lecture du fichiers ...

le fonctionnemnt est simple :
* on initialise la DLL/SO grace a InitShaman
* on ajoute une chaine a crypter ShaManAdd
* on choisi un algo SCT->meth = SHA1_HASH ( voir example )
* on procede au hashage (ShamanHashData && ShaManCheckSum pour les fichiers )
* voila ( voir example )

SHAMAN est portable et marche sur WIN32/64 POSIX(linux/BSD/Solaris/Mac) ==> TESTES && valides

Source

  • /*
  • ShaMan Hash Shared Library (SHA1 SHA256 SHA384 SHA512 MD5 BASE64 + random string generator )
  • Copyright (c) 2007 James Mrad (xtremejames183@msn.com)
  • Permission is hereby granted, free of charge, to any person obtaining
  • a copy of this software and associated documentation files (the
  • "Software"), to deal in the Software without restriction, including
  • without limitation the rights to use, copy, modify, merge, publish,
  • distribute, sublicense, and/or sell copies of the Software, and to
  • permit persons to whom the Software is furnished to do so, subject to
  • the following conditions:
  • The above copyright notice and this permission notice shall be included
  • in all copies or substantial portions of the Software.
  • 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.
  • 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.
  • */
  • /*********************************** API ***********************************************************************/
  • #ifndef __SHAMAN_H__
  • #define __SHAMAN_H__
  • #include <stdio.h> /* FILE */
  • #include <stdlib.h>
  • #include <string.h>
  • #include <errno.h>
  • #include <time.h> /* for srand */
  • /* local */
  • #include "gdefs.h"
  • #include "sha1.h"
  • #include "sha256.h"
  • #include "sha384.h"
  • #include "sha512.h"
  • #include "md5.h"
  • #include "base64.h"
  • /* pool memory managment */
  • #include "pool.h"
  • /* portable&&safe snprintf */
  • #include "snprintf.h"
  • #define FILE_HASH_SIZE 65635
  • #define MAX_HASH_BUFFER SHA512_HASH_SIZE * 5
  • #define SHAMAN_OK 0
  • #define SHAMAN_VER "Shaman Hash Library V2.1"
  • typedef enum
  • {
  • /* supported Method */
  • SHA1_HASH,
  • SHA256_HASH,
  • SHA384_HASH,
  • SHA512_HASH,
  • MD5_HASH,
  • BASE64_HASH /* lol :-) */
  • }HASHMETH; /* Hash method */
  • typedef struct shaman_st
  • {
  • uint8_t *clear; /* clear chain */
  • HASHMETH meth;
  • FILE *fp;
  • pool p;
  • uint8_t *hash ; /* final hash chain */
  • uint8_t *version ; /* SHAMAN Version */
  • }SHAMAN_CTX;
  • /**
  • * Util codes
  • * Generate Random String
  • * @param output: data will be copied to output , hide : optional 1/true if yu want to hash it using SHA1
  • * @return SHAMAN_OK on succes , -1 on failure
  • */
  • int GenRandomString(uint8_t *output,unsigned long len);
  • /**
  • * Read a file and return it as buffer
  • * @param open File Pointer
  • * @ return a malloced buffer (must be freed) on success , -1 on failure
  • */
  • uint8_t *XReadFile(FILE *fp);
  • #if defined _WIN32 || !defined HAVE_BZERO
  • /* bzero for NON POSIX */
  • void bzero(void *buf, size_t buf_size) ;
  • #endif
  • /* Core Code */
  • /**
  • * Init ShaMan Context
  • * By default HashMethod is SHA256 */
  • SHAMAN_CTX * InitShaMan(void);
  • /**
  • * Prepare string for Hash Operation
  • * @param SHAMAN_CTX Not NULL , a cstr (NOT NULL)
  • * @return SHAMAN_OK on succes , -1 on failure
  • */
  • int ShaManAdd(SHAMAN_CTX *sctx,uint8_t *cstr);
  • /*
  • * Main Hash Processing
  • * Hash the clear buffer and copy its hex code to hash(member of CTX)
  • * @param CTX with clear buffer (NOT NULL)
  • * @return sctx->hash : the HEX Code && SHAMAN_OK on Sucess , -1 on failure
  • */
  • int ShaManHashData(SHAMAN_CTX *sctx);
  • /*
  • * Do File Checksum
  • * Hash the file named fname (must not exceed < FILE HASH_SIZE )
  • * @param CTX all is done done internally
  • * @return sctx->hash on sucess , -1 on failure
  • */
  • int ShaManFileCheckSum(SHAMAN_CTX *sctx,char *fname);
  • /*
  • * Destructor OO Style
  • */
  • int DestroyShaMan(SHAMAN_CTX *sctx);
  • #endif
  • /******************************** TEST DE L'API ***************************************************************/
  • #include <stdio.h>
  • #include <stdlib.h>
  • #include <errno.h>
  • #include "shaman.h"
  • int main(int argc,char *argv[])
  • {
  • SHAMAN_CTX *SCT; /* Context ShaMan */
  • int res ;
  • uint8_t test[512];
  • int i;
  • char HAMETH[6][10] = { "SHA1","SHA256","SHA384","SHA512","MD5","BASE64" } ;
  • /* Init Shaman Library*/
  • SCT = InitShaMan() ;
  • if( SCT == NULL)
  • {
  • puts("Cannot Load ShaMan Library");
  • exit(EXIT_FAILURE);
  • }
  • puts(SCT->version);
  • /* genrate a random String */
  • res = GenRandomString(test,17);
  • if(res != SHAMAN_OK)
  • {
  • puts("Cannot Generate Random String");
  • exit(EXIT_FAILURE);
  • }
  • printf("Random String is %s\n\n",test);
  • /* prepare to hash */
  • ShaManAdd(SCT,test);
  • /* core hash module */
  • for(i = 0 ; i<= BASE64_HASH ; i++ )
  • {
  • SCT->meth = i ;
  • res = ShaManHashData(SCT);
  • if(res != SHAMAN_OK)
  • {
  • puts("Error While Hasing Data");
  • continue ;
  • }
  • printf("%s Hex Code is:\n\t %s\n\n",HAMETH[i],SCT->hash);
  • }
  • SCT->meth = SHA1_HASH;
  • ShaManFileCheckSum(SCT,"./license.txt");
  • printf("License.txt Checksum(SHA1): %s\n",SCT->hash);
  • SCT->meth = SHA256_HASH;
  • ShaManFileCheckSum(SCT,"./license.txt");
  • printf("License.txt Checksum(SHA256): %s\n",SCT->hash);
  • SCT->meth = MD5_HASH;
  • ShaManFileCheckSum(SCT,"./license.txt");
  • printf("License.txt Checksum(MD5): %s\n",SCT->hash);
  • DestroyShaMan(SCT);
  • system("PAUSE");
  • return 0;
  • }
/*
ShaMan Hash Shared Library (SHA1 SHA256 SHA384 SHA512 MD5 BASE64 + random string generator )
Copyright (c) 2007 James Mrad (xtremejames183@msn.com)

Permission is hereby granted, free of charge, to any person obtaining
a copy of this software and associated documentation files (the
"Software"), to deal in the Software without restriction, including
without limitation the rights to use, copy, modify, merge, publish,
distribute, sublicense, and/or sell copies of the Software, and to
permit persons to whom the Software is furnished to do so, subject to
the following conditions:

The above copyright notice and this permission notice shall be included
in all copies or substantial portions of the Software.

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.
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.
*/

/*********************************** API ***********************************************************************/
#ifndef __SHAMAN_H__
#define __SHAMAN_H__

#include <stdio.h> /* FILE */
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <time.h> /* for srand */

/* local */
#include "gdefs.h"
#include "sha1.h"
#include "sha256.h"
#include "sha384.h"
#include "sha512.h"
#include "md5.h"
#include "base64.h"

/* pool memory managment */
#include "pool.h"
/* portable&&safe snprintf */
#include "snprintf.h"

#define FILE_HASH_SIZE	65635

#define MAX_HASH_BUFFER	SHA512_HASH_SIZE * 5
#define SHAMAN_OK	0
#define SHAMAN_VER	"Shaman Hash Library V2.1"

typedef enum
{
	/* supported Method */
	SHA1_HASH,
	SHA256_HASH,
	SHA384_HASH,
	SHA512_HASH,
	MD5_HASH,
	BASE64_HASH /* lol :-) */

}HASHMETH; /* Hash method */
typedef struct shaman_st
{
	uint8_t	*clear; /* clear chain */

	HASHMETH	meth;
	FILE	*fp;
	pool	p;

	uint8_t	*hash ; /* final hash chain */

	uint8_t	*version ; /* SHAMAN Version */
}SHAMAN_CTX;

/**
* Util codes
* Generate Random String 
* @param output: data will be copied to output , hide : optional 1/true if yu want to hash it using SHA1
* @return SHAMAN_OK on succes , -1 on failure
*/
int GenRandomString(uint8_t	*output,unsigned long	len);
/**
* Read a file and return it as buffer
* @param open File Pointer
* @ return a malloced buffer (must be freed) on success , -1 on failure
*/
uint8_t	*XReadFile(FILE	*fp);

#if defined _WIN32 || !defined HAVE_BZERO
/* bzero for NON POSIX */
void bzero(void *buf, size_t buf_size) ;
#endif 

/* Core Code */
/**
* Init ShaMan Context
* By default HashMethod is SHA256 */
SHAMAN_CTX	*	InitShaMan(void);
/**
* Prepare string for Hash Operation
* @param SHAMAN_CTX Not NULL , a cstr (NOT NULL)
* @return SHAMAN_OK on succes , -1 on failure
*/
int ShaManAdd(SHAMAN_CTX	*sctx,uint8_t *cstr);
/*
* Main Hash Processing
* Hash the clear buffer and copy its hex code to hash(member of CTX)
* @param CTX with clear buffer (NOT NULL)
* @return sctx->hash : the HEX Code && SHAMAN_OK on Sucess , -1 on failure
*/
int ShaManHashData(SHAMAN_CTX	*sctx);
/*
* Do File Checksum
* Hash the file named fname (must not exceed < FILE HASH_SIZE )
* @param CTX all is done done internally
* @return sctx->hash on sucess , -1 on failure
*/
int ShaManFileCheckSum(SHAMAN_CTX	*sctx,char	*fname);
/*
* Destructor OO Style
*/
int DestroyShaMan(SHAMAN_CTX	*sctx);


#endif
/******************************** TEST DE L'API ***************************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>

#include "shaman.h"

int	main(int argc,char	*argv[])
{

	SHAMAN_CTX	*SCT; /* Context ShaMan */
	int res ;
	uint8_t	test[512];
	int i;
	char HAMETH[6][10] = { "SHA1","SHA256","SHA384","SHA512","MD5","BASE64" } ;
	/* Init Shaman Library*/

	SCT = InitShaMan() ;
	
	if( SCT == NULL)
	{
		puts("Cannot Load ShaMan Library");
		exit(EXIT_FAILURE);
	}
	puts(SCT->version);
	
	/* genrate a random String */
	res = GenRandomString(test,17);
	if(res != SHAMAN_OK)
	{
		puts("Cannot Generate Random String");
		exit(EXIT_FAILURE);
	}
	printf("Random String is %s\n\n",test);


	/* prepare to hash */
	ShaManAdd(SCT,test);

	/* core hash module */
	for(i = 0 ; i<= BASE64_HASH ; i++ )
	{
	SCT->meth = i ;
	res = ShaManHashData(SCT);

	if(res != SHAMAN_OK)
	{
		puts("Error While Hasing Data");
		continue ;
	}
	printf("%s Hex Code is:\n\t %s\n\n",HAMETH[i],SCT->hash);

	}

	SCT->meth = SHA1_HASH;
	ShaManFileCheckSum(SCT,"./license.txt");
	printf("License.txt Checksum(SHA1): %s\n",SCT->hash);
	SCT->meth = SHA256_HASH;
	ShaManFileCheckSum(SCT,"./license.txt");
	printf("License.txt Checksum(SHA256): %s\n",SCT->hash);
	SCT->meth = MD5_HASH;
	ShaManFileCheckSum(SCT,"./license.txt");
	printf("License.txt Checksum(MD5): %s\n",SCT->hash);


	DestroyShaMan(SCT);

	system("PAUSE");
	return 0;
}

 Conclusion

voila j'espere que ca seras utiles pour vos ...
j'attends vos critiques
PS: si ma methode de programmation vous semble bizare (normal elle est inspire de la methode de PROG de Berkeley)

 Fichier Zip

Les Membres Club peuvent télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip


 Sources du même auteur

Source avec Zip Source avec une capture COMPRESSION FICHIERS ALGORITHME HUFFMAN C
Source avec Zip Source avec une capture CLEX ANALYSEUR LEXICALE DU LANGAGE C
ITOA FAIT MASION: COVERSION ENTIER 32 BIT NON SIGNE VERS CHA...
Source avec Zip COMBSORT ALGORITHME DE TRI SIMPLE RAPIDE NON-RECURSIF
Source avec Zip CONNEXION A UNE BD SQLITE

 Sources de la même categorie

Source avec Zip Source avec une capture CRYPTEUR-DÉCRYPTEUR-IP par antho974
Source avec Zip Source avec une capture ELGAMALCIPHER par CHAR As Human
Source avec Zip CRYPTER-DECRYPTER EN UTILISANT L'ALGORITHME DE CESAR par Antoinejdu44
Source avec Zip CRYPT-O-MATIC "DARKCHOCOLATE" par FrancoisGauthier
Source avec Zip CREEP SECURITY ALGORITHM par nanonavich

 Sources en rapport avec celle ci

Source avec Zip DLLMAKER V2.0 par Altaris
Source avec Zip Source avec une capture [C/WIN32] INJECTION DE DLL 2 MÉTHODES (REMOTETHREAD PROPRE &... par deck_bsd
Source avec Zip CHECKSUM MD5 D'UN FICHIER C par xtremejames183
Source avec Zip Source avec une capture HASH FINDER - CALCULATEUR DE HASH EN C par ordiman85
Source avec Zip DIFFERENTS TYPES DE CODAGE POUR HOSTNAME OU IP par BuGs59

Commentaires et avis

Aucun commentaire pour le moment.

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

hash md5 [ par flatou ] salut a tousje travail sur un projet en c qui doit utiliser le hashage md5. je me suis inspiré donc de cette source (pour faire simple) :http://www.cp inversion md5 [ par emmatopiak ] Bonjour J'ai vu qu'un ami a fait un code pour inverser un hash md5, en force brute. Actuellement, c'est en PHP. Je me demandais si ca vaudrait pa vc2005 dll [ par lilington ] Bonjourvoila je viens d'installer msvc2005 le probleme c'est que je ne peux pas executer mes prog.je recois un message windows disant que la dll:msvcr comment créer une dll en vc++ 2005 [ par lhoua94 ] Bonjour,Je souhaite créer une DLL en VC++ 2005  pour un pocket pc 2005 ou un smartphone  que l'on  puisse appeler depuis un autre projet sous WINDEV . comment créer une dll en vc 2005 [ par lhoua94 ] Bonjour,Je souhaite créer une DLL en VC++ 2005  pour un pocket pc 2005 ou un smartphone  que l'on  puisse appeler depuis un a DLL windows [ par zoomeo ] Salut les gars!Je dois bosser sur un prog et j'aimerai avoir des precisions car c'est un peu confu tout ca pour moi...En gros, pour mon programme, je dll pour vb6 [ par draluorg ] Salut a tous,J'essai de faire une dll en C pour utiliser sous vb6, mais je recois toujours le message "Bad dll Calling Convention" depuis vb6 :(Voici utilisation d'une dll.net en C [ par thmatew ] Bonjour a tous,Voila mon souci, j'ai besoin d'intégrer une dll.NET en C, j'aimerais savoir comment faire pour utiliser cette dll???!!!!j'utilise Visua importer une dll [ par omtp13 ] Salut tout le monde,je désire importer les fonctions d'une dll pour que ces fonctions puissent être utilisées dans le code d'une seconde dll.j'ai ente Executer une dll comme un programme? [ par Neo_Fr ] Salut,Est - il possible d'éxecuter une dll comme un programme?Si oui comment?Neo_Fr


Nos sponsors


Sondage...

CalendriCode

Février 2010
LMMJVSD
1234567
891011121314
15161718192021
22232425262728

Consulter la suite du CalendriCode

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,749 sec (4)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales