begin process at 2010 09 03 07:31:04
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Applications

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

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


 Information sur la source

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

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10
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é :145 748 / 847

Auteur : FloZix

Ecrire un message privé
Site perso
Commentaire sur cette source (3)
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

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


 Historique

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

 Sources du même auteur

Source avec Zip Source avec une capture Source .NET (Dotnet) BINDING OBJET (CODUS 1.3, VC#)

 Sources de la même categorie

Source avec Zip Source avec une capture Source .NET (Dotnet) CRYPTOGRAPHY V2 par DanMor498
Source avec Zip Source avec une capture Source .NET (Dotnet) UN COMPILATEUR C#.NET par ayoube2009
Source avec Zip Source .NET (Dotnet) CRYSTALREPORT C# SQLSERVER par badis1996
Source avec Zip Source .NET (Dotnet) THREADWORKER par krimog
Source avec Zip Source .NET (Dotnet) INTERVENTION INFORMATIQUE par monssif007

 Sources en rapport avec celle ci

Source avec Zip Source .NET (Dotnet) COPIE DE CLÉ USB AUTOMATIQUE par pigedanslelac
Source avec Zip Source avec une capture Source .NET (Dotnet) CALCUL D'EMPREINTES DE FICHIERS par lex35
Source avec Zip Source avec une capture Source .NET (Dotnet) CRYPTAGE PAR CESAR par youma85
Source avec Zip Source .NET (Dotnet) MOTEUR DE PLUGINS AVEC CHARGEMENT/DÉCHARGEMENT par maitredede
Source avec Zip Source avec une capture Source .NET (Dotnet) GESTIONNAIRE DE MOTS DE PASSE par angelofdeath08

Commentaires et avis

Commentaire de georgeduke le 25/05/2006 19:49:08

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

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

Commentaire de toro2008 le 23/12/2008 19:04:03

There is a mistake:

#  public bool VerifierINSEE(string strNumero, string strCle)
# {
# if (CalculerCleINSEE(strNumero).ToString() == strCle)
# return true;
# else
# return false;
# }

Example. If CalculerCleINSEE return 9 and strCle is "09", the test will fail.

Alternative solution will be:
try
        {
            if (CalculerCleINSEE(strNumero) == Int16.Parse(strCle))
                return true;
            else
                return false;
        }
        catch
        {
            return false;
        }

But it can be done in a better way. ;)

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

Comparez les prix

CalendriCode

Septembre 2010
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
27282930   

Consulter la suite du CalendriCode

Photothèque

 
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,640 sec (4)

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