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 :

[bouncycastle][signature][jeton]


Sujet :

Sécurité Java

  1. #1
    Membre régulier
    Homme Profil pro
    responsable technique
    Inscrit en
    Novembre 2002
    Messages
    100
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : responsable technique

    Informations forums :
    Inscription : Novembre 2002
    Messages : 100
    Points : 89
    Points
    89
    Par défaut [bouncycastle][signature][jeton]
    Bonjour,
    J'utilise l'API bouncycastle pour valider des capsules de signatures CMS.
    La méthode verify sur l'objet SignerInformation me valide bien les signatures de ma capsule.
    Cependant chaque signature possède un jeton d'horodatage, il me faut récupérer ce jeton puis, à l'intérieur de celui-ci, le timestamp. Voici ci-dessous mon code, qui plante à la ligne 4 (classCastException)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    //pour chaque signerInfo de la capsule
    1 ASN1Set unauthenticatedAttributes = signerInfo.getUnauthenticatedAttributes();
    2 Attribute jeton =  new Attribute((ASN1Sequence)unauthenticatedAttributes.getObjectAt(0));
    3 ASN1Set jetonAttrValues = jeton.getAttrValues();
    4 ContentInfo content = ContentInfo.getInstance(jetonAttrValues.getObjectAt(0));
    5 SignedData signedDataJeton = SignedData.getInstance(content.getContent());
    6 ContentInfo jetonInfo = signedDataJeton.getEncapContentInfo();
    7 ByteArrayInputStream bais = new ByteArrayInputStream(((DEROctetString)jetonInfo.getContent()).getOctets());	
    8 ASN1InputStream asnis = new ASN1InputStream(bais);
    9 ASN1Sequence asnseq = ASN1Sequence.getInstance(asnis.readObject());
    10 String timeStampingDate = DERGeneralizedTime.getInstance(asnseq.getObjectAt(4)).getTime();
    merci d'avance de votre aide[/b]

  2. #2
    Membre régulier
    Homme Profil pro
    responsable technique
    Inscrit en
    Novembre 2002
    Messages
    100
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : responsable technique

    Informations forums :
    Inscription : Novembre 2002
    Messages : 100
    Points : 89
    Points
    89
    Par défaut
    En fait j'ai trouvé. C'est tout bétement que mon jeton d'horodatage n'est pas en première position dans les attributs non signés (alors que jusqu'ici nos capsules avaient un jeton en 1ere position). Donc à la ligne 2, le code jetonAttrValues.getObjectAt(0) ne marchait pas. Il faut que je parcours les attributs et retrouver celui dont l'OID est un OID "TimeStampToken".

    Mais cela me pose une autre question. J'ai vu dans l'API BouncyCastle qu'il existe un objet TSTInfo qui permet justement de gérer un Jeton. Qq'un aurait-il une idée de comment l'utiliser avec mon exemple précédent, car j'ai beau chercher, je n'arrive pas a construire un objet TstInfo correct...

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 3
    Dernier message: 22/01/2009, 09h15
  2. [BouncyCastle] Co-Signature d'un document
    Par Eleyone dans le forum Sécurité
    Réponses: 3
    Dernier message: 26/11/2008, 16h52
  3. [BouncyCastle] vérifier signature détachée
    Par amr_at_work dans le forum Sécurité
    Réponses: 4
    Dernier message: 04/06/2008, 09h02
  4. afficher la signature des opérations dans XDE
    Par ChristopheH dans le forum Rational
    Réponses: 1
    Dernier message: 24/05/2004, 15h41

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