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

Jasper Discussion :

Exécution d'un rapport via une url utilisant un paramètre à plusieurs valeurs


Sujet :

Jasper

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    26
    Détails du profil
    Informations personnelles :
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Juin 2009
    Messages : 26
    Points : 27
    Points
    27
    Par défaut Exécution d'un rapport via une url utilisant un paramètre à plusieurs valeurs
    Bonjour,

    Je débute sur Jasper Reports et rencontre le problème suivant :

    J'ai un rapport publié sur mon serveur JasperServer.
    Celui-ci contient un input control avec Prompt :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Nom = Parcel
    Type = Multi-select query
    Quand j'exécute mon rapport depuis I-Reports, ou depuis le portail JasperServer, mon rapport se remplit bien.
    Mais je souhaite appeler ce rapport en passant les paramètres dans l'url, si je ne sais pas comment renseigner plusieurs valeurs pour le paramètre Parcel.

    Dans mon rapport, j'ai un paramètre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Parcel de type Java.util.Collection
    valeur par défaut : new ArrayList(Arrays.asList(new String[] {"ZK0040"}))
    Ma requête utilise ce paramètre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    select a.id_parcel, b.nom_prop, b.adress from parcel a, prop b
    where a.id_parcel=b.id_parcel
    and $X{IN,a.id_parcel,Parcel}
    order by b.nom_prop
    L'url (quand je n'ai qu'une valeur pour Parcel) que j'envoie est la suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    http://server:8080/jasperserver/flow.html?_flowId=viewReportFlow&ParentFolderUri=%2FDBASE%2FRapports&ndefined=&standAlone=true&reportUnit=%2FGEOPARCEL%2FRapports%2FConv&j_username=jasperadmin&j_password=jasperadmin&Parcel=ZN0202
    Comment faire pour mettre deux valeurs à Parcel?

    J'ai essayé ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    http://server:8080/jasperserver/flow.html?_flowId=viewReportFlow&ParentFolderUri=%2FDBASE%2FRapports&ndefined=&standAlone=true&reportUnit=%2FGEOPARCEL%2FRapports%2FConv&j_username=jasperadmin&j_password=jasperadmin&Parcel=ZN0202&Parcel=ZN0203
    Résultat : Je n'ai que la première valeur de Parcel traitée

    J'ai fait d'autres tentatives en mettant Parcel=ZN0202,ZN0203 ou Parcel=(ZN0202,ZN0203) en traduisant les (,) et %28, %2C, %29.

    Rien n'y fait.

    Avez-vous une idée?

    J'utilise Jasper Server 3.7.0 sous Windows 2003 R2 SP2 et I-Reports 3.7.3

  2. #2
    Membre averti

    Homme Profil pro
    Consultant informatique
    Inscrit en
    Août 2007
    Messages
    293
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 79
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Service public

    Informations forums :
    Inscription : Août 2007
    Messages : 293
    Points : 440
    Points
    440
    Par défaut
    Bonjour,
    J'ai eu une fois ce type de problème. Ce que j'ai fait c'est de ne pas utiliser de type "collection" mais d'utiliser un type "string" et je passe donc un paramètre qui contient , par exemple, "(1,2,3,4,5)"
    et dans ma requête j'ai la condition "classique":

    where champ in $P!{Param}

    (Param contient la chaine citée plus haut)

    Ca ne pose pas de problème pour passer la string dans l'URL

    Par contre l'utilisation avec un input control et un multi-select est un peu plus complexe : il faut "caster" la java.util.collection vers un string et remplacer les "[" et "]" par des parenthèses.

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    26
    Détails du profil
    Informations personnelles :
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Juin 2009
    Messages : 26
    Points : 27
    Points
    27
    Par défaut
    Bonjour et merci pour la réponse.
    J'ai tenté de simplifier mon problème en supprimant les input controls.

    Mon paramètre Parcel est défini dans le jrxml comme un string.

    Ma requête est redéfinie comme suit :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select ... where id_parcel in $P!{Parcel}
    ORA-00933 : LA commande SQL ne se termine pas correctement

    Ca ne fonctionne pas -> Erreur Oracle
    ORA-00933 : LA commande ne se termine pas correctement

    Du coup, je ne vois pas trop de solution.

    D'autre part, si le premier point fonctionne, mes valeurs sont du texte, donc dans mon url, je dois mettre la chaîne suivante ?
    (ZN0202, ZN0203) ou ('ZN0202', 'ZN0203')

    Merci d'avance pour l'aide.

  4. #4
    Membre averti

    Homme Profil pro
    Consultant informatique
    Inscrit en
    Août 2007
    Messages
    293
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 79
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Service public

    Informations forums :
    Inscription : Août 2007
    Messages : 293
    Points : 440
    Points
    440
    Par défaut
    Dans mon exemple les valeurs que je passe sont des "id" donc des nombres, mais je passe le paramètre sous forme de string et non pas de "collection".

    Donc dans ton cas tu devrais passer :

    "('ZN0202', 'ZN0203')"

    Pour vérifier si le paramètre que tu reçois effectivement est bien conforme à ce que tu attends, je te conseille d'utiliser une requête qui "marche à tous les coups" du style "select 1 from dual" en oracle et dans ton rapport tu fais simplement imprimer le paramètre reçu : çà te permet de vérifier. C'est souvent à ce niveau que l'on a des surprises.

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    26
    Détails du profil
    Informations personnelles :
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Juin 2009
    Messages : 26
    Points : 27
    Points
    27
    Par défaut Remerciements
    Merci infiniment Gabriel !
    Il me semble qu'il me reste encore un long chemin à parcourir avant de maîtriser les subtilités de Jasper, mais je suis en marche.

    Cordialement.

    Jila.

  6. #6
    Membre éprouvé

    Inscrit en
    Janvier 2009
    Messages
    467
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 467
    Points : 1 253
    Points
    1 253
    Billets dans le blog
    2
    Par défaut
    Je n'ai jamais travaillé en cherchant à passer des paramètres dans l'URL, mais je sais que quand on interroge JasperServeur par SOAP, il faut répéter le paramètre avec un attribut indiquant qu'on est en train d'envoyer

    De même j'avais découvert que quand on a une multi select dans un form HTML qui permet formait une requète GET de type ;

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    http://url.com/?f[]=val1&f[]=val2
    (ou f est la nom du tableau qui contient (val1 et val2)



    Peut être que cela marche pareil avec le serveur JasperServer.

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

Discussions similaires

  1. Réponses: 13
    Dernier message: 06/02/2010, 16h53
  2. Exécution de code via une URL
    Par PeteZah dans le forum Services Web
    Réponses: 9
    Dernier message: 30/05/2008, 13h56
  3. Passer deux variables via une URL
    Par 123quatre dans le forum Langage
    Réponses: 8
    Dernier message: 28/06/2007, 19h02
  4. Accéder au contenu d'un fichier via une URL en mode binaire
    Par sbelli dans le forum API standards et tierces
    Réponses: 4
    Dernier message: 11/10/2005, 10h25
  5. [net] recuperer les proprietes d'un File via une URL
    Par mma dans le forum Entrée/Sortie
    Réponses: 5
    Dernier message: 06/05/2004, 12h45

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