Hola a todos, en esta oportunidad traigo un tutorial sencillo, de cómo subir archivos a mi servidor, guardar el nombre y una descripción del archivo en una base de datos de mysql y luego mostrar en un listado los registros que voy ingresando, todo esto hecho con UPLOADIFY v2.1.4.
Antes que nada quiero decir que lo hice con esta versión porque es con la cual he trabajado hasta ahora, las últimas versiones no las probé aún, sé que hay algunos cambios , pero con esta versión funciona perfectamente. Pueden descargala de aquí y lo copiamos en el proyecto que crearemos más adelante. Bueno, ahora manos a la obra.
En primer lugar pues, hay que tener instalado un emulador de servidor Web local, ya sea xampp, wamp o app server, el que sea de su agrado. Para este ejemplo yo tengo instalado el xampp 1.7.2 (uds pueden descargarse el xampp la última versión o anteriores aquí )y obviamente ejecutando los servicios de Apache y de MySQL.
Una vez que tenemos nuestros servicios ejecutándose, procedemos a crear la base de datos en la cual vamos a guardar el nombre de la imagen concatenado con un número aleatorio de PHP, para que no guarde archivos con el mismo nombre, y una descripción de la imagen y un estado, para luego mostrar sólo las imágenes que estén activas, es decir que su estado sea 1; para eso en el navegador en la barra de direcciones escribimos localhost o 127.0.0.1 y nos aparece la interfaz de xampp. Nos vamos a herramientas y elegimos phpMyAdmin. Una vez dentro creamos la base de datos “tutorial”.
Luego una tabla llamada imágenes con la siguiente estructura:
Una vez que ya hemos creado nuestra tabla, ahora procedemos a realizar un proyecto PHP con la IDE que más les agrade, ya sea eclipse, netbeans u otra, para este caso yo lo he trabajado en netbeans 6.9.1, pero eso sí, debemos tener la siguiente estructura:(podemos descargarnos la ultima versión de jquery desde aquí) y la copiamos en la carpeta js.
Una vez que tenemos la estructura anterior procedemos a programar cada uno de los archivos. El código es el siguiente:
Carpeta estilos
Archivo estilo.css
Código :
body { background:#fff; } .cajas{ background:#F7F8E0; border:1px solid #00BFFF; height: 30px; border-radius:5px; } #contenedor{ background-color:#A9E2F3; width:100%; border-radius:10px; margin:50px auto; } #nuevaimagen{ background-color:#A9E2F3; float:left; } #listadoimagenes{ margin-left: 50px; float:left; } #mensajevacio{ background: #084B8A url(../images/warning_32x32.png)no-repeat; padding:10px; color:#fff; text-align: center; width:300px; border-radius:5px; } .botones{ background: #084B8A; color:#fff; padding:5px; border: 1px solid #fff; border-radius:5px; cursor:pointer; } .botones:hover{ background: #0174DF; } #cabecera{ background: #084B8A ; padding:10px; color:#fff; text-align: center; font-size:14px; border-radius:5px; } .formulario-title{ background: #0B0719; color:#fff; padding:5px; text-align: center; } .demoTable { border-spacing:1px; font-family:Verdana, Arial, Helvetica, sans-serif; font-size:10px; background-color:#C3E6FF; color: #b7b7b7; width:100%; margin:auto; } .demoTable td, .demoTable tr, .demoTable th{ border-collapse: separate; border-collapse: collapse; border-spacing: 0; } .demoTable caption { font-weight: bold; background: #50ADEA url(../images/corner.gif) no-repeat right top; border-bottom:2px solid #1975d7; color: #FFF; text-transform:uppercase; padding:10px; margin:auto; } .demoTable td, .demoTable th { padding: 4px; } .demoTable thead th { text-align: center; background: #C3E6FF; color: #0B173B; border: 1px solid #C3E6FF; text-transform:uppercase; } .demoTable tr:hover{ background:#C3E6FF; } .demoTable tbody tr { background-color:#C3E6FF; color: #0B173B; text-align:left; } .demoTable tbody tr th { background-color:#C3E6FF; color: #2E2E2E; text-align:left; } .demoTable tbody tr.odd { background: #f9f9f9; border-top:1px solid #FFF; } /*.demoTable tbody tr:hover { background: red; border-top:1px solid #FFF; }*/ .demoTable tbody tr:hover{ background: #fff; color:#000; } .demoTable tbody tr { height:50px; background: #FAFAFA; border: 1px solid #FFF; } .demoTable tbody tr.odd td{ background: #f9f9f9; border-top:1px solid #FFF; } .demoTable td a:link, .demoTable td a:visited { color: #0B3861; text-decoration: none; } .demoTable td a:hover { color: #0B3861; border-bottom:2px solid #8FD5FF; text-decoration: none ; } .demoTable tfoot th, .demoTable tfoot td { background-color:#fff; padding:10px; text-align:center; font-family:Georgia, “Times New Roman”, Times, serif; font-size:22px; font-weight:bold; font-style:italic; border-bottom:3px solid #CCC; border-top:1px solid #DFDFDF; }
Carpeta images
Para la carpeta images nos descargamos las siguientes imágenes:
Carpeta js
Archivo funciones.js
Código :
$(document).ready(function(){ verformularionuevaimagen(); verlistadoimagenes(); }) function verformularionuevaimagen() { var randomnumber=Math.random()*11; $.post(‘nuevaimagen.php’, { randomnumber:randomnumber }, function(data){ $(“#nuevaimagen”).html(data).slideDown(‘slow’); }); } function verlistadoimagenes() { var randomnumber=Math.random()*11; $.post(‘libs/listadoImagenes.php’, { randomnumber:randomnumber }, function(data){ $(“#listadoimagenes”).html(data).slideDown(‘slow’); }); }
Archivo nuevaimagen.js
Es aquí donde configuramos nuestro uploadify y le especificamos la carpeta donde queremos que nos guarde el archivo.
Código :
$(document).ready(function() { $(“#file_upload”).fileUpload({ ‘uploader’: ‘uploadify/uploader.swf’,//ruta del boton para subir el archivo ‘cancelImg’: ‘uploadify/cancel.png’,//boton para cacelar la carga del archivo ‘script’: ‘libs/subirarchivo.php’, //archivo que realiza la accion de subir el archivo al servidor y guardar en la bd ‘folder’: ‘uploads’, //directorio en el cual queremos que se guarde el archivo ‘buttonText’: ‘examinar’, //texto que contiene el boton ‘checkScript’: ‘uploadify/check.php’, //archivo que hace la verificacion de la subida de la imagen y si hay archivos con el mismo nombre ‘fileDesc’: ‘archivos imagen’, ‘auto’:false,//la subida no es atuomatica sino cuando nosotros hacemos clic en guardar imagen ‘fileExt’: ‘*.jpg;*.jpeg;*.gif;*.png’, //tipos de archivo a seleccionar , para este caso imagenes ‘multi’: false,//solo un archivo a la vez puedo subir ‘displayData’: ‘percentage’,//el avance de la subida al servidor se muestra en porcentajes onComplete: function (){ verlistadoimagenes(); //una vez que guarda el archivo me ejecuta la funcion que lista los registros de la tabla imagenes $(“#txtdes”).val(”);//limpia el textarea } }); $(‘#txtdes’).bind(‘change’, function(){ $(‘#file_upload’).fileUploadSettings(‘scriptData’,'&des=’+$(this).val());//capturo el valor del textarea y lo envio para poder insertarlo al archivo subirarchivo.php }); }) function startUpload(id, conditional) //funcion que me realiza la carga teniendo como requisito obligatorio ingresar algo en la descripcion(recibe el id del file y el id del textarea) { if(conditional.value.length != 0) { $(‘#’+id).fileUploadStart(); } else alert(“ingrese un descripción para la imagen”); }
Carpeta Libs
Archivo conexion.php
Código :
<?php function Conectarse(){ $servidor=”localhost”; $basededatos=”tutorial”; $usuario=”root”; $clave=”"; $cn=mysql_connect($servidor,$usuario,$clave) or die (“Error conectando a la base de datos”); mysql_select_db($basededatos ,$cn) or die(“Error seleccionando la Base de datos”); mysql_query (“SET NAMES ‘utf8′”); return $cn;} ?>
Archivo listadoimagenes.php
Código :
<?php require_once(‘conexion.php’); $cn=Conectarse(); $listar= mysql_query(“select * from imagenes where ImagenEstado=1″,$cn); if(mysql_num_rows($listar)>0) { echo”<table class=’demoTable’>”; echo”<caption>LISTADO DE IMAGENES</caption>”; echo”<tr>”; echo”<th>Estado</th>”; echo”<th>Descripcion</th>”; echo”<th>Miniatura</th>”; echo”</tr>”; while($imagen=(mysql_fetch_array($listar))) { echo”<tr>”; if($imagen['ImagenEstado']==1){ echo”<td><img src=’images/001_18.png’ width=’20′></td>”; } else { echo”<td><img src=’images/001_19.png’ width=’20′></td>”; } echo”<td>”.$imagen['ImagenDescripcion'].”</td>”; echo”<td><a href=’uploads/”.$imagen['ImagenArchivo'].”‘ ‘><img src=’uploads/”.$imagen['ImagenArchivo'].”‘ width=’70′ height=’50′></a></td>”; echo”</tr>”; } echo”</table>”; }else { echo”<div id=’mensajevacio’>no existen imagenes registradas</div>”; } ?>
Archivo subirarchivo.php
Código :
<?php include_once(“conexion.php”);//archivo que contiene la conexion try { $cn = Conectarse(); $arrayreempla=array(‘/’,’ ‘); $targetPath = $_SERVER['DOCUMENT_ROOT'] . $_REQUEST['folder'] . ‘/’; $archivo= str_replace($arrayreempla,”, $_FILES['Filedata']['name']); $tempFile = $_FILES['Filedata']['tmp_name']; $imagen= md5(mt_rand(2147483647, 4294967294)) . _ . $archivo; $targetFile = str_replace(‘//’, ‘/’, $targetPath) . $imagen; $resultadoi = mysql_query(“INSERT INTO imagenes (ImagenDescripcion,ImagenArchivo,ImagenEstado)values(‘”.$_REQUEST['des'].”‘,’”.$imagen.”‘,1)”,$cn); if ($resultadoi) { echo “1″; move_uploaded_file($tempFile, $targetFile); } else { echo “0″; } } catch (Exception $ex) { echo “0″; } ?>
Carpeta Raíz
Archivo index.php
Código :
<!–ESTILO GENERAL –> <link rel=”stylesheet” href=”estilos/estilo.css” type=”text/css” /> <!–JQUERY –> <script src=”js/jquery-1.3.2.min.js” type=”text/javascript” ></script><!–se modifica por la version de jquery que tengan –> <!–PARA SUBIR ARCHIVOS –> <link rel=”stylesheet” href=”uploadify/uploadify.css” type=”text/css” /> <script src=”js/jquery-1.3.2.min.js” type=”text/javascript” ></script> <script type=”text/javascript” src=”uploadify/jquery.uploadify.js”></script> <!–FUNCIONES GENERALES –> <script type=”text/javascript” src=”js/funciones.js”></script> <div id=”cabecera”><h1>TUTORIAL SUBIR ARCHIVOS AL SERVIDOR Y GUARDAR NOMBRE EN BD CON LISTADO</h1></div> <div id=”contenedor”> <div id=”nuevaimagen”> </div> <div id=”listadoimagenes”> </div> </div [b]Archivo nuevaimagen.php[/b] <script type=”text/javascript” src=”js/nuevaimagen.js”></script> <form > <div class=”formulario-title”> <span >REGISTRAR IMAGENES</span> </div> <div > <div > <div > <table > <tr> <td > <span >Breve descripcion</span><br/> <textarea class=”cajas” cols=”" name=”txtdes” id=”txtdes” style=”width: 400px;height: 80px” ></textarea> </td> <td> <span >Agregar Imagen</span><br/> <input id=”file_upload” type=”file” name=”file_upload” /> </td> </tr> <tr> </table> </div> </div> </div> <div > <input class=”botones” type=”button” value=”Guardar Imagen” onclick=”javascript:startUpload(‘file_upload’, document.getElementById(‘txtdes’))”/> </div> </form>
El siguiente paso es descomprimir el archivo uploadify y copiar la carpeta uploadify que descargamos en el link que les pase al principio en nuestra carpeta raíz de nuestro proyecto.
Ahora, si hemos hecho todo bien, ejecutamos nuestro proyecto y debería de verse así
Hacemos clic en examinar y seleccionamos la imagen que queremos subir:
Ahora, si queremos guardar la imagen sin haber ingresado una descripción, nos muestra el siguiente mensaje:
Ingresamos una descripción:
Hacemos clic en Guardar Imagen y automáticamente nos muestra el listado con el registro ingresado y la imagen:
Ahora verificamos si realmente subió el archivo de imagen a la carpeta uploads de mi proyecto:
Por ultimo verficamos en la BD que se haya insertado el registro, aunque con solo ver que aparece el listado se verifica, pero de todas maneras…
Como vemos funciona perfectamente…. eso es todo por ahora… gracias por la atención brindada; comentarios, críticas constructivas o sugerencias serán bien recibidas.
Hasta otra oportunidad.
¿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 malder el 27 de Abril de 2012
Gracias
Por Jos el 27 de Abril de 2012
Por segu_fe el 27 de Abril de 2012
Por LocoTriste el 30 de Abril de 2012
http://conservatoriotrujillo.edu.pe/ejemplos/upload/
Por Jazmine el 30 de Abril de 2012
Por LocoTriste el 30 de Abril de 2012
Archivo nuevaimagen.php, si esta verifica
Por JoseAlejandro_Realza el 30 de Abril de 2012
Por José el 30 de Abril de 2012
Por LocoTriste el 30 de Abril de 2012
José-blog :
ovbio que es meramente didactico, para que mas es un tutorial sino con el fin de compartir un conocimiento de manera didactica..si quizñas utilice el termino equivocado, para decir que en si eso es un servidor web pero funcionando claro, de ninguna manera este codigo en entornos de produccion?????....disculpa alli si no te entiendo, yo lo tengo en produccion con ese codigo, tvz se puede mejorar ovbiamente, pero no entiendo cuando dices que de ninguna manera se deberia usar en entornos de produccion.. me gustaria que expliques porque?? ..gracias por comentar
Por Braulio el 11 de Junio de 2012
Por Braulio el 11 de Junio de 2012
La aplicacion tiene dos tablas y sube una imagen con los datos adicionales de la propiedad y luego muestra esos datos con php.
El punto es que necesito subir mas de una imagen en la misma id (en distinto campo) . pero no e podido lograrlo. por favor si alguien me puede ayudar o quiza proporcionarme un codigo para logralo? Muchas Gracias.
Por kakashi2000 el 15 de Junio de 2012
Ademas de solo imagenes se puede modificar para hacer como un seccion de repositorios?? donde puedas subir cualquier clase de archivo? ya sea .doc, .xls, .jpg, .pdf, .html etc.
Por RicardoIII el 23 de Noviembre de 2012
Llevo tiempo esforzándome por corregir los problemas de las comillas y todo eso y ya estoy cabreadísimo y necesito en forma urgentísima esta solución. Te quiero pedir si puedes enviarme tus archivos corregidos, ¿es posible? De veras te lo agradeceré muchísimo.
Saludos!
Por kakashi2000 el 28 de Noviembre de 2012
Disculpa que no te haya respondido, claro te paso esta URL donde lo puedes descargar esta probado en los siguientes estandares que uso:
XAMPP V.3.1
Windows 8
Este son los archivos correjidos.
https://www.dropbox.com/s/vk2x4rhfj8tja6p/cargaarchivos.zip
Suerte
Por RicardoIII el 13 de Diciembre de 2012
kakashi2000 :
Disculpa que no te haya respondido, claro te paso esta URL donde lo puedes descargar esta probado en los siguientes estandares que uso:
XAMPP V.3.1
Windows 8
Este son los archivos correjidos.
https://www.dropbox.com/s/vk2x4rhfj8tja6p/cargaarchivos.zip
Suerte
Gracias, amigo! Grandioso!!
Saludos navideños
Por kakashi2000 el 13 de Diciembre de 2012
http://foros.cristalab.com/subir-archivos-con-uploadify-en-php-mysql-y-html5-version-final-t108980/#657759
Por RicardoIII el 14 de Diciembre de 2012
Por rvasquez1980 el 18 de Diciembre de 2012
Por RicardoIII el 21 de Diciembre de 2012
Si alguien sabe dónde hay un ejemplo, con códigos descargables, muy agradecido. Saludos!
Ricardo
Por cesar el 22 de Diciembre de 2012
Por Mario Benitez el 10 de Enero de 2013
Muchas gracias por la ayuda, esto es muy valioso aporte, sin embargo, tengo una duda y es la siguiente:
Si deseo agregar un campo de texto y un campo de selección, ¿Cómo quedaría el código para enviar esas otras variables?
Te agradecería bastante esta información, te dejo mi correo si me deseas colaborar: [email protected]
Muchas gracias.
Por Seve el 25 de Febrero de 2013
$('#txtdes').bind('change', function(){
$('#file_upload').fileUploadSettings('scriptData','&des='+$(this).val());
});
Por Iñigo el 09 de Mayo de 2013
Me gustaría saber como hacer para poder subir mas de una imagen a la vez. Es decir, con este tutorial acabamos subiendo las imágenes una a una.
Habría alguna manera, pasa seleccionar x imágenes de golpe y subirlas al servidor y a la base de datos de una sola vez?
Saludos.
Por taringero17 el 23 de Septiembre de 2013
se que la sentencia es esta la que llama al archivo subirarchivo.php
como podría solucionarlo?
$('#txtdes').bind('change', function(){
$('#file_upload').fileUploadSettings('scriptData','&des='+$(this).val());
});
Gracias!
Por entidad el 29 de Noviembre de 2013
Por ErickMuro el 16 de Diciembre de 2013
Cómo le hago para no generar un nombre aleatorio?
Quiero el nombre original con el que se sube el árchivo
Por INGEACEV el 14 de Agosto de 2014
Por kakashi2000 el 14 de Agosto de 2014
Lo tendre en cuenta para la nueva version.
Saludos
Por Alejandra el 09 de Octubre de 2014
Por wcifuentes el 20 de Enero de 2015
Si alguien tiene una idea me dice por favor.
Por rikrdo7x el 25 de Enero de 2015
Por rikrdo7x el 25 de Enero de 2015
Si alguien sabe sobre esta dos opciones podria ayuarme
Por bis el 25 de Marzo de 2015
Por Fidel el 13 de Junio de 2015
Por MACZ el 10 de Noviembre de 2015
gracias
Por MACZ el 10 de Noviembre de 2015
<?php
$cod=$_POST[txtcodigo];
$des=$_POST[txtdescripcion];
$uni=$_POST[sltunidad];
$codf=$_POST[sltfamilia];
$codm=$_POST[sltmarca];
$mod=$_POST[txtmodelo];
$ser=$_POST[txtserie];
$fot=addslashes(file_get_contents($_FILES['txtimagen']['tmp_name']));
$nofot=
$pv=$_POST[txtpventa];
$obs=$_POST[txtobservaciones];
include("..\conecta.inc");
if(!empty($fot))
$sql="call sp_Manarticulos('$cod','$des','$uni','$codf','$codm','$mod','$ser','$fot',$pv,'$obs',1)";
else
$sql="call sp_Manarticulos('$cod','$des','$uni','$codf','$codm','$mod','$ser','$nofot',$pv,'$obs',1)";
mysqli_query($cn,$sql);
mysqli_close($cn);
?>
<script language="javascript">
window.location="frmmantenimiento.php";
</script>
pdt: no se que poner en la variable $nofot para que al guardar en la base de datos tome la imagen NoDisponible.jpg y la guarde en el campo de la tabla
Por Mitotoloache el 16 de Abril de 2016
Por Michael el 03 de Julio de 2016
Por el 31 de Julio de 2016
Por 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
Por chanyuan el 24 de Abril de 2018
true religion jeans
jordan shoes
nike presto
mulberry handbags
kevin durant shoes
pandora jewelry
knicks jerseys
air jordan 4
longchamp pliage
canada goose jackets
ugg outlet
suns jerseys
louis vuitton outlet
chicago blackhawks jerseys
cheap jordans
air jordan pas cher
cheap jordans
michael kors outlet
mont blanc pens
christian louboutin outlet
kate spade outlet
michael kors outlet
ugg boots
coach outlet
ralph lauren polo
canada goose jackets
mbt shoes
oakley sunglasses
ugg boots
canada goose outlet
true religion jeans
yeezy boost
ray ban sunglasses
kate spade outlet
michael kors outlet
michael kors outlet
longchamp pas cher
michael kors outlet
moncler jackets
coach outlet
pandora charms
oakley sunglasses
nike trainers
longchamp solde
ray-ban sunglasses
canada goose jackets
kobe shoes
mulberry handbags
coach outlet
true religion outlet
louis vuitton outlet
christian louboutin outlet
bulls jerseys
nfl jersey wholesale
football shirts
uggs outlet
michael kors outlet
coach outlet
air max 90
world cup jerseys
coach outlet
coach factory outlet
coach outlet
oakley sunglasses
salomon shoes
michael kors outlet
ralph lauren polo shirts
air max 90
canada goose jackets
swarovski outlet
moncler outlet
air max uk
polo ralph lauren
michael kors outlet online
prada handbags
cazal sunglasses
air max trainers
burberry outlet
longchamp outlet
true religion outlet
michael kors outlet online
cavaliers jerseys
ray ban sunglasses
air max 90
burberry outlet
bucks jerseys
adidas nmd
cheap jordans
cheap nfl jerseys
ugg outlet
wizards jerseys
jazz jerseys
michael kors outlet
kings jerseys
michael kors
michael kors outlet
longchamp outlet
ugg outlet
canada goose parka
kobe 9
cheap jerseys
coach outlet
canada goose jackets
gucci outlet
asics shoes
christian louboutin outlet
ralph lauren outlet
michael kors outlet
cartier outlet
coach outlet store online
soccer jerseys
michael kors handbags
ugg outlet
pandora charms sale clearance
longchamp handbags
kate spade outlet
air max 90
ralph lauren polo
michael kors handbags
uggs
ugg boots
uggs outlet
futbol baratas
coach outlet
ugg outlet
kate spade outlet
true religion uk
oakley sunglasses
longchamp handbags
jordan shoes
michael kors outlet
mac makeup
polo outlet
tory burch outlet
tory burch outlet
magic jerseys
canada goose outlet
adidas wings
longchamp outlet
nike outlet
nobis outlet
air jordan shoes
ray ban sunglasses
oakley sunglasses
tory burch outlet
coach outlet online
tods outlet
canada goose jackets
coach outlet
pandora
true religion jeans
true religion jeans
pandora charms
adidas nmd
asics pas cher
oakley sunglasses
pandora charms sale clearance
lacoste polo shirts
canada goose outlet
clippers jerseys
nike factory outlet
ugg outlet
canada goose jackets
birkenstock sandals
louboutin pas cher
michael kors outlet
michael kors
jordan shoes
mulberry handbags
air jordan 12
true religion jeans
soccer jerseys
polo ralph lauren
true religion jeans
polo outlet
cheap mlb jerseys
canada goose outlet
polo ralph lauren
ray ban sunglasses
pandora charms
manchester united jersey
air huarache
herve leger outlet
nba jerseys
giuseppe zanotti outlet
michael kors outlet
adidas trainers
oakley sunglasses
michael kors wallets
christian louboutin outlet
links of london
tory burch outlet
nike foamposite
cheap mlb jerseys
ugg outlet
hermes outlet
wellensteyn jackets
polo ralph lauren
air max 2017
louboutin shoes
pandora jewelry
kate spade outlet
rolex watches
canada goose outlet
trailblazers jerseys
longchamp bags
birkenstock outlet
nike store uk
nhl jerseys
tory burch outlet
coach outlet online
michael kors outlet online
ray ban sunglasses
canada goose jackets
dansko shoes
nike shoes
coach outlet
nike air max 90
new balance pas cher
pistons jerseys
nike pas cher
uggs outlet
real madrid jersey
coach outlet online
mulberry bags
canada goose
ray ban sunglasses
asics pas cher
nike shoes
michael kors outlet
basketball shoes
adidas outlet
true religion jeans
san antonio spurs jerseys
ysl outlet
ray ban sunglasses
mulberry outlet
pandora charms
new balance shoes
ray ban sunglasses
canada goose jackets
polo ralph lauren
yeezy boost 350
oakley sunglasses
michael kors outlet
cheap jordans
tory burch outlet
kate spade outlet
ugg outlet
valentino outlet
michael kors outlet
rolex watches
nike air max 2015
michael kors
canada goose outlet
adidas outlet
air force 1
rolex watches
timberwolves jerseys
ralph lauren pas cher
lakers jerseys
tory burch outlet
michael kors outlet
true religion jeans
coach factory outlet
nike store
fitflops sale clearance
rolex watches for sale
fred perry polo shirts
prada outlet
nike shoes
76ers jerseys
adidas uk
cheap jordans
cheap jordans
polo ralph lauren
true religion outlet
polo outlet
ray ban sunglasses
oakley sunglasses
hermes belt
pandora charms
nike outlet
polo ralph lauren
swarovski outlet
longchamp handbags
mavericks jerseys
barcelona jersey
canada goose jackets
coach handbags
coach outlet online
rockets jerseys
hermes birkin
pandora jewelry
prada sunglasses
louis vuitton outlet
nhl jerseys
coach outlet
burberry outlet
ecco shoes
uggs outlet
lebron james shoes
coach outlet online
pandora charms
ralph lauren polo shirts
ugg outlet
michael kors outlet
ray ban sunglasses
fitflops sale clearance
kobe bryant shoes
soccer shoes
ugg outlet
denver broncos jerseys
air jordan pas cher
coach factory outlet
michael kors outlet
coach canada
nike pas cher
michael kors outlet
ed hardy clothing
grizzlies jerseys
coach outlet
cheap jerseys
swarovski outlet
coach outlet online
ferragamo outlet
moncler outlet
montblanc pens
longchamp handbags
gucci outlet
supra shoes
ferragamo shoes
nike blazer pas cher
christian louboutin shoes
cheap nhl jerseys
swarovski outlet
polo ralph lauren
fitflops
longchamp solde
coach outlet
coach outlet
fitflops sale
thunder jerseys
canada goose outlet
canada goose outlet
michael kors outlet
christian louboutin outlet
air max 1
coach outlet canada
fitflops
gucci outlet
ray ban sunglasses
michael kors outlet
pandora charms
raptors jerseys
chrome hearts outlet
michael kors outlet
canada goose outlet
nfl jerseys wholesale
ray ban sunglasses
coach outlet
ugg outlet
ray ban sunglasses
oakley sunglasses
ferragamo outlet
air jordan retro
michael kors outlet
canada goose outlet
coach outlet
canada goose jackets
ugg outlet
pandora outlet
polo ralph lauren
marc jacobs outlet
prada shoes
lacoste soldes
coach handbags
fitflops shoes
cheap jordans
nike air force 1
ray ban sunglasses
coach outlet online
canada goose outlet
michael kors bags
michael kors outlet
air jordan shoes
canada goose jackets
coach outlet
swarovski crystal
bottega veneta outlet
jordan shoes
gucci outlet
nike roshe one
mulberry bags
cleveland cavaliers jersey
stephen curry shoes
polo outlet
puma outlet
lakers jerseys
oakley sunglasses
reebok outlet store
cheap jordans
true religion jeans
swarovski crystal
reebok trainers
coach factory outlet
hermes outlet
ferragamo outlet
mulberry handbags
oakley sunglasses
canada goose outlet
michael kors outlet
barbour outlet
michael kors handbags
ferragamo outlet
coach outlet
coach outlet online
polo outlet
mizuno running shoes
air max 90
canada goose jackets
air jordan 3
cheap jordans
jordan shoes
cheap snapbacks
canada goose coats
hornets jerseys
canada goose outlet
nike air max
christian louboutin outlet
michael kors uk
nba jerseys
cheap jordans
polo ralph lauren
fitflops sale
celtics jerseys
ferragamo outlet
cheap football shirts
oakley sunglasses
christian louboutin outlet
polo ralph lauren
pandora charms
pelicans jerseys
louis vuitton outlet
kate spade outlet
jordan shoes
oakley sunglasses wholesale
jordan shoes
burberry outlet
nets jerseys
fitflops sale clearance
ray ban sunglasses
oakley sunglasses
warriors jerseys
michael kors handbags
pandora charms
true religion jeans
oakley sunglasses
nike roshe
chrome hearts outlet
oakley sunglasses
pandora outlet
canada goose outlet
converse shoes
coach outlet
ray ban sunglasses
golden state warriors jerseys
polo shirts
michael kors handbags
air jordan 4
oakley sunglasses
moncler outlet
mulberry outlet
ray ban sunglasses
ugg outlet
canada goose outlet
oakley sunglasses
ralph lauren polo shirts
heat jerseys
ray ban sunglasses
polo outlet
pacers jerseys
michael kors outlet
tory burch outlet
ugg boots
pandora charms
new balance pas cher
yeezy boost
denver broncos jerseys
canada goose outlet
moncler jackets
christian louboutin outlet
ralph lauren polo
nuggets jerseys
kate spade outlet
true religion jeans
ugg outlets
canada goose outlet
oakley sunglasses
spurs jerseys
coach outlet online
nba jerseys
canada goose outlet
air jordan release dates
ferragamo shoes
chelsea jersey
ugg boots clearance
michael kors outlet
true religion outlet
hawks jerseys
canada goose outlet
michael kors
air max 90
canada goose outlet
mcm outlet
fitflops outlet
air huarache
michael kors handbags
cheap jordans
oakley sunglasses wholesale
coach outlet