Crearemos un formulario de login en PHP en 4 sencillos pasos. Necesitamos crear varios archivos y carpetas primero:
- Paso 1: crear el archivo php.php y guardarlo en /application/controllers/
- Paso 2: crear el archivo login.php y guardarlo en /application/views/
- Paso 3: crear usuarios_model.php y guardarlo en /application/models/
- Paso 4: crear la tabla mysql con algunos usuarios de prueba
Paso 1: Código para el controlador "php.php":
Código :
<? class Php extends CI_Controller { function login() { $this->load->helper('form'); if(!isset($_POST['maillogin'])){ // Si no recibimos ningún valor proveniente del formulario, significa que el usuario recién ingresa. $this->load->view('login'); // Por lo tanto le presentamos la pantalla del formulario de ingreso. } else{ // Si el usuario ya pasó por la pantalla inicial y presionó el botón "Ingresar" $this->form_validation->set_rules('maillogin','e-mail','required|valid_email'); // Configuramos las validaciones ayudandonos con la librería form_validation del Framework Codeigniter $this->form_validation->set_rules('passwordlogin','password','required'); if(($this->form_validation->run()==FALSE)){ // Verificamos si el usuario superó la validación $this->load->view('login'); // En caso que no, volvemos a presentar la pantalla de login } else{ // Si ambos campos fueron correctamente rellanados por el usuario, $this->load->model('usuarios_model'); $ExisteUsuarioyPassoword=$this->usuarios_model->ValidarUsuario($_POST['maillogin'],$_POST['passwordlogin']); // comprobamos que el usuario exista en la base de datos y la password ingresada sea correcta if($ExisteUsuarioyPassoword){ // La variable $ExisteUsuarioyPassoword recibe valor TRUE si el usuario existe y FALSE en caso que no. Este valor lo determina el modelo. echo "Validacion Ok<br><br><a href=''>Volver</a>"; // Si el usuario ingresó datos de acceso válido, imprimos un mensaje de validación exitosa en pantalla } else{ // Si no logró validar $data['error']="E-mail o password incorrecta, por favor vuelva a intentar"; $this->load->view('login',$data); // Lo regresamos a la pantalla de login y pasamos como parámetro el mensaje de error a presentar en pantalla } } } } } ?>
Paso 2: Código para la vista "login.php":
Código :
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <title>Blogdephp.com, ¿cómo hacer un login de usuarios en php? Ver script y demo!</title> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"> <link rel="stylesheet" href="http://www.blogdephp.com/script/php-login.css" type="text/css" media="screen"> <!--<link rel="stylesheet" href="../../php-login.css" type="text/css" media="screen">--> </head> <body style="margin-top:0px"> <?php echo form_open('php/login'); ?> <div class="Info"> <p class="Titulo">Demo: ¿cómo hacer un login de usuarios en php?</p> <p> </p> </div> <div id="LoginUsuarios"> <div class="fila"> <div class="LoginUsuariosCabecera">E-mail:</div> <div class="LoginUsuariosDato"><input type="text" name="maillogin" value="<?= set_value('maillogin'); ?>" size="25" /></div> <div class="LoginUsuariosError"> <? if(isset($error)){ echo "<p>".$error."</p>"; } echo form_error('maillogin'); ?> </div> </div> <div class="fila"> <div class="LoginUsuariosCabecera">Contraseña:</div> <div class="LoginUsuariosDato"><input type="password" name="passwordlogin" value="<?= set_value('passwordlogin'); ?>" size="25" /></div> <div class="LoginUsuariosError"><?= form_error('passwordlogin');?></div> </div> <div class="fila"> <div class="LoginUsuariosCabecera"></div> <div class="LoginUsuariosDato"></div> </div> <div class="fila"> <div class="LoginUsuariosCabecera"><input type="submit" value="Ingresar"></div> <div class="LoginUsuariosDato"></div> </div> </div> <p> </p> <p> </p> </form> <div class="Info"> <p><strong><u>Datos de acceso</u></strong> (correspondiente a un usuario ya ingresado en la base de datos)</p> <p><strong>e-mail</strong>: [email protected]</p> <p><strong>password</strong>: blogdephp</strong></p> </div> <p> </p> <p> </p> <div class="Info"> <p><strong><u>Requerimientos</u></strong></p> <p>Para poder implementar este script de login, se requiere el framework de php "Codeigniter"</p> <p>(esta maravillosa herramienta nos ayuda a ahorrar mucho tiempo y esfuerzo en nuestros trabajos de programación php).</p> <p> </p> <p>La empresa <a href="http://www.solo10.com/productos/WebHostingLinux/?safblogdephp">Solo10.com</a>, cuando contratas un paquete de hosting anual desde u$s 49.95,</p> <p>te ofrece la instalación y configuración inicial del Codeigniter gratis :-)</p> <p> </p> <p>Este blog y demo se encuentran alojados en los servidores de Solo10.com.</p> <p>Te recomiendo el <a href="http://www.solo10.com/productos/WebHostingLinux/?safblogdephp">servicio de hosting</a> que ofrece esta empresa de hablahispana!</p> </div> <div class="Info"> <p><a href="http://www.blogdephp.com/php-login/">Volver a Blog</a></p> </div> </body> </html>
Paso 3: Código para el modelo usuarios_model.php
Código :
<?php class Usuarios_model extends CI_Model{ function ValidarUsuario($email,$password){ // Consulta Mysql para buscar en la tabla Usuario aquellos usuarios que coincidan con el mail y password ingresados en pantalla de login $query = $this->db->where('Usuario',$email); // La consulta se efectúa mediante Active Record. Una manera alternativa, y en lenguaje más sencillo, de generar las consultas Sql. $query = $this->db->where('Password',$password); $query = $this->db->get('Usuarios'); return $query->row(); // Devolvemos al controlador la fila que coincide con la búsqueda. (FALSE en caso que no existir coincidencias) } } ?>
Paso 4: Consulta Mysql para crear la tabla de usuarios
Código :
CREATE TABLE `Usuarios` ( `Id` INT NOT NULL AUTO_INCREMENT , `Usuario` VARCHAR( 50 ) NOT NULL , `Password` VARCHAR( 50 ) NOT NULL , PRIMARY KEY ( `Id` ) ) ENGINE = MYISAM ; INSERT INTO `Usuarios` ( `Id` , `Usuario` , `Password` ) VALUES ( NULL , '[email protected]', 'blogdephp' );
Explicación del código para forms de login con usuario y contraseña en PHP
Se trata de un script que, mediante pocas líneas de código, te permite configurar un login de usuarios propio en tu página web.
Esta capacidad es sumamente importante y la necesitaremos en cualquier proyecto web que iniciemos. Puesto que seguramente existe cierta información y funciones que nos interesa ofrecer únicamente a usuarios registrados y no al resto del público.
Por ejemplo, si estamos haciendo un sistema web para un periódico, nos interesará que los periodistas puedan ingresar al sistema (mediante un usuario y password) y puedan ingresar noticias.... Por supuesto, esta función debería ser accesible únicamente por periodistas y no por un lector común.
Funcionalidades
- Permitir acceso a determinada información y utilidades únicamente a determinados usuarios (aquellos que se encuentren registrados en una tabla de base de datos Mysql)
- Mensaje de error cuando falta rellenar algún campo de la pantalla de acceso
- Mensaje de error cuando los datos ingresados no coinciden con ningún usuario registrado en la base de datos.
- Recordar los datos previamente ingresados por el usuario cuando éste no supera el login y tenemos que volver a presentarle la pantalla de acceso.
Explicación técnica
Como pueden observar, los códigos del script se encuentran con comentarios. Cada sentencia importante tiene su explicación de que función cumple. Lo que intentaremos ahora es hacer una explicación general de cómo funciona el script; como si fuera un cuento...
Comencemos con la pantalla de acceso "login.php", donde el usuario podrá ingresar sus datos (usuario y password). Recordemos que todo lo que sea interacción con el usuario (entrada y salida de datos) lo trabajamos con las vistas (capa presentación).
Lo importante aquí es la sentencia
Código :
<?php echo form_open('php/login'); ?>donde creamos nuestro formulario html y especificamos que sus datos deben ser enviados y procesados por el método "login" del controlador "php". La sentencia form_open es de CodeIgniter.
Otro punto importante de la vista es cuando creamos los campos (serían las cajas de texto donde el usuario podrá ingresar los datos):
Código :
<input type="text" name="maillogin" value="<?= set_value('maillogin'); ?>" size="25" /></div>
Aquí estamos creando un campo de texto llamado "maillogin". La sentencia "set_value" nos sirve para recordar los datos rellenados por el usuario en caso que su acceso no sea válido y tengamos que volver a presentarle la pantalla de acceso. Es un valor agregado para dar mejor usabilidad a los usuarios.
Luego pasemos al controlador "php.php". Esta es la parte más compleja del script, por tal motivo intenté poner comentarios a cada una de las y facilitar así su comprensión. Te recomiendo leer los comentarios directo en el código.
El controlador (php.php) hace lo que hace es tomar los datos provenientes del formulario, hacer las validaciones, consultar al modelo (usuarios_model.php) si el usuario existe en la base de datos y su password es válida. Por último, decide si el usuario corresponde que pueda acceder, o no, y comunica su decisión a la vista (login.php) para que el usuario vea la respuesta en su pantalla.
Me interesa remarcar aquí algunas sentencias y declaraciones puntuales que son muy básicas de php y te servirán en todo sistema web que desarrolles.
Código :
$_POST['maillogin'](sirve para tomar los valores provenientes del formulario, en este caso se toma el valor del campo "maillogin")
Código :
$this->load->model('usuarios_model'); (sirve para cargar el modelo usuarios_model y poder utilizar sus recursos) this->usuarios_model->ValidarUsuario($_POST['maillogin'],$_POST['passwordlogin']);(ejecuta el método "ValidarUsuario" de nuestro modelo "usuarios_model" y le pasa los dos parámetros. )
En el próximo artículo continuaremos mejorando este script de login. Por ejemplo, estudiaremos como hacer para que el usuario pueda acceder a muchas pantallas de información restringida sin tener que poner siempre sus datos de login (únicamente ingresarlos la primer vez).
Espero que lo disfruten, les sea útil para sus proyectos y principalmente los ayude a continuar aprendiendo
Ver la demo!
Por favor, envíen sus consultas y dudas a través de los comentarios y lo revisamos juntos.
Saludos!
¿Sabes SQL? ¿No-SQL? Aprende MySQL, PostgreSQL, MongoDB, Redis y más con el Curso Profesional de Bases de Datos que empieza el martes, en vivo.
Por Freddie el 15 de Febrero de 2011
Por Reymond el 15 de Febrero de 2011
De cualquier forma es bueno el tutorial.
Por Blogdephp el 15 de Febrero de 2011
Puedes observarlo gráficamente en el archivo php.php del tutorial. Fijate que aquí se encuentra el código php verdaderamente importante del script.
Éste código, al no estar mesclado con todo el extenso código HTML...., quedo mucho más compacto, elegante y comprensible
Este es un punto clave del modelo MVC, tener bien separado la lógica (php) de las vistas (html) y los modelos (mysql); para facilitar la comprensión y hacer más sencillos el mantemiento y ampliación de un sistema...
Si buscas en mi blog, podrás encontrar un post "Programación secuencial vs MVC en php" donde enumero detalladamente las ventajas de trabajar con el modelo MVC.
Aprovecho también a invitarte a suscribirte en el blog, así serás avisado por mail cuando subamos nuevos artículos y scripts-
Si estás acostumbrado a trabajar con tu código php insertado dentro del código html..., es lógico que al comienzo de miedo comenzar a trabajar con MVC.
Pero aquí viene el gran poder del framework CodeIgniter. En CI es muy sencillo la transmisión de datos entre los controladores, modelos y vistas.
Te recomiendo revisar detenidamente la documentación oficial de CI; es verdaderamente muy clara, completa y escrita en lenguaje entendible (no se necesita ser un experto en php para su comprensión).
Te invito a probar el scritp del tutorial y ante cualquier duda u error que aparesca, por favor escribime y lo revisamos juntos
Por Blogdephp el 15 de Febrero de 2011
En realidad mi comentario iba apuntado a todas aquellos programadores con deseo e intenciones de comenzar a trabajar con programación orientada a objetos, frameworks, mvc, etc. No hay que tener miedo a estas herramientas, al contrario, nos facilitan mucho el trabajo!
Un gran saludo y nuevamente disculpas.
Por Patricio el 15 de Febrero de 2011
Típico de este sitio!
Por Freddie el 15 de Febrero de 2011
Patricio-blog :
Típico de este sitio!
Por jronal el 15 de Febrero de 2011
Por Patricio el 15 de Febrero de 2011
Por otro lado el html define una estructura de información. Eso quiere decir que no deben sobrar etiquetas, como la cantidad descomunal de etiquetas <div> que usa. Lo otro es el uso abusivo de clases. Parte de lo que hace importante separar la hoja de estilos de la estructura de la página es poder usar selectores para acceder a los elementos para poderles dar estilos.
Uno podría decir que es un tutorial de PHP. Pero se debe ser integral en el conocimiento y mas si se hace para que otra gente aprenda.
Entonces Freddie, no lo hago pro "trollear" (palabra que no existe en nuestro idioma) sino por la falta educativa tan grave que se comente con esto.
Por robz el 15 de Febrero de 2011
Por Patricio el 15 de Febrero de 2011
Por oro lado. Si no lo hubiera visto no lo podría haber comentado. Entonces es un comentario que la verdad se cae de su propio peso.
Por Ramm el 15 de Febrero de 2011
Patricio-blog :
Para ser tan crítico con un detalle que para la finalidad del tutorial no tiene ninguna relevancia, deberías saber que las etiquetas <strong> son estructura, no presentación, ya que sí contienen significado semántico.
Por Patricio el 15 de Febrero de 2011
Por Freddie el 15 de Febrero de 2011
Patricio-blog :
Estoy muy en desacuerdo con varias de tus aseveraciones respecto a "buen HTML", pero prefiero no juzgarte hasta no ver lo que haces. ¿Quieres escribir como quedaría este ejemplo, con la misma funcionalidad pero con un HTML "correcto" según tu? Entonces podré darte o no la razón. Mientras, sólo parece que quieres que te digan "sí, eres mejor que yo".
Por Villa el 16 de Febrero de 2011
Por Patricio el 16 de Febrero de 2011
@Freddie Creo que Esta por fuera de todo razonamiento lo que me esta diciendo y esta desviando completamente la discusión. Yo simplemente estoy diciendo que si están dando un ejemplo de mvc, muy bien estructurado en el lado de php. debería existir el mismo rigor para la parte de html. Que en términos educativos no se puede dar buen ejemplo en una parte de la guía y en otra no. En ningún momento estoy diciendo que yo soy mejor que otra persona. O que este o aquel es bueno o malo html. Repito, estoy haciendo evidente una inconsistencia en la guía que debería ser revisado o auditado antes de hacerlo publico ya que deja ver que los estándares no están a la altura. falta un editor de contenido que de cuenta de estas inconsistencias. Ahora si no puedo dar mi opinión como educador me quedo callado y no hay lío.
Yo no estoy pidiendo ue ud me juzgue. Si quiere ver mi trabajo es diferente y si quiere que de una corrección al html que esta en esta página es completamente diferente.
A modo de ejemplo de lo que se debe hacer es hacer todas las modificaciones de estilo, como subrayados y negritas desde la hoja de estilos y no usar etiquetas de estilo que el w3c ya no las recomienda.
Les pido encarecidamente un poco de altura al debate y no caer en sofismas que lo único que hacer es desviar el propósito de mejorar y darle mas rigor a esta comunidad que tanto le hace falta.
Por Freddie el 16 de Febrero de 2011
Patricio-blog :
Quiero que entiendas: una critica no tiene valor por si sola en la web. No está bien que digas "eso está mal". Tampoco está bien que digas "eso está mal por esto".
Está bien que digas "Eso está mal por esto, en cambio, así se debería hacer: [código corregido]".
De otra manera, no aportas nada, excepto el decir "oh, yo sí sé y ustedes no". Genera valor, no sólo criticas.
Patricio-blog :
Por Patricio el 16 de Febrero de 2011
Todo el tiempo he dicho que se debe hacer en cuanto al código que no es consecuente. No estoy diciendo si bien o mal sino consecuente con los objetivos propuestos al principio de la guía. Que evidentemente no están expuestos sino que vienen implícitos, que por demás no debería hacerse.
Con el tema del código casualmente pareciera que no lo leyera y ahí es donde radica mi crítica, que mas adelante hablare a fondo de eso. En el link que envía ud la w3c dice lo siguiente respecto a las etiquetas <strong>:
"EM and STRONG are used to indicate emphasis. The other phrase elements have particular significance in technical documents"
Al compararlo con el uso que se le da a esta etiqueta en el articulo:
Código :
Se da cuenta claramente que la etiqueta <strong> no se usa para dar énfasis a un elemento en especial sino para crear un título. Que en este caso es mucho mejor usar una de las etiquetas hx, que separaría la capa de presentación de la capa de estructura semántica del documento.
otro caso bien interesante respecto al uso semántico, que no era lo que yo estaba hablando al principio, es el siguiente:
Código :
En este caso se están usando un par de etiquetas <div> para separar un input del rótulo de este. Lo que se debería usar es una etiqueta label para hacer semánticamente correcta esta parte del código:
Código :
Si se dan cuenta salí de los divs que sobraban, y también del input salí del atributo size que son los que deberían ir en la hoja de estilos.
Bueno, donde radica el centro de mi crítica es la forma tan irresponsable en la que se aprueban los artículos. Y es una realidad tan a puño esto que el comentario anterior suyo demuestra que no leen los artículos que hacen. La falta de rigor en el tema educativo es completamente inaceptable y hasta ofensiva con su público objetivo. La crítica constructiva que les estoy haciendo es que por favor tengan un poco de consecuencia con la labor educativa que hacen y de responsabilidad. Si hacen una guía, que por favor lo lean antes de publicarla y le hagan las revisiones necesarias antes de elevarlo de estado a poder ser publicado. De lo contrario esto se vuelve un sitio donde se publica por amiguismo y no porque realmente haya una labor de educación a conciencia.
Estos son mis aportes como educador, que ya explique en otro post y finalmente es de uds aceptarlos o no y lo que si me queda claro es que esta es una comunidad donde uno no puede hacer una critica ya que empieza a pisar muchos egos porque ya veo venir la frase de ataque cuando se quedan sin argumentos. "Es que yo le he metido mucho esfuerzo a esto y ud que ha hecho". Y como por derecha me dijeron que no querían ver mi trabajo, pues nada, queda completamente clara la forma como operan uds.
Saludos
Por Blogdephp el 16 de Febrero de 2011
Si... En realidad lo que a mi me apasiona, e intento compartir mis conocimientos, es la parte de software (php, mysql y codeigniter). De todas maneras, considero muy valiosas sus observaciones sobre la parte html e intentaré aplicarlas en los próximos aportes cuando vayamos agregando funcionalidad a éste script de login.
@Reymond, gracias por tu comentario . Justamente este punto me agrada mucho de CodeIgniter. La posibilidad de ejecutar sentencias nativas de php y no estar obligado a utilizar únicamente sentencias propias del framework. Es cierto lo que mencionas, sería bueno remarcar sentencias importantes hechas con CodeIgniter y comentarlas un poco. Haré todo lo posible en prepararles este trabajo para mañana.
¿Alguién intentó ejecutar el script en su sitio?
¿Saltó algún error?
Por favor, transcriban los errrores y/o dudas y lo revisamos juntos
Saludos!
Por torrealbaruben el 17 de Febrero de 2011
Por BOBEsponjaPatricioFa el 11 de Marzo de 2011
Por kase el 15 de Marzo de 2011
if(!isset($_POST['maillogin'])){ // Si no recibimos ningún valor proveniente del formulario, significa que el usuario recién ingresa.
$this->load->view('login'); // Por lo tanto le presentamos la pantalla del formulario de ingreso.
}
si tu formulario fuera de 100 campos aser eso para los 100 seria estupido..
ahora yo te ago una mejora
function setval($valor){
if(!isset($valor)){
return '';
}else{
return $valor;
}
}
de este modo llamas a $this->setval($post[parametro]) cuando lo necesites, si existe te dara el valor, y sino te lo devolvera vacio
Por LuisManuel el 21 de Marzo de 2011
Por vero el 26 de Julio de 2011
Fatal error: Call to undefined function form_open() in \xampp\htdocs\Coduno\system\application\views\header_login.php on line 55
y lo que tengo en esa linea es esto
<?php echo form_open('php/login'); ?>
que puede ser?
estoy trababjando con la version 1.7 2
desde ya muchas gracias!
Por galax13a el 12 de Enero de 2012
$maillogin= $this->input->post('maillogin'); en lugar como se expresa aqui ya que de esa forma se hace una limpieza al sql injection y ataques xss_filtering & csrf_protection un saludo U.U
$_POST['maillogin'];
Por oops el 14 de Febrero de 2012
Por sergiom23 el 21 de Febrero de 2012
Ayuda!
Por oscar el 30 de Marzo de 2012
Call to undefined function form_open() in
Por Jazmine el 01 de Mayo de 2012
ayuda
Por Paloky el 11 de Mayo de 2012
Os explico.
En el controlador php, he tenido que añadir lo siguiente, si no, si ingresabas un login incorrecto, no volvía correctamente al inicio.
function index() { $this->login(); }
Como no tengo la Base de Datos instalada, he subtituido la funcion de "usuarios_model" por:
function ValidarUsuario($email, $password) { return 0; }
Finalmente, también me he encontrado con que en el controlador, le falta cargar la librería de verificación:
function login()
{
$this->load->helper('form');
$this->load->library('form_validation');
...........................
.............................
}
Lo publico por si hay alguien que no le funcione.
Saludos.
Por Israel Martinez el 10 de Octubre de 2012
esto es para llamar al controlador y la funcion de login
conicido con Paloky, falta meter la libreria from_validation
y en el model cambie la consulta a:
$this->load->database();
$array = array('email' => $email, 'password' => $password);
$query=$this->db->where($array);
$query = $this->db->get('usuarios');
return $query->row();
Por aerodinos el 27 de Mayo de 2013
Por LeftBehind el 18 de Julio de 2013
claramente el tirulo lo dice, como hacer un login en php - es obvio que al html no le tiene porque dar bola - de última eso que lo arregle el mismo usuario que quiere usar el tutorial/login ... no seas tan paspado ... no traes nada positivo al tema... no escribas mas ...salame -
Por camilos el 04 de Diciembre de 2014
Por johny el 15 de Febrero de 2015
Por ewerwer el 20 de Abril de 2015
Por hardcore el 13 de Mayo de 2015
Por gol el 11 de Enero de 2016
Por arturo el 29 de Junio de 2016
Por goooll el 15 de Julio de 2016
Por Luis el 16 de Agosto de 2016
lords mobile hack
Por José el 31 de Enero de 2018
classroom rental space
training rrom rental in singapore
training rooms in singapore
seminar room rental in singapore
indoor team building activities
corporate team building games singapore
team bonding in singapore
team building activities singapore
team building games singapore
10 soft skills you need
administrative office procedures
administrative support courses
adult learning mental skills
adult learning physical skills
anger management courses in singapore
appreciative inquiry courses
archiving and records management
assertiveness and self confidence
attention management courses
basic bookkeeping courses
being a likeable boss
body language basics courses
budgets and financial reports
business acumen courses
business ethics courses
business etiquette courses in singapore
business succession planning courses
business writing courses in singapore
call center training courses
change management courses in singapore
coaching and mentoring courses
coaching sales people courses
collaborative business writing
communication strategies courses
conducting annual employee reviews
conflict resolution courses
contact center training courses
contract management courses in singapore
creating a great webinar
creative problem solving courses
crisis management courses
critical thinking courses in singapore
customer service courses in singapore
customer support courses
cyber security courses in singapore
delivering constructive criticism
developing a lunch and learn
developing corporate behavior
developing creativity courses
developing new managers
digital citizenship courses
emotional intelligence courses
employee motivation courses
employee on boarding courses
employee recognition courses
employee recruitment courses
employee termination processes
entrepreneurship courses in singapore
event planning courses in singapore
executive and personal assistants
facilitation skills courses
generation gaps courses
goal setting and getting things done
handling a difficult customer
health and wellness at work courses
high performance teams inside the company
high performance teams remote work force
hiring strategies courses
human resource management courses in singapore
improving mindfulness
improving self awareness
increasing your happiness
internet marketing fundamentals courses
interpersonal skills courses
job search skills courses
knowledge management courses in singapore
leadership and influence courses
lean process and six sigma
life coaching essentials courses
manager management courses
managing personal finances courses
managing work place anxiety
marketing basics courses
measuring results from training
media and public relations courses
meeting management courses
middle manager courses
millennial on boarding courses
m learning essentials
motivating your sales team
multi level marketing courses
negotiation skills courses
networking outside the company
networking within the company
office politics for managers
organizational skills courses
overcoming sales objections
performance management courses
personal branding courses in singapore
personal productivity courses
presentation skills courses in singapore
project management courses in singapore
proposal writing courses
prospecting and lead generation
public speaking courses in singapore
risk assessment and management courses
safety in the work place courses
sales fundamentals courses
sales training courses in singapore
servant leadership courses
it courses in singapore
microsoft training singapore
corporate training in singapore
corporate sgx
social intelligence courses
social learning courses
social media in the work place
social media marketing courses in singapore
soft skills courses in singapore
stress management courses in singapore
supervising others
supply chain management courses
taking initiative courses
talent management courses
team building for managers
team building through chemistry
teamwork and team building
telephone etiquette courses
telework and telecommuting
time management courses in singapore
trade show staff training
train the trainer courses
virtual team building and management
women in leadership courses
work life balance courses in singapore
work place diversity courses
work place harassment courses
work place violence courses
sancy suraj
sancy suraj
sancy suraj
sancy suraj
sancy suraj
sancy suraj
sancy suraj
sancy suraj
[url=https://books.google.com.sg/books?id=1QykBQAAQBAJ&pg=PT362&lpg=PT362&dq=%22sancy+suraj+singh%22&source=bl&ots=E86QDyrLG2&sig=H-6a_YH-kTWaZWTfPSr1xfm4BOs&hl=en&sa=X&ved=0ahUKEwi3_56hhubVAhWJLo8KHcxTBxQ4ChDoAQgjMAA#v=onepage&q =% 22sancy% 20suraj% 20singh% 22 & f = false]sancy suraj[/url]
sancy suraj
longest colour sequence memorised
sancy suraj
longest colour sequence memorised
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
lunch talks
lunch talks
memory training course
memory training course
cabin crew
online memory course
memory training course
memory training course
memory training course
memory training course
memory training course
speed reading
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
geography tuition for secondary school students in singapore
geography tuition for secondary school students singapore
geography tuition for secondary school students singapore
geography tuition for secondary school students singapore
geography tuition for secondary school students singapore
secondary geography tuition in singapore
history tuition for secondary school students in singapore
social studies tuition for secondary school students in singapore
psle english tuition in singapore
psle science tuition in singapore
secondary 1 chemistry tuition in singapore
secondary 1 physics tuition in singapore
school holiday workshops courses for students in singapore
school holidays activitie in singapore
school holidays activitie in singapore
[url=http://umonictuitionadvantage.com/2017-november-school-holidays-activities-programmes-workshop-courses-camps-for- students-kids-in-singapore/]school holidays activitie in singapore[/url]
school holidays activitie in singapore
study skills
study skills
study skills workshops course in singapore
study skills workshops course in singapore
speed reading
speed reading
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition[
tuition[
tuition[
tuition[
tuition[
tuition[
tuition[
tuition[
student courses
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
team building
team building ideas
team building activities
unique team building
team building
corporate training in singapore
corporate training courses
corporate training courses
corporate training courses
corporate training courses
corporate health talk
corporate health talk
corporate health talk
lunch and learn talk
workplace lunch and learn
corporate training companies in singapore
training companies in singapore
emcee
emcee
health talks
soft skills training course
corporate training providers
professional development courses
training and development courses
short courses in singapore
corporate training courses in singapore
corporate training courses
corporate training in singapore
school holiday workshops courses for students in singapore
business students memory course in singapore
business students memory improvement workshop in singapore
memory improvement course for business students
memory improvement course for business students
business students memory improvement course
business students memory course in singapore
corporate health talks singapore
corporate health talks in singapore
corporate health talk singapore
corporate health talk in singapore
corporate health talks singapore
corporate health talks singapore
finance students memory training course in singapore
finance students memory training course in singapore
finance students memory training course in singapore
memory training courses for finance students in singapore
memory training courses for finance students in singapore
memory improvement courses for finance students in singapore
pinnacle minds
memory course
study skills
speed reading
memory training
school holiday
lunch and learn
march school holidays workshops
march school holidays workshops
march school holidays workshops
march school holidays workshops
march school holidays workshops
june school holidays workshops
june school holidays workshops
june school holidays workshops
june school holidays workshops
september 2018 school holidays workshops
september 2018 school holidays workshops
september 2018 school holidays workshops
september 2018 school holidays workshops
november 2018 school holidays workshops
november 2018 school holidays workshops
november 2018 school holidays workshops
november 2018 school holidays workshops
december 2018 school holidays workshops
december 2018 school holidays workshops
december 2018 school holidays workshops
december 2018 school holidays workshops
top 10 soft skills you need training course
administrative office procedures training course
administrative support training course
anger management training course
appreciative inquiry training course
archiving and records management training course
archiving and records management training course
self confidence and assertiveness training course
improving your attention management training course
bacis bookkeeping training course
being a likeable boss training course
body language training course
budgets and-financial reports training course
business acumen training course
business ethics training course
business etiquette training course
business succession planning training course
business writing training course
call centre training course
change management training course
civility in the workplace training course
coaching and mentoring training course
coaching salespeople training course
collaborative business writing training course
communication strategies training course
conducting annual employee reviews training course
conflict resolution training course
contact centre training course
contract management training course
creating a great webinar training course
creative problem solving training course
crisis management training course
critical thinking training course
customer service training course
customer support training course
cyber security training course
delivering constructive criticism training course
developing lunch and learn training course
developing corporate behavior training course
developing creativity training course
developing new managers training course
digital citizenship training course
emotional intelligence training course
employee motivation training course
employee onboarding training course
employee recognition training course
employee recruitment training course
employee termination processes training course
entrepreneurship training course
event planning training course
executive and personal assistants training course
facilitation skills training course
generation gaps training course
goal setting and getting things done training course
handling a difficult customer training course
health and wellness at work training course
high performance teams inside the company training course
high performance teams remote workforce training course
hiring strategies training course
human resource management training course
improving mindfulness training course
improving self awareness training course
internet marketing fundamentals training course
interpersonal skills training course
job search skills training course
knowledge management training course
leadership and influence training course
lean process and six sigma training course
life coaching essentials training course
manager management training course
managing personal finances training course
managing workplace anxiety training course
marketing basics training course
measuring results from training course
media and public relations training course
meeting management training course
middle manager training course
millennial onboarding training course
mlearning essentials training course
motivating your sales team training course
negotiation skills training course
networking outside the company training course
networking within the company training course
office politics for managers training course
organizational skills training course
overcoming sales objections training course
performance management training course
personal branding training course
personal productivity training course
presentation skills training course
project management training course
proposal writing training course
prospecting and lead generation training course
public speaking training course
risk assessment and management training course
safety in the workplace training course
sales fundamentals training course
servant leadership training course
social intelligence training course
social learning training course
social media in the workplace training course
social media marketing training course
stress management training course
supervising others training course
supply chain management training course
taking initiative training course
talent management training course
team building for managers training course
team building through chemistry training course
teamwork and team building training course
telephone etiquette training course
telework and telecommuting training course
time management training course
top 10 sales secrets training course
trade show staff training course
train the trainer training course
virtual team building and management training course
women in leadership training course
work life balance training course
workplace diversity training course
workplace harassment training course
workplace violence training course
half day memory improvement courses workshops
speed reading courses workshops in singapore
10 soft skills you need corporate training course in singapore
administrative office procedures corporate training course in singapore
administrative support corporate training course in singapore
anger management corporate training course in singapore
appreciative inquiry corporate training course in singapore
archiving and records management corporate training course in singapore
self confidence assertiveness corporate training course in singapore
improving your attention management corporate training course in singapore
basic bookkeeping corporate training course in singapore
being a likeable boss corporate training course in singapore
body language basics corporate training course in singapore
budgets and financial reports corporate training course in singapore
business acumen corporate training course in singapore
business ethics corporate training course in singapore
business etiquette corporate training course in singapore
business succession planning corporate training course in singapore
business writing corporate training course in singapore
call center corporate training course in singapore
change management corporate training course in singapore
civility in the workplace corporate training course in singapore
coaching and mentoring corporate training course in singapore
coaching salespeople corporate training course in singapore
collaborative business writing corporate training course in singapore
communication strategies corporate training course in singapore
conducting annual employee reviews corporate training course in singapore
conflict resolution corporate training course in singapore
contact center corporate training course in singapore
contract management corporate training course in singapore
creating a great webinar corporate training course in singapore
creative problem solving corporate training course in singapore
crisis-management corporate training course in singapore
critical thinking corporate training course in singapore
customer service corporate training course in singapore
customer support corporate training course in singapore
cyber security corporate training course in singapore
delivering constructive criticism corporate training course in singapore
developing a lunch and learn corporate training course in singapore
developing corporate behavior corporate training course in singapore
developing creativity corporate training course in singapore
developing new managers corporate training course in singapore
digital citizenship corporate training course in singapore
emotional intelligence corporate training course in singapore
employee motivation corporate training course in singapore
employee onboarding corporate training course in singapore
employee recognition corporate training course in singapore
employee recruitment corporate training course in singapore
employee termination processes corporate training course in singapore
entrepreneurship training course in singapore
event planning corporate training course in singapore
executive and personal assistants corporate training course in singapore
facilitation skills corporate training course in singapore
generation gaps corporate training course in singapore
goal setting and getting things done corporate training course in singapore
handling a difficult customer corporate training course in singapore
health and wellness at work corporate training course in singapore
high performance teams inside the company corporate training course in singapore
high performance teams remote workforce corporate training course in singapore
hiring strategies corporate training course in singapore
human resource management corporate training course in singapore
improving mindfulness corporate training course in singapore
improving self awareness corporate training course in singapore
increasing your happiness corporate training course in singapore
internet marketing fundamentals corporate training course in singapore
interpersonal skills corporate training course in singapore
job search skills corporate training course in singapore
knowledge management corporate training course in singapore
leadership and influence corporate training course in singapore
lean process and six sigma corporate training course in singapore
life coaching essentials corporate training course in singapore
manager management corporate training course in singapore
managing personal finances corporate training course in singapore
marketing basics corporate training course in singapore
measuring results from corporate training course in singapore
media and public relations corporate training course in singapore
meeting management corporate training course in singapore
middle manager corporate training course in singapore
millennial onboarding corporate training course in singapore
mlearning essentials corporate training course in singapore
motivating your sales team corporate training course in singapore
negotiation skills corporate training course in singapore
networking outside the company corporate training course in singapore
networking within the company corporate training course in singapore
office politics for managers corporate training course in singapore
organizational skills corporate training course in singapore
overcoming sales objections corporate training course in singapore
performance management corporate training course in singapore
personal branding corporate training course in singapore
personal productivity corporate training course in singapore
presentation skills corporate training course in singapore
project management corporate training course in singapore
proposal writing corporate training course in singapore
prospecting and lead generation corporate training course in singapore
public speaking corporate training course in singapore
[url