Skip to content

Latest commit

 

History

History
218 lines (175 loc) · 6.14 KB

README.md

File metadata and controls

218 lines (175 loc) · 6.14 KB

Node JS

Présentation de la technologie.

Voir sujet détaillé.

Concepts à mettre ne œuvre :

- Implémentation d'un serveur NodeJs
- Utilisation du framwork Express
- Utilisation de la base de donnée (MYSQL)
- Implémentation d'un formulaire d'inscription/connexion HTML5
- Format d'échange JSON
  • Technologies utilisées:
  • NodeJS, MySQL, HTML5, CSS3, javascript

A installer

Telecharger le projet

Github

Structure du projet

lpsil-web/
  |- public/
  |- models/
  |- test/
  |- server.js
  |- package.json
  |- README.md

Package.json

Créer un fichier package.json dans le dossier de notre projet :

{
    "name": "lpsil-web",
    "version": "0.0.1",
    "dependencies": {
           "body-parser": "^1.14.2",
           "ejs": "^2.3.4",
           "express": "^4.13.3",
           "log4js": "^0.6.29",
           "morgan": "^1.6.1",
           "mysql": "^2.10.2",
           "serve-favicon": "^2.3.0"
    },
    "author": "Mail <email@etu.unice.fr>",
    "description": "Enregistrement et authentification"
}
Installation des packages
npm install
Création du serveur
var express = require('express');
var morgan = require('morgan'); // Charge le middleware de logging
var favicon = require('serve-favicon'); // Charge le middleware de favicon
var logger = require('log4js').getLogger('Server');
var app = express();


app.use(morgan('combined')); // Active le middleware de logging

app.use(express.static(__dirname + '/public')); // Indique que le dossier /public contient des fichiers statiques (middleware chargé de base)

app.use(function (req, res) { // Répond enfin
    res.send('Hello world!');

});

logger.info('server start');
app.listen(1313);
Ajouter les templates
// config
app.set('view engine', 'ejs');
app.set('views', __dirname + '/views');
Définition des routes
/* On affiche le formulaire d'enregistrement */

app.get('/', function(req, res){
    res.redirect('/login');
});

app.get('/login', function(req, res){
    res.render('login');
});

app.post('/login', function (req, res) {
    // TODO vérifier si l'utilisateur existe
});

app.get('/register', function (req, res) {
    // TODO ajouter un nouveau utilisateur
});
/* On affiche le profile  */
app.get('/profile', function (req, res) {
    // TODO  
    // On redirige vers la login si l'utilisateur n'a pas été authentifier 
    // Afficher le button logout                                                
});      

Base de donnée

Connection Simple
var mysql = require('mysql');


var connection = mysql.createConnection({
    host: 'localhost',
    user: '< MySQL username >',
    password: '< MySQL password >',
    database: '<nom de vôtre base de données>'
});

connection.connect();

connection.query('SELECT * from < table name >', function (err, rows, fields) {
    if (!err)
        logger.info('Le résultat de la requête: ', rows);
    else
        logger.error(err);
});

connection.end();
Pool

  var pool =  mysql.createPool({
    connectionLimit : 100, //important
	host : 'localhost',
	user : '< MySQL username >',
	password: '< MySQL password >',
        database: '<nom de vôtre base de données>'
  });	

  pool.getConnection(function(err,connection){
        if (err) {
          connection.release();
          res.json({"code" : 100, "status" : "Erreur de connexion à la DB"});
          return;
        }  

        logger.info('connecté en tant que ' + connection.threadId);
       
        connection.query("select * from user",function(err,rows){
            connection.release();
            if(!err) {
                res.json(rows);
            }          
        });

        connection.on('error', function(err) {      
              res.json({"code" : 100, "status" : "Erreur de connexion à la DB"});
              return;    
        });
  });

A faire

  • Implémentation d'une plateforme e-commerce
  • Dashboard utilisateur
    • Modification des données utilisateurs
    • Suppression du compte
    • Accès au page après identification
    • Panier - Dashboard Administration
    • Ajouter des catégories
    • Ajouter des produits
    • Suppression des catégories
    • Suppression des produits
    • Modification de profile
    • Suppression de profile
    • Révocation des identifiants

En option

  • Intégration d'un API externe (Facebook, Google et/ou twitter)
  • L'utilisation d'AngularJS ou de VueJS
  • Un Dockerfile pour le déploiement
  • L'intégration d'une API de payment

Package intéressant à utiliser

Date de remise

Le 18/01/2018 à 8h00 CET

Documentation et lien uties