Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

VERIFICATION D'UN NUMÉRO INSEE (SÉCURITÉ SOCIALE)


Information sur la source

Catégorie :Applications Source .NET ( DotNet ) Classé sous : insee, sécurité, sociale, nir Niveau : Débutant Date de création : 08/05/2006 Date de mise à jour : 25/11/2007 20:25:05 Vu / téléchargé: 108 623 / 648

Note :
10 / 10 - par 2 personnes
10,00 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10

Commentaire sur cette source (2)
Ajouter un commentaire et/ou une note

Description

Cliquez pour voir la capture en taille normale
Une petite classe pour vérifier la validité d’un numéro de sécu. La classe effectue le calcul de la clé puis compare avec le numéro saisi.
Le tout livré avec un petit programme de test.
 

Source

  • using System;
  • using System.Text.RegularExpressions;
  • namespace INSEE
  • {
  • class NumeroINSEE
  • {
  • /// <summary>
  • /// Constante pour le calcul de la clé
  • /// </summary>
  • private const Int16 CLE_VERIF = 97;
  • /// <summary>
  • /// Nombre de caractère du numéro INSEE
  • /// </summary>
  • private const Int16 NB_CARACTERES = 13;
  • #region "Constructeur"
  • /// <summary>
  • /// Constructeur par défaut
  • /// </summary>
  • public NumeroINSEE()
  • {
  • }
  • #endregion
  • #region "Méthodes publiques"
  • /// <summary>
  • /// Verifie le numéro INSEE passé en paramètre (numero + clé)
  • /// </summary>
  • /// <param name="strNumero">Numéro INSEE</param>
  • /// <param name="strCle">Clé de verification du numéro INSEE</param>
  • /// <returns>True si le numéro et la clé sont cohérents, sinon false</returns>
  • public bool VerifierINSEE(string strNumero, string strCle)
  • {
  • if (CalculerCleINSEE(strNumero).ToString() == strCle)
  • return true;
  • else
  • return false;
  • }
  • /// <summary>
  • /// Verifie le numéro INSEE passé en paramètre
  • /// </summary>
  • /// <param name="strNumero">Numéro INSEE avec la clé</param>
  • /// <returns>True si le numéro et la clé sont cohérent, sinon false</returns>
  • public bool VerifierINSEE(string strNumero)
  • {
  • string strCle = "";
  • strNumero = NettoyerString(strNumero);
  • try
  • {
  • strCle = strNumero.Remove(0, NB_CARACTERES);
  • strNumero = strNumero.Remove(NB_CARACTERES);
  • }
  • catch
  • {
  • // il manque des caractères
  • return false;
  • }
  • return VerifierINSEE(strNumero, strCle);
  • }
  • /// <summary>
  • /// Calcul la clé correspondante au numéro INSEE passé en paramètre
  • /// </summary>
  • /// <param name="strNumero">Numero INSEE</param>
  • /// <returns>Clé du numéro INSEE passé en paramètre, 0 si numéro invalide</returns>
  • public Int16 CalculerCleINSEE(string strNumero)
  • {
  • // clé retournée
  • Int16 cle = 0;
  • // numéro apres convertion
  • Int64 numero = NumeroEnInt(strNumero);
  • if (numero != 0)
  • {
  • cle = (short)(CLE_VERIF - (numero % CLE_VERIF));
  • }
  • return cle;
  • }
  • #endregion
  • #region "Méthodes privées"
  • /// <summary>
  • /// Enlève les caractères ne pouvant faire partie du numéro
  • /// A-Z0-9 uniquement
  • /// </summary>
  • /// <param name="strNumero">Numéro INSEE</param>
  • /// <returns>Retourne la chaîne épurée</returns>
  • private string NettoyerString(string strNumero)
  • {
  • strNumero = strNumero.ToUpper();
  • Regex regINSEE = new Regex("[^A-Z0-9_]");
  • strNumero = regINSEE.Replace(strNumero, "");
  • return strNumero;
  • }
  • /// <summary>
  • /// Convertion du numéro (string) en entier
  • /// </summary>
  • /// <param name="strNumero">Numéro INSEE</param>
  • /// <returns>Retourne le numéro INSEE sous forme d'un entier, 0 si numéro invalide</returns>
  • private Int64 NumeroEnInt(string strNumero)
  • {
  • // le numero apres convertion
  • long numero = 0;
  • // Pour les Corses !
  • // Emplacement de la lettre pour les corses
  • const Int16 INDICE_LETTRE_CORSE = 6;
  • // Constante pour calcul Corse 2A
  • const Int32 CORSEA = 1000000;
  • // Constante pour calcul Corse 2B
  • const Int32 CORSEB = 2000000;
  • strNumero = NettoyerString(strNumero);
  • // le numero doit faire NB_CARACTERES sinon c'est pas
  • // la peine d'aller plus loin
  • if (strNumero.Length != NB_CARACTERES)
  • return numero;
  • // convertion en entier, si la chaîne ne peut etre convertie
  • // soit une erreur, soit un Corse...
  • if (!long.TryParse(strNumero, out numero))
  • {
  • // verification du 7eme caractère
  • if (strNumero[INDICE_LETTRE_CORSE] == 'A')
  • {
  • // un Corse du Sud
  • strNumero = strNumero.Replace('A', '0');
  • if (long.TryParse(strNumero, out numero))
  • {
  • numero -= CORSEA;
  • }
  • }
  • else if (strNumero[INDICE_LETTRE_CORSE] == 'B')
  • {
  • // Haute Corse
  • strNumero = strNumero.Replace('B', '0');
  • if (long.TryParse(strNumero, out numero))
  • {
  • numero -= CORSEB;
  • }
  • }
  • }
  • return numero;
  • }
  • #endregion
  • }
  • }
using System;
using System.Text.RegularExpressions;

namespace INSEE
{
    class NumeroINSEE
    {
        /// <summary>
        /// Constante pour le calcul de la clé
        /// </summary>
        private const Int16 CLE_VERIF = 97;
        /// <summary>
        /// Nombre de caractère du numéro INSEE
        /// </summary>
        private const Int16 NB_CARACTERES = 13;
        

        #region "Constructeur"
        /// <summary>
        /// Constructeur par défaut
        /// </summary>
        public NumeroINSEE()
        {
        }
        #endregion

        #region "Méthodes publiques"
        /// <summary>
        /// Verifie le numéro INSEE passé en paramètre (numero + clé)
        /// </summary>
        /// <param name="strNumero">Numéro INSEE</param>
        /// <param name="strCle">Clé de verification du numéro INSEE</param>
        /// <returns>True si le numéro et la clé sont cohérents, sinon false</returns>
        public bool VerifierINSEE(string strNumero, string strCle)
        {
            if (CalculerCleINSEE(strNumero).ToString() == strCle)
                return true;
            else
                return false;
        }

        /// <summary>
        /// Verifie le numéro INSEE passé en paramètre
        /// </summary>
        /// <param name="strNumero">Numéro INSEE avec la clé</param>
        /// <returns>True si le numéro et la clé sont cohérent, sinon false</returns>
        public bool VerifierINSEE(string strNumero)
        {
            string strCle = "";
            strNumero = NettoyerString(strNumero);

            try
            {
                strCle = strNumero.Remove(0, NB_CARACTERES);
                strNumero = strNumero.Remove(NB_CARACTERES);
            }
            catch
            {
                // il manque des caractères
                return false;
            }

            return VerifierINSEE(strNumero, strCle);
        }

        /// <summary>
        /// Calcul la clé correspondante au numéro INSEE passé en paramètre
        /// </summary>
        /// <param name="strNumero">Numero INSEE</param>
        /// <returns>Clé du numéro INSEE passé en paramètre, 0 si numéro invalide</returns>
        public Int16 CalculerCleINSEE(string strNumero)
        {
            // clé retournée
            Int16 cle = 0;
            // numéro apres convertion
            Int64 numero = NumeroEnInt(strNumero);

            if (numero != 0)
            {
                cle = (short)(CLE_VERIF - (numero % CLE_VERIF));
            }

            return cle;
        }
        #endregion

        #region "Méthodes privées"
        /// <summary>
        /// Enlève les caractères ne pouvant faire partie du numéro
        /// A-Z0-9 uniquement
        /// </summary>
        /// <param name="strNumero">Numéro INSEE</param>
        /// <returns>Retourne la chaîne épurée</returns>
        private string NettoyerString(string strNumero)
        {
            strNumero = strNumero.ToUpper();
            Regex regINSEE = new Regex("[^A-Z0-9_]");
            strNumero = regINSEE.Replace(strNumero, "");

            return strNumero;
        }

        /// <summary>
        /// Convertion du numéro (string) en entier
        /// </summary>
        /// <param name="strNumero">Numéro INSEE</param>
        /// <returns>Retourne le numéro INSEE sous forme d'un entier, 0 si numéro invalide</returns>
        private Int64 NumeroEnInt(string strNumero)
        {
            // le numero apres convertion
            long numero = 0;

            // Pour les Corses !
            // Emplacement de la lettre pour les corses
            const Int16 INDICE_LETTRE_CORSE = 6;
            // Constante pour calcul Corse 2A
            const Int32 CORSEA = 1000000;
            // Constante pour calcul Corse 2B
            const Int32 CORSEB = 2000000;

            strNumero = NettoyerString(strNumero);
            
            // le numero doit faire NB_CARACTERES sinon c'est pas
            // la peine d'aller plus loin
            if (strNumero.Length != NB_CARACTERES)
                return numero;

            // convertion en entier, si la chaîne ne peut etre convertie
            // soit une erreur, soit un Corse...
            if (!long.TryParse(strNumero, out numero))
            {
                // verification du 7eme caractère
                if (strNumero[INDICE_LETTRE_CORSE] == 'A')
                {
                    // un Corse du Sud
                    strNumero = strNumero.Replace('A', '0');
                    if (long.TryParse(strNumero, out numero))
                    {
                        numero -= CORSEA;
                    }
                }
                else if (strNumero[INDICE_LETTRE_CORSE] == 'B')
                {
                    // Haute Corse
                    strNumero = strNumero.Replace('B', '0');
                    if (long.TryParse(strNumero, out numero))
                    {
                        numero -= CORSEB;
                    }
                }
            }

            return numero;
        }
        #endregion
    }
}

Fichier Zip

Pour les "Membres Club", vous pouvez télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip

Historique

25 novembre 2007 20:25:06 :
suppression du lien vers site perso

Commentaires et avis

signaler à un administrateur
Commentaire de georgeduke le 25/05/2006 19:49:08

Merci :-) Bien utile + source bien commentée = 10/10

signaler à un administrateur
Commentaire de Kniom59 le 17/08/2008 23:40:41

Cette classe ne contient aucun membre variable. Il serait judicieux d'en faire une classe statique.

De plus, sauf erreur de ma part, il me semble que cette classe peut aussi être utilisée pour la vérification des RIBs

Ajouter un commentaire

Discussions en rapport avec ce code source dans le forum

Securite et mise a jour des données [ par aeled ] lors d'une mise à jour d'une base de données via un formulaire, la sécurité est telle qu'elle n'accepte pas les balises du type &lt;br&gt;il se produi Projet de sécurité [ par UniCyclon ] Salut,Je représente Sy-Labs, une assoc globale basée sur les technologies informatiques, et plus particulièrement Subria, qui a pour but d'augmenter l Sécurité => authorization avec roles [ par Kati83 ] Bonjour,Je voudrais avoir quelques informations concernant la sécurité pour les webforms.En fait, je voudrais définir plusieurs roles (dans mon web.co politique de sécurité des logiciels [ par nnnax ] Salut à tous,J'ai crée un logiciel (avec sharpdevelop) et je voudrais en restreindre l'acces à des utilisateurs auxquels j'aurai au préalable fournit sécurité tcp/client [ par Fildomen ] salutje peux savoir s'il existe ou peut exister des applications qui peuvent avoir les données écrites dans les ports???mercihttp://www.devportail.tk Remoting et "sécurité" [ par CMatt ] Bonjour tout le monde!J'ai commenc&#233; &#224; d&#233;velopper un jeu en temps r&#233;el&nbsp;et j'essaie d'impl&#233;menter un mode multijoueurs (pa Patch sécurité [ par MorpionMx ] Comme je sais pas ou poster ca (pas de blog), je met ca dans le forum : Il y a une mise a jour de s&#233;curit&#233; pour le Framework .NET 1.1, tele Sécurité fichier excel [ par tenrod ] Bonsoir a tous ! Bon voila je fais une appli en c# ki li les fichiers excel pour ins&#233;rer les donn&#233;es dans une base sql server. Tout marche b Probleme sécurité [ par martok ] Bonjour, J'ai développé un programme C# qui s'exécute sans problème. Mais quand je l'exécute sur une machine distante, j'ai une exception qui est lev Windows form + problème de stratégie de sécurité [ par alexSot ] Salut les garsJe m'en remets &#224; vous car j'ai un blem qui est le suivant: * j'ai concu une appli windows form qui est lanc&#233;e sur un serveur &


Nos sponsors

Sondage...

CalendriCode

Novembre 2008
LMMJVSD
     12
3456789
10111213141516
17181920212223
24252627282930

Consulter la suite du CalendriCode



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel BAÏSE, 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
Temps d'éxécution de la page : 0,203 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.