IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Sécurité Java Discussion :

Problème cipher / 3DES/ mode CFB


Sujet :

Sécurité Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2005
    Messages
    489
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2005
    Messages : 489
    Par défaut Problème cipher / 3DES/ mode CFB
    Bonjour à tous,

    Voilà, jusqu'à présent, j'utilise déjà le cryptage 3DES dans un environnement PHP pour des échanges de données avec des sites extérieurs. Tout fonctionne très bien.

    Actuellement, je développe des web services en java, dans lesquels je dois utiliser le même mode de cryptage pour atteindre mon autre serveur en PHP.

    Le cryptage en lui-même fonctionne, mais sur mon serveur PHP, je n'arrive pas à décrypter correctement.

    Voici mon code java
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
     
    public class CryptData {
    	private KeySpec keySpec;
    	private SecretKey key;
    	private IvParameterSpec iv;
     
    	public CryptData(String keyString, String ivString) {
    		try {
    			final MessageDigest md = MessageDigest.getInstance("md5");
    			final byte[] digestOfPassword = md.digest(Base64
    					.decodeBase64(keyString.getBytes("utf-8")));
    			final byte[] keyBytes = Arrays.copyOf(digestOfPassword, 24);
    			for (int j = 0, k = 16; j < 8;) {
    				keyBytes[k++] = keyBytes[j++];
    			}
     
    			keySpec = new DESedeKeySpec(keyBytes);
     
    			key = SecretKeyFactory.getInstance("DESede")
    					.generateSecret(keySpec);
     
    			iv = new IvParameterSpec(ivString.getBytes());
    		} catch (Exception e) {
    			e.printStackTrace();
    		}
    	}
     
    	public String encrypt(String value) {
    		try {
    			Cipher ecipher = Cipher.getInstance("DESede/CFB/PKCS5Padding",
    					"SunJCE");
    			ecipher.init(Cipher.ENCRYPT_MODE, key, iv);
     
    			if (value == null)
    				return null;
     
    			// Encode the string into bytes using utf-8
    			byte[] utf8 = value.getBytes("UTF8");
     
    			// Encrypt
    			byte[] enc = ecipher.doFinal(utf8);
     
    			// Encode bytes to base64 to get a string
    			return new String(Base64.encodeBase64(enc), "UTF-8");
    		} catch (Exception e) {
    			e.printStackTrace();
    		}
    		return null;
    	}
    }
    et mon serveur PHP
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    $montant = "AlcGCGBoh84=";
     
    $montant = base64_decode($montant);
     
    //$montant = utf8_decode($montant);
     
    $message_crypte = mcrypt_decrypt(MCRYPT_3DES, $maKey, $montant, ,CRYPT_MODE_CFB, $iv);
    Auriez-vous une idée qui expliquerait pourquoi ça ne fonctionne pas?

    D'avance merci

    Vince

  2. #2
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Mai 2012
    Messages
    535
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2012
    Messages : 535
    Par défaut
    salut!

    as-tu réussi à solutionner le problème?

  3. #3
    Membre confirmé Avatar de TheZopo
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2012
    Messages
    29
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 26
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2012
    Messages : 29
    Par défaut
    Magnifique up (4 mois et demis), de plus on dit "résoudre" et pas "solutionner"

  4. #4
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Mai 2012
    Messages
    535
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mai 2012
    Messages : 535
    Par défaut
    Merci pour cette remarquable intervention qui fait bien avancer le schmillblick.........

    Et pour info: http://fr.wiktionary.org/wiki/solutionner

Discussions similaires

  1. [TP] Problème avec le mode VESA
    Par dectroo dans le forum Turbo Pascal
    Réponses: 5
    Dernier message: 29/01/2007, 13h44
  2. problème avec setsockopt() mode RAW
    Par poporiding dans le forum Windows
    Réponses: 20
    Dernier message: 25/04/2006, 14h41
  3. problème avec setsockopt() mode RAW
    Par poporiding dans le forum C++
    Réponses: 15
    Dernier message: 24/04/2006, 17h17
  4. [VB.NET] Problème exécution en mode release.
    Par leSeb dans le forum Windows Forms
    Réponses: 2
    Dernier message: 07/01/2005, 17h39

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo