Aller au contenu

Leaderboard

Popular Content

Showing content with the highest reputation on 05/09/2015 in all areas

  1. III - PHP et MySQL, l'union fait la force PRÉSENTATION DES BASES DE DONNÉES : Les bases de données vont vous permettre de stocker de nombreuses données et d'interagir avec simplement mais pour cela, il vous faut un minimum de connaissances que nous traiterons dans ce guide. Interactions entre clients, serveur et base de données. Les bases de données se divisent en tableaux (aussi appelés table) : INTERACTIONS ENTRE PHP ET LES BASES DE DONNÉES : Je vous conseille d'avoir un minimum de connaissances sur le langage SQL pour maîtriser les interactions mais les bases seront rappelées. Dans ce cours, nous utiliserons l’interface PDO pour accéder aux bases de données. Tout d’abord, il nous faut établir une connexion avec le serveur MySQL (dans ce cas mais nous pouvons évidemment changer de SGDB) : try { $bdd = new PDO('mysql:host=localhost;dbname=test', 'root', ''); // On ouvre une instance avec "PDO" /* ** "host" : nom de domaine du serveur SQL, ** "dbname" : nom de la base de données, ** Dans les deux derniers arguments, vous devez entrer dans cette ordre votre nom d'utilisateur et votre mot de passe de votre BDD */ } catch(Exception $e) { die('Erreur : '.$e->getMessage()); }Note : Ici j’ai utilisé une exception qui nous permettra de récupérer les erreurs et de les afficher clairement à l’écran. Maintenant que notre connexion est établie, nous pouvons exécuter des requêtes sur notre base de données. Pour cela, vous avez le choix entre deux fonctions : PDO::query : Exécute une requête SQL, retourne un jeu de résultats en tant qu'objet PDOStatement.PDOStatement::execute : Exécute une requête précédemment préparée avec PDO::prepare (Prépare une requête à l'exécution et retourne un objet). Ces fonctions permettent de récupérer des données maintenant, il nous faut quelques fonctions permettant d’agir sur ces données et aussi de les sécuriser pour éviter une injection SQL : PDOStatement::bindValue : Associe une valeur à un paramètre.PDOStatement::bindParam : Lie un paramètre à un nom de variable spécifique.PDOStatement::bindColumn : Lie une colonne à une variable PHP.PDOStatement::fetch : Récupère la ligne suivante d'un jeu de résultats PDO.PDOStatement::fetchAll : Retourne un tableau contenant toutes les lignes du jeu d'enregistrements.PDOStatement::fetchColumn : Retourne une colonne depuis la ligne suivante d'un jeu de résultats.PDOStatement::setFetchMode : Définit le mode de récupération par défaut pour cette requête.PDOStatement::rowCount : Retourne le nombre de lignes affectées par le dernier appel à la fonction PDOStatement::execute. Maintenant, on va écrire une requête SQL mais avant quelques rappels : Sélectionner des données : « SELECT attribut_1, attribut_2 FROM nom_table » (Pour sélectionner le tableau entier, remplacez les attributs par *).Créer une nouvelle ligne : « INSERT INTO table_name(attribut_1, attribut_2) values(valeur_1, valeur_2) ».Mise à jour d’une ligne : « UPDATE nom_table SET attribut_1 = valeur_1, attribut_2 = valeur_2 ».Suppression d’une ligne : « DELETE FROM nom_table WHERE attribut = valeur » (à noter que WHERE peut être utilisé avec n’importe quelle autre fonction vu précédemment)./* CONNEXION AU SERVEUR SQL ICI */ $query = $bdd->prepare('SELECT attributs FROM my_db WHERE attribut = :value'); // Préparation d'un requête de sélection (ici :value est un paramètre de la requête SQL qu’on va associer à une valeur ensuite) $query->bindValue(':value', $value, \PDO::PARAM_STR); // On associe la valeur au paramètre (ce qui évite les injections SQL) $query->execute(); // On exécute la requête $data = $query->fetchAll(); // On associe à un tableau les résultats obtenus avec la requête $query->closeCursor(); // On ferme notre requête
    1 point
  2. II - Les joies du PHP TRANSMISSION DE DONNÉES : Avec PHP, vous pouvez transmettre des données à d'autre page notamment avec deux éléments : l'URL et le forumulaire. Une URL peut etre constituée de la sorte : protocole://domaine/page.extension (prenons l'exemple de Melinyel : http://melinyel.net/index.php). Avec le PHP vous pouvez rajouter des paramètres et leur asigner une valeur comme ceci protocole://domaine/page.extension?param=valeur&param2=valeur2. Ces valeurs peuvent etre récupérées avec la variable superglobale $_GET (exemple : $_GET['param'] retourne "valeur"). Toutefois, chacun peut modifier l'URL et envoyer de fausses données. Avec un formulaire vous avez le choix entre envoyer les données par la méthode get (par l'URL) ou par la méthode post (l'utilisateur ne voit pas les données qu'il a envoyé). Néanmoins, ceci ne nous protège pas contre une attaque mais il existe des moyens pour y remédier que je vous montrerez. <form action="cible.php" method="post"> <p> <input type="text" name="prenom" /> <input type="submit" value="Valider" /> </p> </form>Dans cette exemple, vous pouvez voir qu'on a method="post" : c'est ce que je vous ai expliqué tout à l'heure et action="cible.php" qui sera le fichier de réception de notre formulaire. Concrètement, lorsque que vous cliquez sur le boutton envoyer, vous etes redirigé vers une autre page qui conservera les données du formulaire. La balise <input /> créée un champ avec un type (text, password, subit) et un nom qui nous permettra de récupérer le contenu du champ grace à la variable superglobale $_POST. Actions effectuées lors de l'envoi d'un formulaire. © OpenClassrooms VARIABLES SUPERGLOBALES : Il existe différents types de variables superglobales : $_SERVER : ce sont des valeurs renvoyées par le serveur. Elles sont nombreuses et quelques-unes d'entre elles peuvent nous être d'une grande utilité. Je vous propose de retenir au moins $_SERVER['REMOTE_ADDR']. Elle nous donne l'adresse IP du client qui a demandé à voir la page, ce qui peut être utile pour l'identifier.$_ENV : ce sont des variables d'environnement toujours données par le serveur. C'est le plus souvent sous des serveurs Linux que l'on retrouve des informations dans cette superglobale. Généralement, on ne trouvera rien de bien utile là-dedans pour notre site web.$_SESSION : on y retrouve les variables de session. Ce sont des variables qui restent stockées sur le serveur le temps de la présence d'un visiteur. Nous allons apprendre à nous en servir dans ce chapitre.$_COOKIE : contient les valeurs des cookies enregistrés sur l'ordinateur du visiteur. Cela nous permet de stocker des informations sur l'ordinateur du visiteur pendant plusieurs mois, pour se souvenir de son nom par exemple.$_GET : vous la connaissez, elle contient les données envoyées en paramètres dans l'URL.$_POST : de même, c'est une variable que vous connaissez et qui contient les informations qui viennent d'être envoyées par un formulaire.$_FILES : elle contient la liste des fichiers qui ont été envoyés via le formulaire précédent.Il y a notamment deux variables à retenir : $_SESSION et $_COOKIE. Celle-ci vous serviront dans beaucoup de cas de figure. $_SESSION va stocker des données durant la session de l'utilisateur et son contenu sera détruit lorsque l'utilisateur fermera la session. Pour utiliser cette variable superglobale, vous devez amorcer la session au tout début de votre code avec : <?php session_start(); ?> $_COOKIE va stocker des données cookies chez l'utilisateur. Ainsi, vous pouvez appelé cette variable superglobale pour récupérer des données sur l'utilisateur même s'il a quitté la session qui a remplit ces données. Un cookie se définit avec cette fonction : <?php setcookie('pseudo', 'M@teo21', time() + 365*24*3600, null, null, false, true); ?> Les cookies sous Mozilla Firefox. © OpenClassrooms GESTION DE FICHIER : Tout d'abord, vous devez paramétrer votre fichier pour le rendre accessible à PHP en modifiant son CHMOD à 777. Pour ouvrir votre fichier, il vous faut utiliser la fonction fopen() et vous devez le refermer avec fclose(). Pour lire votre fichier, vous avez deux possibilités : lire caractère par caractère avec la fonction fgetc() ou lire ligne par ligne avec fgets(). Vous pouvez aussi écrire dans votre fichier à l'emplacement du curseur, que vous pouvez déplacer avec cette fonction fseek(), grâce à cette fonction fputs(). Exemple : <?php $mon_fichier = fopen('mon_fichier.ext', 'r+'); // On ouvre le fichier en mode lecture et écriture echo fgets($mon_fichier); // On affiche la première ligne du fichier fseek($mon_fichier, 0); // On met le curseur au début du fichier fputs($mon_fichier, 'du texte'); echo fgets($mon_fichier); // On verra que la ligne est modifié fclose($mon_fichier); // On ferme le fichier ?>
    1 point
  3. I - Commençons à partir de 0 Dès lors que vous utiliserez le langage PHP dans un de vos codes de votre site web, le fichier le contenant doit être impérativement en .php. Vous pourrez à partir de ce fichier écrire du HTML normalement à la différence que vous pourrez rajouter la balise <?php ?> et écrire du code PHP entre celle-ci. VARIABLES ET TEXTE : Contrairement à d'autres langages, déclarer des variables et les afficher grâce à l’instruction echo est une tâche très simple en PHP. Quelques exemples vont vous aider à comprendre : <!-- (Commentaire HTML)Ceci est un commentaire réservé exclusivement au langage HTML --> <?php // Ceci est un commentaire sur une ligne (Commentaire PHP) /* Ceci est un commentaire sur plusieurs lignes (Commentaire PHP) */ /* Variables */ $ma_variable; // Ceci est une variable $ma_variable = 1; // Ceci est une variable valant 1 /* Afficher du texte */ echo 'Du texte'; // Ceci va afficher "Du texte" echo $ma_variable; // Ceci affiche le contenu de "$ma_variable" ?> CONDITIONS ET BOUCLES : Une condition vous permet d’exécuter des scripts différents en fonction de certains critères. Vous trouverez notamment deux types de conditions : la condition if...else et la condition switch. Elles s'utilisent de cette manière : <?php // Avec if...else if ($autorisation_entrer == 1) // SI on a l'autorisation d'entrer { // instructions à exécuter quand on est autorisé à entrer } else if ($autorisation_entrer == 0) // SINON SI on n'a pas l'autorisation d'entrer { // instructions à exécuter quand on n'est pas autorisé à entrer } else // SINON (la variable ne contient ni Oui ni Non, on ne peut pas agir) { echo "Euh, je ne connais pas ton âge, tu peux me le rappeler s'il te plaît ?"; } // Avec switch switch ($autorisation_entrer) { case 0: // instructions à exécuter quand on n'est pas autorisé à entrer break; case 1: // instructions à exécuter quand on est autorisé à entrer break; default: echo "Euh, je ne connais pas ton âge, tu peux me le rappeler s'il te plaît ?"; break; } ?>Dans mon exemple, j'utilise des symboles comparateur que vous devez absolument connaître : == Est égal à === Est équivalent à > Est strictement supérieur à < Est inférieur supérieur à >= Est supérieur ou égal à <= Est inférieur ou égal à != Est différent de On peut donner plusieurs conditions à la fois et ce grâce à ces petits symboles : || OR Ou && AND Et FONCTIONS ET INCLUSION DE PAGES : Quand vous serez un expert en PHP, vos codes pourront atteindre des centaines de lignes. Il est clairement difficile de s'y retrouver même avec des commentaires bien rédigés. Je vous propose deux solutions : les fonctions et l'inclusion de pages. Lorsque vous écrivez votre code PHP il se peut que vous ayez à écrire plusieurs fois le même chose mais il existe les fonctions qui vous permettront de rentrer votre code à l'intérieur de la fonction et en appelant celle-ci à l'endroit voulu le code de la fonction sera exécuté. Une fonction peut aussi prendre des arguments et retourner une valeur. Je m'explique, quand vous appelez votre fonction, vous pouvez lui attribuer des valeurs dans les parenthèses que vous pouvez ensuite récupérer dans votre fonction et après quelques lignes de calculs, vous pouvez renvoyer une valeur que vous pourrez utiliser à l'endroit où votre fonction a été appelé. Bien que pratique, les fonctions prennent elles aussi beaucoup de place dans un fichier c'est pour quoi je vous propose de diviser votre page en plusieurs ainsi chaque page de votre aura une fonction bien définie et pourra être appelée dans une autre grâce aux fonctions suivantes : include() : Inclut une page dans une autre.include_once() : Inclut une seule fois une page dans une autre.require() : Inclut une page dans une autre et renvoie un message d'erreur en cas d’échec.require_once() : Inclut une seule fois une page dans une autre et renvoie un message d'erreur en cas d’échec.<?php // Ceci est une fonction function maFonction($argument1, $argument2) { return $argument1; } $une_variable_inutile = 2; $variable_contenant_la_valeur_retourne_par_la_fonction = maFonction('blabla', $une_variable_inutile); // Le contenu de "variable_contenant_la_valeur_retourne_par_la_fonction" serra "blabla" ?> TABLEAUX : Un tableau est variable à laquelle on peut donner plusieurs valeurs associées chacune à une clé. Exemples : <?php $membre = array('nom' => 'Truc', 'prenom' => 'Machin'); // Vous pouvez aussi faire comme cela $membre['nom'] = 'Truc'; $membre['prenom'] = 'Machin'; ?>Pour parcourir un tableau on pourrait utiliser la boucle for() mais celle-ci n'est pas très pratique donc je vous propose d'utiliser cette boucle : foreach() qui s'utilise comme ci-dessous : <?php foreach($member as $cle => $information) { echo $cle.' : '.$information; } /* Dans ce cas, j'ai récupéré la clé et son contenu. Vous pouvez très bien ne pas récupérer la clé en faisant comme ceci : foreach($member as $information) */ ?>Pour effectuer des testes sur votre tableau, vous avez trois fonctions très pratiques : array_key_exists : pour vérifier si une clé existe dans l'array ;in_array : pour vérifier si une valeur existe dans l'array ;array_search : pour récupérer la clé d'une valeur dans l'array.
    1 point
  4. Nombreux sont ceux qui se demande comment protéger et augmenter les performances son ordinateur à moindre coût. Ce guide va vous montrer comment optimiser et sécuriser Windows à travers des logiciels gratuit ou intégrés à Windows et de manière très simple malheureusement les tâches ne sont pas automatisées et il vous faudra donc les répéter régulièrement pour que votre ordinateur reste au meilleur de lui-même. Se protéger contre les virus : Il existe une grande liste d'antivirus aujourd'hui et difficile de dire qui est le plus fiable. Ce qu'on peut déjà savoir c'est qu'un antivirus payant sera toujours plus efficace qu'un antivirus gratuit car ils proposeront toujours des solutions de sécurités supplémentaires (chiffrement des données sensibles, pare-feu, anti-spam, etc...). Heureusement, des sites vous propose une comparaison des différents antivirus existant. Bien qu'il soit en anglais, AV-Comparative va vous aider à trouver votre antivirus en en comparant plusieurs. AV-Comparatives - Independent Tests of Anti-Virus Software - Real World Protection Test Overview : Explications : Voici un diagramme réalisé par AV-Comparative comparant les différents produits et leur efficacité réelle. On peut voir que Bitdefender assure parfaitement son rôle pusqu'il a été élu meilleur antivirus de l'année 2014, malheureusement il est payant mais il a l'avantage d'être moins cher que ses autres concurrents. Le premier antivirus gratuit que nous pouvons rencontrer est en sixième position et cette place est occupée par Avira. On dit souvent d'Avast que c'est le meilleur antivirus gratuit et pourtant il est en quatorzième. Rappelons que ce test porte sur l'efficacité de l'antivirus donc la capacité du produit à détecter et éliminer les virus présents. En outre, Avast propose d'autres solutions pour palier aux virus comme l'agent mail qui va analyser vos e-mails et l'agent web qui va analyser les sites web sur lesquels vous naviguez, contrairement à ses concurrents qui ne vont proposer qu'aux utilisateurs un agent de fichiers (ou protection en temps réel) qui va analyser uniquement les fichiers. Éliminer la publicité : Adblock Plus : Ce petit addon pour les navigateurs web va vraiment vous sauver la vie contre l'envahissement de la publicité que nous subissons quotidiennement. En effet, il va bloquer toutes les publicités quelles qu’elles soient. Et bonne nouvelle, adieu la publicité sur les vidéo Youtube ! Téléchargements : sous Firefox, sous Chrome Adwcleaner : La publicité n'est pas l'unique soucis que vous avez, certains logiciels que vous pensez de confiance installent d'autres logiciels malveillants qui ralentissent votre ordinateur. Adwcleaner est un logiciel a absolument avoir qui va nettoyer votre ordinateur de tous les adware, PUP/LPIs, toolbar et hijacker. Entretenir Windows : Défragmenter régulièrement : ATTENTION : Il est vivement déconseiller de défragmenter un SSD (pensez à désactiver la défragmentation automatique programmée par Windows). Quand il s'agit de défragmenter Windows a normalement planifié cette tâche malheureusement, si l'on veut le faire bien le défragmenteur de disque de Windows n'est pas le plus efficace. Auslogics DiskDefrag est un logiciel gratuit permettant de défragmenter son disque dur bien plus efficacement qu'avec l'outil intégré à Windows. En outre, Defraggler vous permet aussi de connaître l'état de santé de vos disques. Nettoyer ses disques : Vous connaissez surement l'outil proposé par Windows "Nettoyage de disque" qui permet de faire le ménage sur votre ordinateur et libérant quelques mégaoctets qui vous seront surement très précieux. Bien que cette outil soit plutôt efficace pour nettoyer son disque, je vais vous proposer un autre outil qui va nettoyer votre ordinateur bien plus efficacement : CCleaner. Ce logiciel assez célèbre vous permet de nettoyer votre ordinateur en profondeur en examinant des éléments de Windows (votre corbeille, votre presse-papier) mais aussi des éléments de vos logiciels (les cookies et l’historique de vos navigateurs). De plus, ce programme dispose d'un nettoyeur de registre permettant de supprimer ou de réparer les clés du registre corrompues. Enfin, ce logiciel dispose de quelques outils supplémentaires afin d'optimiser au mieux votre ordinateur. Quelques astuces : Démarrer plus rapidement Rendre l'explorateur Windows plus fiable Sauvegarder le registre [Windows 8] Créer un lecteur de récupération Créer une partition de restauration "usine" Verrouiller sa session après plusieurs tentatives de connexion
    1 point
×
×
  • Créer...