INDEX COURSE 1. Backend, Creating the server: 04:08 2. Mysql Connection using pool: 31:55 3. Views (Template Engine): 53:28 4. Saving Data in Mysql: 01:10:26 5. Retrieving Data from Mysql: 01:17:35 6. Deleting Data from Mysql: 01:33:47 7. Updating Data from Mysql: 01:40:58 8. Connect-flash Messages and Navigation: 01:53:27 9. Users Signup: 02:11:28 10. Users Signin or Login: 02:50:56 11. Protecting Routes from the Server: 03:12:12 12. Personal Data: 03:31:05 INDICE DEL TUTORIAL 1. Backend, Creando el servidor: 04:08 2. Mysql, Conexión: 31:55 3. Views (Template Engine): 53:28 4. Guardar datos en Mysql: 01:10:26 5. Obteniendo Datos desde Mysql: 01:17:35 6. Eliminando Datos de Mysql: 01:33:47 7. Actualizar Datos de Mysql: 01:40:58 8. Mensajes de connect-flash y navegación: 01:53:27 9. Registro de Usuarios en Mysql: 02:11:28 10. Login de Usuarios en Mysql: 02:50:56 11. Protegiendo Rutas del servidor: 03:12:12 12. Datos Privados: 03:31:05
@victorgiovannibeltranrodri10476 жыл бұрын
Fazt porque te avientas el videotete? Osea no es una crítica? Pero porque? La duda? Para ti para monetizar no es mejor vídeos cortos? Como los que le dan like/vista/suscripctor creo que también es mejor por vídeos cortos puedo acceder a una parte un tema alguna duda, no se además no sé si pasa a muchos pero cuando alguien ve un vídeo con más de cuatro líneas amarillas (anuncios) en el vídeo da un poco de hueva ver el vídeo a mí me pasa eso , tus vídeos son buenos pero alguien que apenas le entra le dará hueva es pregunta/ sugerencia
@ricardotovar45976 жыл бұрын
@@victorgiovannibeltranrodri1047 concuerdo contigo ..lo mejor seria q lo haga en videos cortos ..a mk tmb me sucede lo mismo con eso de ver un video de 3 horas y ccomo que me da hueva
@lindltaylor40936 жыл бұрын
se puso rudo el input type URL XD
@wilmergaleano74656 жыл бұрын
@@victorgiovannibeltranrodri1047 Creo que da igual y es mucho mejor verlo así. Digo por experiencia... los vídeos cortos me cansan y muchos proyectos prueba no los termino por lo cansón que resulta estar viendo uno por uno los vídeos.
@Alejandro-gg7oz6 жыл бұрын
Que crac, que grande se aprende mucho más que en la universidad
@carlosnunez5806 жыл бұрын
He visto canales de programación, pero tengo por seguro que este es el MEJOR! Explicas cosas que otros canales no lo hacen... Sigue así men!!
@PatriotaMex5 жыл бұрын
Claro que no. No explica muchas de las configuración por que se hacen de tal o cual manera...
@OFISPOT4 жыл бұрын
@@PatriotaMex Investigue. El curso es muy completo !
@vic_epsy4 жыл бұрын
@@PatriotaMex de echo, hasta tiene "minicursos" que son como de 3 horas, de varios frameworks, ahí puedes checar eso de manera general. Si no te basta, entonces busca o compra un curso más profundo.
@camiloandresruizbernal67584 жыл бұрын
@@PatriotaMex pues es obvio, no es como te vaya a enseñar a usar MySQL, Javascript, CSS, Bootstrat4 y el resto de tecnologías con todas las bases en un solo video de 3 horas. ._.
@PatriotaMex4 жыл бұрын
@@camiloandresruizbernal6758 eso es obvio mi retraído amigo, yo me refiero a las configuraciones del tema principal que es la configuración de los archivos de nodejs, solamente eso.
@ernestoalonso55653 жыл бұрын
20:53 para los que esten trabajando con common js, el objeto handlebars deben registrarlo como { engine } y no como exphbs, esto es por si les da algun error. Por cierto, muchas gracias fazt por el tutorial!
@kuroDx3 жыл бұрын
a mi me sale este error "TypeError: exphbs is not a function" si lo cambio como engine sigue saliendo. sabras que es bro?
@ernestoalonso55653 жыл бұрын
@@kuroDx Hola Elmer, en efecto, ese mismo error me daba a mi, al parecer han cambiado la sintaxis, porque solo me funciono importandolo como { engine } y usandolo como engine en la funcion. Por cierto, es importante las {} rodeandolo cuando lo importas.
@kuroDx3 жыл бұрын
@@ernestoalonso5565 muchas gracias!!!! Si era éso. Lo cambie con los { } y ya funciona bien.
@pr4zka3 жыл бұрын
jaja todos tuvimos ese erorr. Gracias bro!!
@gd7s.a.s.3813 жыл бұрын
Podrías agregar la sintaxis please!!??
@luisma03302 жыл бұрын
Si alguien tiene problemas para cerrar la sesión (3:20:14) lo que pasa es que la función logout cambio y ahora es una función asíncrona por lo cual, para que funcione debe estar algo asi: router.get("/logout", (req, res, next) => { req.logOut(req.user, err => { if(err) return next(err); res.redirect("/signin"); }); });
@gxbs23182 жыл бұрын
gracias por el debugging Luis estaba detenido ahi.
@guillermosandoval84162 жыл бұрын
Heroe
@justanothervideo54332 жыл бұрын
Genio
@kanasber87402 жыл бұрын
Te mereces el cielo bro :3
@TheKTUTOS2 жыл бұрын
garcias bro ufff, lo bueno q es ver loscomentarios
@AndresBenthan3 жыл бұрын
"ok, y asi hemos terminado nuestra aplicacion del dia de hoy", yo llevo dos semanas! jajaja pero al fin, termine!; muchas gracias @fazt por este curso, estuvo genial
@Chikipencio3 жыл бұрын
yo me tome 3 casi 4 semanas!! mas de una vez toco revisar todo el codigo por que se iba una coma donde iba punto y cosas asi pequeñas que me jodian toda la app!!
@byson80693 жыл бұрын
Como se llama para darle una observación
@swyme66124 жыл бұрын
Este y unos cuantos programadores más merecen todo lo bueno que haya en el mundo, la forma en que transmiten su conocimiento sin ningún compromiso y enseñan al resto de personas que inician en este mundo de la programación, es de admirar. Muchas gracias por tus grandes aportes!!
@cientifica91502 жыл бұрын
Estoy aprendiendo programacion por mi cuenta (sin universidad ni profesores), soy una principiante que tiene conocimientos basicos de JavaScript y que ni siquiera conoce del todo la tecnologia nodejs, sin embargo, me animo a aventurarme con proyectos como estos porque siento que logro crecer mejor y de forma mas direccionada. Gracias por tus grandes tutoriales tan geniales, seria genial que hicieras un video acerca de como aprendes la programacion y de donde obtienes fuente de conocimiento para adquirir tales conocimientos y especializarte tan bien. Excelente canal y muchas gracias por todo!
@OMARFELIXRIVERAROSAS-e1s Жыл бұрын
yo estoy en un instituto y tambien hago proyectos asi con youtube , de echo diria q manejas asi con proyectos de la vida real y asi vas mas practicando ✌✌
@jpnet90876 жыл бұрын
Eres un gran desarrollador. Personas como tu merece que las personas que visitan tu canal y valoren tu trabajo aporten un poco de tu tiempo convertido en dinero, esta app que creaste usando tecnologia open source es maravillosa. Implica muchos temas complejos...
@LudwigMoreno4 жыл бұрын
Genial, impecable forma de enseñar. De verdad, muchas gracias por tan excelente tutorial! Algo necesario sería evitar que un nuevo usuario se registre con el mismo username de otro usuario. Esto se puede prevenir con dos cambios, que coloco aquí en caso de que puedan servir de utilidad a alguien más: En mysql: USE database_links; ALTER TABLE users ADD CONSTRAINT user_info UNIQUE (username); Si alguien intenta registrar un username que ya existe, entonces se genera un error 'ER_DUP_ENTRY', que se puede manejar así: Dentro del archivo lib/passport.hbs , en lugar de newUser.password = await helpers.encryptPassword(password); const result = await pool.query('INSERT INTO users SET ?', [newUser]); console.log('The database New User insertion results in: ', result); newUser.id = result.insertId; return done(null, newUser); se coloca este try-catch: try { newUser.password = await helpers.encryptPassword(password); const result = await pool.query('INSERT INTO users SET ?', [newUser]); console.log('The database New User insertion results in: ', result); newUser.id = result.insertId; return done(null, newUser); } catch (err) { if (err.code === 'ER_DUP_ENTRY') { return done(null, false, req.flash('message', 'The Username that you selected is already in use, please choose a different Username')); } }
@miguelangellp15164 жыл бұрын
Excelente aporte.
@EdwardsEvias4 жыл бұрын
Quiero felicitarte por lo ordenado que trabajas. La excelente memoria que tienes. Eres demasiado bueno programando, en mucho tiempo que tengo tratando de aprender específicamente lo que has puesto aquí, que considero el mejor video que he visto hasta los momentos, porque vas al grano sin titubeos y con total conocimiento y propiedad. De verdad me quito el sombrero ante su maestría.
@lecotte67996 жыл бұрын
Yo sinceramente me alegro contigo. La manera como explicas y compartes tu conocimiento. Consigo aprender todo lo que explicas. Tus clases tienen un nivel alto ... Congratulations brother. Muito obrigado !
@siradesdbc4 жыл бұрын
primero quiero darte las gracias por este magnifico tutorial.....Tengo 35 años y deje el oficio de programador por otra rama de ingeniería, y por cosas de la vida e regresado a esto, y estoy aprendiendo a la par java con spring boot y nodejs-express y solo puedo decir oh boy!!!! las cosas han cambiado mucho. Lo mas difícil de trabajar con spring y nodejs es la configuración de tu zona de trabajo en realidad me perdí mucho en eso.
@nicketech63484 жыл бұрын
Increíble. Como agradecerte Fazt. Eres increíble. Ninguna plataforma de programación paga es mejor que este canal. Aquí se aprende de verdad. Muchas gracias. Cuando empiece a ganar dinero te prometo que te voy a donar algo en forma de agradecimiento. Saludos
@nicolasaybar7738Ай бұрын
otro que cambio es el const { create } = require('express-handlebars'); // Importa el método 'create'...buenisimo el video, gracias totales
@miguelangelburbano82125 жыл бұрын
excelente vídeo, no se como hace para tener en mente tantos lenguajes es un duro... si alguien esta en windows y no le carga el comando mysql en la carpeta del proyecto, solo tiene que modificar las variables del sistema y agregar en las variables de entorno la ruta de mysql por lo general es C:\Program Files\MySQL\MySQL Server 8.0\bin. tal vez le sirva a alguien...a demas si tienes otras instancias en la base de datos u otros esquemas "schemas" verificar bien el puerto port: y el password.
@Ing_Maria4 жыл бұрын
Cuando voy por el minuto 18:05 me arroga un error de Error: listen EADDRINUSE: address already in use :::4000 en la consola y no me muestra el puerto
@OscarD3v3 жыл бұрын
solumobil.com
@manuelvils4 жыл бұрын
Mi primera vez en este canal, y es increíble lo fácil que resulta entender cada concepto aplicado en esta app, personalmente utilicé y adapté esto para el proyecto de un cliente y fue el único video que tuve que ver para desarrollarla por completo.
@manuelvils4 жыл бұрын
Gracias Fazt!
@castillodelgado3 жыл бұрын
Muy buen tutorial, me agrada que no eliminas los pequeños errores que pueden surgir durante el desarrollo, lo hace ver mucho más real y puedes ver cómo se solucionan los problemas revisando la documentación.
@mauroqkjo3 жыл бұрын
La verdad que este proyecto es completísimo. Ir pausando, anotando, buscando más sobre lo que vas mostrando, me sumó muchísimo para entender un poquito más este tema de la progamación web. Gracias!
6 жыл бұрын
Excelente Fazt, siempre algo nuevo, ahora ( Nodejs y Mysql ), juntos, jejeje, eres super. Muchas gracias por compartir estos conocimientos y tu forma de explicar tan buena que entendemos de forma simple. Muchas gracias. y Feliz Noche buena. Muchas cosas buenas para ti.
@OscarD3v3 жыл бұрын
solumobil.com
@natxo84833 жыл бұрын
Mis suscripciones me sobran en una mano, pero por la grandeza de tus cursos, tu manera de explicar, yendo directamente a los temas sin marear a la gente, tu eres una de mis suscripciones. Excelente, de más de 30 cursos que he visto, no hay duda que los tuyos son los mejores CON DIFERENCIA!!
@angelmamberto83124 жыл бұрын
Muchas gracias por compartir tu conocimiento! He aprendido un montón con este tutorial, muy bien explicado y muy completa la app. Además, 100% práctico, ideal para quienes saben programar pero no conocen NODE. Recomendadísimo! Saludos y sigue así!
@conradollanos45332 жыл бұрын
nono, sos el tipo mas genio que conoci en youtube!! lo que me salvaste esta ultima semana con estos proyectos con node y express, no te das una idea, nuevo suscriptor y futuro recomendador de tu canal!! tremendo trabajo! y gracias por compartir todos tus conocimientos!
@fedegregori3186 жыл бұрын
Te amo Fazt, literalmente siento cariño por vos después de tantas horas de mi vida invertidas en tus videos jaja. Saludos y gracias. Por otro lado me gustaría consultar tu distro de linux y si tienes algún video con tus config o "customización" del mismo. Felices fiestas!
@FaztTech6 жыл бұрын
xD Gracias, esta distro se llama Linux Lite, esta basada en Ubuntu, asi que puedes hacer todo lo de allí, pero esta distro consume muchos menos, así que para desarrollo me gusta mucho, sobre todo cuando ejecutas muchos programas a la vez, editores, maquinas virtuales, IDEs, transpiladores y demas. Creo que seria una buena idea crear un video explicando como configuro una distro nueva :)
@fedegregori3186 жыл бұрын
@@FaztTech Leí que no soporta UEFI, y ya lo estoy descargado. Veré si puedo hacerlo bootear dual con ElementaryOS y espero no arruinar el disco jaja
@MiguelBaena55 жыл бұрын
amigo una pregunta estoy en windows y siempre tengo problemas con la consola cuando pongo mysql no me reconoce apesar de que tengo instalado xampp y tambien mysql como lo hiciste ayuda
@ace_33155 жыл бұрын
Hola @@MiguelBaena5 No explicas cuál es el problema con mysql. Pero sospecho, revisaste las variables de entorno. Debes agregar, la ruta de mysql, a las variables de entorno. Revisa eso. Saludos.
@AquiGeorge4 жыл бұрын
@@MiguelBaena5 Abandona Windows y métete con GNU/Linux ;-)
@mariocalcetin76024 жыл бұрын
Don Fazt no me canso de decirlo. Ud es grande . Antes mi mina me quitaba el sueño ahora lo hacen sus tutoriales , que grande !!!!
@josegallego90935 жыл бұрын
Amigo eres el mejor y sin bromas, yo he visto muchos programadores haciendo Videos pero como tu ninguno, tienes una forma de explicarlo muy bien y detallado. La verdad es que tendrías que ganar dinero por esto. Un saludo desde Kassel (el país de las patatas)
@rodolfogallardo41843 жыл бұрын
de Hector de León no vas a estar hablando! jajajajaja, pero tienes razon en éso
@ernestorosas7972 Жыл бұрын
palabra para describirte ===GENIOOOOOO, GRACIAS INFINITAS, TE AMAMOSSS!!!
@1qazxsw20104 жыл бұрын
A los que tengan problemas con ECONNREFUSED, hay muchas razones por las que el código en este tutorial podría fallar, yo lo resolví agregando el puerto de mysql, el default es 3306 pero en mi caso el puerto era 3307 cuando lo consulté en mi interfaz, una vez que lo agregué, ya se conectaba sin problemas. Esto lo agregas en el archivo keys, donde está la información para acceder a la base de datos.
@ignaciomatiasdiaz97109 ай бұрын
Sos genio fazt, hace cinco días no deje de aprender node.js express y más. Gracias
@yonathangutierrez17336 жыл бұрын
Saca patreon mereces que la gente aporte de lo que gana con lo que transmites
@juliomontilla1006 жыл бұрын
toda la razon
@luistapia14475 жыл бұрын
Confirmo!!!!!
@hugowxox5 жыл бұрын
x4
@eduardoauditore54145 жыл бұрын
Completamente de acuerdo, nos esta compartiendo todo tu conocimiento sin reservas, seria una pequeña muestra de gratitud de nuestra parte
@FabianGrimbeorn4 жыл бұрын
x6
@javierItuzaingo5 жыл бұрын
Inmejorable tutorial, muy bien el dividirlo en partes, tanto conocimiento metidos en 4 horas es increible. Muchas gracias!!!!!!!!!!!!!!!!!!!
@ryannavarro75313 жыл бұрын
Para todos los que les paso el error 'TypeError: exphbs is not a function' lo único que tienes que hacer es cambiar la linea de código donde se importo el "express-handlebars" cambiarla por esta "const { engine } = require('express-handlebars');" (sin las comillas) y seguido cambiar en el 'app.engine' cambiar el 'exphbs' por 'engine'
@ifanfatcat3 жыл бұрын
Me salvaste, muchas gracias!
@alexalejandrooviedogonzale2893 жыл бұрын
En las mismas, lo solucione con ponerle "=>" , pero mas adelante es imposible continuar ya que en ''links'' ya no deja realizar el render de platilla. Gracias @Ryan Navarro
@tjwtb58852 жыл бұрын
Andaba atrasado por eso xd jaja muchas gracias
@camilogonzalez11002 жыл бұрын
gracias pa
@danielleone74902 жыл бұрын
Sos el mejor ser humano que pisó este canal jajaaj llevaba buscando muchísimo y no encontraba la forma, hasta intenté cambiar de motor de plantillas pero nada, ¡GRACIAS!
@ignaciomatiasdiaz97109 ай бұрын
¡Gracias!
@carlosandressanchez8654 жыл бұрын
Y aun, despues de tanto tiempo, es un excelente video y aprendi muchisimo observandolo, muchas gracias Fazt, por compartir tu conocimiento.
@davidmrg Жыл бұрын
Tuve algunas dificultades con la implementación de la librería connect-flash. Seguramente es por actualizaciones. La solución la encontré en ChatGPT, le pasé contexto (el bloque de código completo, descripción del error, etc) y me resolvió el problema en 3 pasos. Gracias totales Fazt!
@alangaelrojas5 жыл бұрын
Alguien también acomodo su libreta, cafe y palomitas para aventarse esta excelente clase? jajajaa Excelente Fazt!!
@OscarD3v3 жыл бұрын
solumobil.com
@jesuslopez5914 Жыл бұрын
2023. Todo funcionando correctamente, me sorprende que a pesar de que este tutorial se haya subido en 2018 el código aun funcione, claro se me presentaron varios errores pero los logre solucionar (sin cambiar tanto el código) y llegar al final del tutorial. Fazt, Gracias a tus videos e aprendido muchas cosas, sigue así que me gustaría seguir aprendiendo con tus tutoriales.
@frandepaulo2 жыл бұрын
2:02:38 Si alguien tiene problemas para implementar el boton de cerrar, hasta la fecha en bootstrap 5 es asi En la doc de bootstrap dice q el atributo es data-dismiss, pero a mi me funciono con data-bs-dismiss
@daniloespinozapino48653 жыл бұрын
Me explotó la cabeza, en algún momento podré decir que estos conocimientos son "míos". Excelente tutorial.
@josepupo8074 Жыл бұрын
para todos los que sigan el video al momento de importar el modulo express-mysql-session la linea para que funcione deben colocarla asi const MySQLStore = require("express-mysql-session")(session);
@nicolasviruel3408 Жыл бұрын
fue la respuesta a mi error!! gracias por compartirlo
@Caslini10fran10 ай бұрын
GRACIASSS !!!! 2 horas estuve buscando jajaja
@valeriadurruty87710 ай бұрын
Hola, en esa parte de express-mysql-sessions, flash y express-sessions, alguien tuvo este error, estuve buscando pero nada: node:internal/modules/cjs/loader:1147 throw err; ^ Error: Cannot find module 'mongodb/node_modules/bson' Require stack: - D:\Repo\dizziness_syst ode_modules\mongoose\lib\drivers ode-mongodb-native\objectid.js - D:\Repo\dizziness_syst ode_modules\mongoose\lib\types\objectid.js - D:\Repo\dizziness_syst ode_modules\mongoose\lib\utils.js - D:\Repo\dizziness_syst ode_modules\mongoose\lib\schema.js - D:\Repo\dizziness_syst ode_modules\mongoose\lib\index.js - D:\Repo\dizziness_syst ode_modules\mongoose\index.js - D:\Repo\dizziness_syst ode_modules\express-sessions\index.js - D:\Repo\dizziness_syst\src\index.js at Module._resolveFilename (node:internal/modules/cjs/loader:1144:15) at Module._load (node:internal/modules/cjs/loader:985:27) at Module.require (node:internal/modules/cjs/loader:1235:19) at require (node:internal/modules/helpers:176:18) at Object. (D:\Repo\dizziness_syst ode_modules\mongoose\lib\drivers ode-mongodb-native\objectid.js:8:16) at Module._compile (node:internal/modules/cjs/loader:1376:14) at Module._extensions..js (node:internal/modules/cjs/loader:1435:10) at Module.load (node:internal/modules/cjs/loader:1207:32) at Module._load (node:internal/modules/cjs/loader:1023:12) at Module.require (node:internal/modules/cjs/loader:1235:19) { code: 'MODULE_NOT_FOUND', requireStack: [ 'D:\\Repo\\dizziness_syst\ ode_modules\\mongoose\\lib\\drivers\ ode-mongodb-native\\objectid.js', 'D:\\Repo\\dizziness_syst\ ode_modules\\mongoose\\lib\\types\\objectid.js', 'D:\\Repo\\dizziness_syst\ ode_modules\\mongoose\\lib\\utils.js', 'D:\\Repo\\dizziness_syst\ ode_modules\\mongoose\\lib\\schema.js', 'D:\\Repo\\dizziness_syst\ ode_modules\\mongoose\\lib\\index.js', 'D:\\Repo\\dizziness_syst\ ode_modules\\mongoose\\index.js', 'D:\\Repo\\dizziness_syst\ ode_modules\\express-sessions\\index.js', 'D:\\Repo\\dizziness_syst\\src\\index.js' ] }
@israx23 ай бұрын
gracias bro!
@parmelota12 жыл бұрын
Sos un Capo. Pocos tienen la capacidad de enseñar tan claro. Felicitaciones.
@snakone6 жыл бұрын
gracias una vez más Fazt! posiblemente tendré que usar algo así en el futuro! PD: 1:06:49 el hombre contra la máquina, el regreso 2
@gonzalitogonzalez10344 жыл бұрын
Te felicito, te tomaste casi 4 horas de tu tiempo para ayudarnos.....gracias.
@colommbiano5 жыл бұрын
profesor, de esta misma manera es que nos gustaría que nos explicaras de manera muy sencilla y basico, los framework ya sea React, Vuejs, Angular y no siempre crear un crud y listo. osea crear un crud no es que este mal si no que hace falta 2 temas muy importante aparte de un crud y es crear un login y Proteger Rutas del servidor. a cuantos nos no hubieras gustado mas, en esos cursos que tiene que explica los stack de MEVN, MERN, MEAN, si le hubieras añadido estos 2 temas el del login y proteger rutas hubieras sido el curso perfecto. por que crear una aplicación web sea con cualquiera stack siempre va tener login, y protección de rutas y crud. Ojala lo tengas en cuenta para proximos tutoriales cuando quieras explicar algun stack. que aparte de explicarnos a crear un crud ahi mismo también nos explique a crear login y proteger rutas. se lo agradecería mucho
@ericlb36313 жыл бұрын
Impresionante tutorial. Varias veces tuve que revisar si la velocidad de reproducción del video no estaba al 1.5x o 2x, muy muy ágil el ritmo. Cada minuto se me hacía como 5 en lo que entendía y codificaba, pero vale mucho la pena. Felicidades por ese entusiasmo @Fazt. Sería un tutorial completamente redondo si hubieras incluido el deployment en un server, pero de cualquier forma, excelente tu trabajo y dedicación.
@guillermosandoval84162 жыл бұрын
Para error en min 20:50 En lugar de requerir handlebars de la forma: - const exphbs = require('express-handlebars'); Tenes que hacerlo de la forma: -const {engine} = require('express-handlebars'); Y despues cuando configuras el motor en app.engine pone: app.engine('.hbs', engine({ (y aca pones toda la configuracion del motor que esta en el video) }));
@anaconda3122 Жыл бұрын
gracias
@luislazaroaquino978811 ай бұрын
gracias
@oscargomez17219 ай бұрын
app.use(require('./routes/authenticacion')) pudiste arreglar este error?
@tomasarias4548Ай бұрын
tienen que escribir const { engine } = require('express-handlebars'); en lugar de const exphbs = require('express-handlebars'); y en lugar de app.engine('.hbs', exphbs({ defaultLayout: 'main', layoutsDir: path.join(app.get('views'), 'layouts'), partialsDir: path.join(app.get('views'), 'partials'), extname: '.hbs', helpers: require('./lib/handlebars') })) solo cambiar exphbs por engine app.engine('.hbs', engine({ defaultLayout: 'main', layoutsDir: path.join(app.get('views'), 'layouts'), partialsDir: path.join(app.get('views'), 'partials'), extname: '.hbs', helpers: require('./lib/handlebars') }))
@lixandermolina93664 жыл бұрын
llevo medio día y por fin me sale "hola mundo" muy bueno el vídeo, me gusta cuando empiezas algo y lo dejas terminado, sin importar el tiempo que te tardes.
@giovannygarzonsoto5 жыл бұрын
3:45:37 "y asi de sencillo hemos terminado con nuestra aplicacion" asdkjaklsdasld estube un dia entero :'c
@jairarteaga38465 жыл бұрын
jaja a mi 2 días XDD
@oscaralvarez15195 жыл бұрын
jajaja a mi 3 dias xDD
@ricardovillalobos22935 жыл бұрын
jaja a mi 4 días XDD DD
@elkinmejia15935 жыл бұрын
jaja a mi una semana XDDDDD
@jhoplainc66885 жыл бұрын
jaja yo a mi 1 mes XDDDDDDDDD
@MikeHurtado-cb4lc5 жыл бұрын
"Pode os colocarlo en un pedazo de código". Si, señor. Tú lo vales
@kalanzans6 жыл бұрын
Sensacional! Gratitud por su empenho y inteligencia! Saludos desde Brasil! :^)
@fadassi1540309184 жыл бұрын
Fatz termine la aplicacion!!! quedo andando!! GRacias hermano, sos muy bueno explicando!
@yuryapaza30776 жыл бұрын
Q buen video fazt, sabes demasiados módulos, podrías enseñarnos a los novatos como saber que modulo y cuando usarlo para crear aplicaciones web
@humbertocoldev6 жыл бұрын
apoyo este comentario
@finonomastropiero42615 жыл бұрын
almenos, un video de los métodos más utilizados para los modulos más utilizados
@osmeig60255 жыл бұрын
Nunca les contestará. Le copia todo el contenido a otro canal. Dudo sepa programar éste muchacho.
@clementedb37125 жыл бұрын
@@osmeig6025 a que canal le copia?
@osmeig60255 жыл бұрын
@@clementedb3712 Traversy Media
@yulian.music.5 жыл бұрын
Te superaste Fazt, ademas de tus conocimientos, añadiste una excelente y dinámica edición al contenido. El index course, algo muy sencillo, es un detalle que se agradece para acceder puntualmente a lo que se desea. Saludos y gracias !!!
@Kyevnieves2 жыл бұрын
Si alguien tuvo problemas al redireccionar al SignIn cuando intentaba entrar al Profile Section, por que la funcion IsAuthenticated is undefined, en el tiempo 03:22:10 . Sugiero cambiar un codigo en el archivo authentication.js cuando creamos la ruta Get '/profile' cambiarla por el siguiente codigo: router.get("/profile", (req, res) => { if (req.user === undefined) { res.redirect("/signin"); } else res.render("profile"); }); Obviamente no creamos la funcion isLoggedIn, si no que esperamos que el req devuelva un usuario (en la comprobacion del If) si no es el caso entonces rendireccionamos a /signin. Espero les sea de utilidad
@virginiafredes47442 жыл бұрын
@Keyver Nieves holas.. sabes tengo un problema con el signin... Los mesajes de error se muestran.. pero cuando pongo bien los datos tanto el usuario y la clave.. me sigue apareciendo clave incorrecta.. :(
@Kyevnieves2 жыл бұрын
@@virginiafredes4744 me parece que estás comparando la contraseña con el Hash que está guardado en la BD, tienes que usar la función compare. No sé si sea tu caso
@virginiafredes47442 жыл бұрын
@@Kyevnieves si.. estoy usando el compare.. pero sigue igual. .( passport.use('local.signin', new LocalStrategy({ usernameField: 'username', passwordField: 'password', passReqToCallback: true }, async (req, username, password, done) => { const rows = await pool.query('SELECT * FROM users WHERE username = ?', [username]); if (rows.length > 0) { const user = rows[0]; const validPassword = await helpers.matchPassword(password, user.password) if (validPassword) { done(null, user, req.flash('success', 'Welcome ' + user.username)); } else { done(null, false, req.flash('message', 'Incorrect Password')); } } else { return done(null, false, req.flash('message', 'The Username does not exists.')); } })); y el metodo matchPasword lotengo asi helpers.matchPassword = async (password, savePassword)=>{ try { return await bcript.compare(password, savePassword); } catch (error) { cosole.log(error); } };
@Kyevnieves2 жыл бұрын
@@virginiafredes4744 y el error en consola que dice
@maykolsalgado2914 Жыл бұрын
gracias me sirvió 😄
@israx23 ай бұрын
puff 3 días metiendole a este video duro. xD aprendí un monton y ahora que me estoy dando cuenta ahora tengo un proyecto base. para cualquier cosa.
@SandraMedina-qe6uw2 жыл бұрын
Si a alguien le aparece el error ER_NOT_SUPPORTED_AUTH_MODE Es muy probable que la versión del MySQL sea 8.0 y está versión trae un modo de autenticación predeterminado que aún no es compatible con esta biblioteca. Se soluciona de la siguiente forma: 1. Vas a MySQL y escribes la siguiente línea de código: ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'escribe la contraseña'; Espero sea de su ayuda 😄
@anonymushadow2822 жыл бұрын
me sale Error: ER_ACCESS_DENIED_ERROR: Access denied for user 'root'@'localhost' (using password: YES), segun lei debo poner eso para cambiar la clave de mysql pero tengo mysql solo en la consola, al intentar poner eso me sale otro error, RROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near 'BY 'aÑsñ//or2*343s'' at line 1...
@mesac19882 жыл бұрын
@@anonymushadow282 amigo tuve el mismo problema y me fije que tenia mal la estructura de el keys.js
@anonymushadow2822 жыл бұрын
@@mesac1988 encontre la solucion y no fue eso xque hasta copie y pegue el codigo, no se bien el xque del error pero tenia sqlServer y mysql instalados, al desinstalar sqlServer y toda su info me anduvo, parece que se interponian los datos op algo asi
@nicolas_stradivarius2 жыл бұрын
Me salvaste la vida, estuve como 2 horas probando otros paquetes como connect-session-sequelize o connect mysql2, porque encima yo no uso el paquete mysql sino mysql2 que es más moderno y seguro y pensaba que eso tenía algo que ver. muchas graciasssssss
@gonzalo71765 жыл бұрын
Nunca antes vi completo un video tan largo en YT! jaja... De principio a fin, excelentes explicaciones y mucha información. A veces tenia que poner la velocidad a 0.75 para seguirte pero igual me gustó mucho. Seguiré más tutoriales tuyos! Gracias por el enorme esfuerzo! Like y Suscripto!
@a.d.z.58404 жыл бұрын
Eu conheci o canal hoje e já sou fã. Parabéns!
@ericlb36313 жыл бұрын
1:31:37 Cuidado con el campo "created_at timestamp NOT NULL DEFAULT current_timestamp" generado automático desde base de datos. Ya estando en producción, el servidor tomará su propia fecha, que no necesariamente coincidirá con la del usuario, y por lo cual el timeago mostrará datos incorrectos. Lo ideal sería tomar la fecha que tiene el cliente al momento de la creación del registro.
@ernestoalonso55653 жыл бұрын
Muy buen aporte!
@davinchocamaron6463 жыл бұрын
como tomo la fecha del cliente?
@ericlb13472 жыл бұрын
@@davinchocamaron646 En el 1:14:45 habría que crear una variable que almacene la fecha y hora del usuario usando new Date(), y luego agregarla al objeto newLink. Algo así: const {title, url, description} = req.body; const created_at = new Date(); const newLink = { title, url, description,created_at, user_id: req.user.id };
@JorgeFuentesDev8 ай бұрын
que gran trabajo, fue un excelente tutorial, detalles como el usar templates lo hacen lejos de lo mejor que he visto, gracias por esto.
@marianocuenca7466 жыл бұрын
Te pasas man! Eres el mejor, gracias por todo!
@OscarD3v3 жыл бұрын
solumobil.com
@vacaloca5245 жыл бұрын
Llevo SEMANAS buscando un tutorial que me sirva y encontré el adecuado, vieras que chingón se sintió que mandara datos correctamente a la bd :'DD ERES EL MEJOR!!! Un cálido abrazo desde México, amigo.
@emanuelengelman97925 жыл бұрын
Hay q imaginar cosas chingonas
@larrycaichihuavergara78126 жыл бұрын
De verdad muchas gracias Fazt !!
@MiguelBaena55 жыл бұрын
amigo una pregunta estoy en windows y siempre tengo problemas con la consola cuando pongo mysql no me reconoce apesar de que tengo instalado xampp y tambien mysql como lo hiciste ayuda
@gustavobataglia1929 Жыл бұрын
Gente! Aca 2023! Tuve muchos problemas a la hora de seguir este magnífico tutorial ya que muchos módulos cambiar.. pero luego de tanto buscar pude encontrar todas las soluciones!! Así que si tienen dudas pregunten! Gracias fatz!
@josslipknot Жыл бұрын
hola bro, como hiciste en el final con el user_id, por que yo lo hice tal cual, me permite agregar el link con total normalidad, pero cuando voy a "All links" no me muestra nada, como si no tuviera, y en realidad están creados en la base de datos.
@diegoalfonsolagosmacaya1310 Жыл бұрын
bro, podrías recopilar algunas soluciones?
@kembertnieves65106 жыл бұрын
Genial!!! pero no nos olvides a los de MERN XD! saludos
@EduMetal-ok5 жыл бұрын
Excelente vídeo. Sin desperdicio cada minuto. Ágil, excelentemente explicado. Entre sin saber nada de nodejs y ya tengo una aplicación base completa y funcional.
@GeekCyan3 жыл бұрын
Sería posible un CRUD Node con express, React y MYSQL, gracias por el contenido
@luisdavidecheverria82813 жыл бұрын
Solo cambia handlebars por React
@mithrandir89193 жыл бұрын
eso esta interesante para aventurarte de manera autodidacta, no es tan distinto de esto. Te lo recomiendo, eso hice yo y aprendes mas solo, una vez que tienes una base como la de este video que siguiendo videos tutoriales para cada cosa que quieres hacer
@lionelojeda25932 жыл бұрын
@@luisdavidecheverria8281 Osea en ves de llamar a las vistas de los archivos handlebars, llamo a las vistas de los archivos que están dentro de la carpeta con el front en react ?
@guatherodson69182 жыл бұрын
@@lionelojeda2593 tiens que instalar cors, y abrir en un puerto diferente el react y en otro le servidor, mirate el reciente video de fazt donde hace el stack MERN
@lionelojeda25932 жыл бұрын
Lo pregunte hace 4 meses xd. Gracias igual
@alexpineda17204 жыл бұрын
El mejor video de passport y mysql que existe en español en youtube, muchas gracias
@alexyz526 жыл бұрын
Hola Fazt, en producción se sube todo el proyecto? O hay que configurar algo adicional? Muy buen contenido. Saludos
@Rhen.5 жыл бұрын
x2
@ZalenjiHD5 жыл бұрын
Puedes configurar las variables de entorno para que no se vea tu base de datos en el código y mas importante, manejar los errores. Ya si lo consideras necesario puedes usar transacciones en las rutas por si quieres usar el ejemplo como molde para tu propio proyecto.
@ricardoromo29646 жыл бұрын
Estas onfire con estos aportes, te mereces que comparta todos tus videos. El mejor youtuber de programacion aplicada
@educode_6 жыл бұрын
Eu sou do Brasil acompanho seus vídeos PF vc poderia fazer mais vídeos sobre mongo dB , parabéns por todos os vídeos e muito obrigado pelo conteúdo
@alejandrotoro6027 Жыл бұрын
Fazt me llevas a otro nivel men. Gracias, bro. No suelo hacerlo, pero debo hacerlo. Aun en este año y todo sirve, hay que leer algunos documentos que han actualizado o los comentarios. Gracias
@kevincoradoperez20393 жыл бұрын
Tengo un problema con la vista profile.hbs, cuando añado {{user.fullname}} o {{user.username}} no me lo muestra por pantalla en la vista /profile, lo he puesto en las variables globales pero nada. ¿Llevo unas 4 horas intentando ver cuál es el error, pero aparentemente está todo bien, alguien me podría ayuda? Gracias.
@ThePablocaleb3 жыл бұрын
Lo pudiste resolver?
@sahuaro0073 жыл бұрын
En el archivo index.js asegurate de que las lineas "app.use(passport.initialize());" y "app.use(passport.session());" esten en la sección de "Middlewares", o sea antes de la sección de "//global variables", que es donde se encuentra esta linea: "app.locals.user = req.user;"
@sahuaro0073 жыл бұрын
@@ThePablocaleb En el archivo index.js asegurate de que las lineas "app.use(passport.initialize());" y "app.use(passport.session());" esten en la sección de "Middlewares", o sea antes de la sección de "//global variables", que es donde se encuentra esta linea: "app.locals.user = req.user;"
@maykolsalgado2914 Жыл бұрын
@@sahuaro007 gracias esto me ayudo a solucionar un miss typing en un app.use
@AlejandroGuerrero4 жыл бұрын
MUCHAS GRACIAS por esta MASTERCLASS de MAESTROS!! He tardado 3 días en seguirla, pero he aprendido muchísimo. Gracias infinitas. Saludos desde Madrid.
@OscarD3v3 жыл бұрын
solumobil.com
@josealbertolopezjimenez8115 жыл бұрын
Ahora con postgres
@SebastianEPH4 жыл бұрын
luego de un mes recien terminé el video XD bueno fui viendo el video y lo iba modificando a un sistema de examenes (como trabajo final de la universidad) donde hay profesores, estudiantes, los profesores pueden crear preguntas y los estudiantes pueden tomar examen, la verdad que sin tu video hubiera sido imposible avanzar por mi cuenta, por ese detalle te agradezco. Orgullo Peruano FAZT
@elbrusbaskaev4835 жыл бұрын
1:16:08 justo ahi me sale un error x.x " pool.query is not a function"
@finonomastropiero42615 жыл бұрын
Estoy en la misma situación, parece que la función pool.query( [lenguaje sql], callback function) necesita afuerzas una funcion callback... definir en caso de error
@@elbrusbaskaev483 alguien pregunto en stackoverflow, y le respondieron bien. Hice lo que indicaron y funcionó todo, mas no entiendo bien la cuestion de las promesas. es.stackoverflow.com/questions/266927/error-en-almacenar-datos-con-mysql-y-node-js?newreg=02f0dbad8ecb48b08498a79e01aeb3b7
@jujo_mine28003 жыл бұрын
fabuloso tutorial bro, se que estoy como 2 años tarde pero queria agradecerte por compartir tan buen material, aprendi muchisimo viendolo.
@luismeza60155 жыл бұрын
Tengo un error en el minuto 18:15 me sale npm ERR! missing script: dev en la consola AYUDAA!
@cristianjaimes99515 жыл бұрын
Tenia el mismo error y era error de sintaxis, revisa bien el codigo.
@luismeza60155 жыл бұрын
@@cristianjaimes9951 si bro, la única solución fue empezar todo desde el inicio y me di cuenta de algunos errores que había cometido en el código, también había instalado el NodoJS LTD y no el Actual por lo que me toco instalar de nuevo el NodoJS. Saludos!
@Alexis-ei9ct4 жыл бұрын
Mis respetos a Fazt. Un millón de gracias por compartir tu conocimiento con el mundo.
@fire81506 жыл бұрын
podrias hacer un crud utilizando nodejs, react y mysql please
@OscarD3v3 жыл бұрын
solumobil.com
@wofwofotroperro71274 жыл бұрын
TE AMOOOOOOOOOOOO, pude hacer mi aplicacion usando oracle en vez de mysql y me salte los comentarios flash, por que son de mysql, y todo lo demas me fue de perlas, aunque si me arrojaba un error al momento de guardar datos en la sesion, eso lo resolvi importando unas cookies y creando mas arriba de app.use(session()); otra sesion que es la misma que el hizo donde esta guardando secret, resave y saveUnitialized
@alfredofjahn6 жыл бұрын
Como que nadie entendio la referencia de pew news
@h4oo5 жыл бұрын
Explicate
@pancaku86045 жыл бұрын
yo si jaja
@1sam2fisher4 жыл бұрын
Jajaja estaba buscando desesperado a ver si alguien más lo había captado, parece somos pocos xD
@OFISPOT4 жыл бұрын
Tu esfuerzo y toda esa experiencia para transmitir, vale de sobra la pena de cualquier aporte que hagamos los seguidores. Saludos
@davidadrianuribesoto18306 жыл бұрын
He aprendido muchísimo de este canal y lo he compartido a mis colegas para que tu canal crezca, para mi el mejor de todos, me ha sido muy útil en mi vida profesional. Muchas gracias Fazt por este excelente trabajo que haces. PD: Seria excelente que aunque los vídeos se extiendan más, uses React, Angular o Vue para los próximos vídeos, creería que la mayoría vamos a preferir React que un motor de plantillas. De nuevo mil gracias y saludos, de verdad espero más vídeos tipo MERN, esperare por ellos jeje.
@vicerix4 жыл бұрын
GRACIAS FAZT!!!!! Me demore todo el finde pero lo logre!, doy fe que todo funciona perfecto!, cuidado con meter los dedos mal!!!
@OscarD3v3 жыл бұрын
solumobil.com
@daniloespinozapino48653 жыл бұрын
Que buen video, lo seguí por completo, no aburre en ningún momento y son 4 horas!
@Sergio-di1jt5 жыл бұрын
Como ya dijeron, saca patreon, mereces que la gente te de dinero por la ayuda que nos estas dando.
@CarlosDan4 жыл бұрын
Mientras ustedes le dicen que patreon el ya creo varios emprendimientos gracias a sus seguidores, otra manera de monetizar :9
@brian08593 жыл бұрын
01:06:31 para el botón me funcionó: Save
@kdrew61913 жыл бұрын
Que joya joya JOYA este canal de youtube, si el video dice 4 horas, pero no te dice +4 días de conocimiento que te aporta
@anonymushadow2822 жыл бұрын
me perdi un poco con lo de la funcion done, pero bueno, lo volvere a revisar, gracias, al fin alguien que explica esto
@olivertzunun37984 жыл бұрын
No se porque pero esto me hace amar mas a flask, me sente a ver el video a las 3 de la tarde y todavia no termino(son las 11)---- GRACIAS FAZT
@grbsql5 жыл бұрын
Muy bien Fazt. Excelente trabajo. Tienes muy buen conocimiento de estas herramintas. Felicitaciones.Muchas gracias por compartirlo. Que avances continuamente y logres TODO lo que quieras. Eso te lo devuelve la Vida por compartir.
@diegosan11254 жыл бұрын
Muchas gracias Fazt. Acabo de terminar este fabuloso curso. Solo faltaron los iconos. Muchas gracias y saludos.
@tatan19945 жыл бұрын
Me fascinó este tutorial. Es el mejor que he descubierto, incluso mejor que los de pago
@eduardoauditore54145 жыл бұрын
Un año después me encontre con tu curso excelente nivel, gracias por el aporte!
@OscarD3v3 жыл бұрын
solumobil.com
@alessandromorales49584 жыл бұрын
Excelente video amigo, muchísimo mejor que muchos cursos pagados. Sigue así crack!!!
@ruthcacua69774 жыл бұрын
Me encanta! definitivamente eres un crack estaba intentando con mongoose y no me resultaba hasta que por tu excelente tutorial logre el back conectarlo con el fronted de react! sigue asi crack
@davidsaso12344 жыл бұрын
Ptmr... Hermano, te A-M-O. Me ha servido demasiado este tutorial, al fin lo terminé. Mil gracias
@LuisRescala4 жыл бұрын
Amigo, tengo un problema con el bcrypt ¿podrías ayudarme?
@quipu20117 ай бұрын
Excelente video, muchas gracias Por favor continúa con más clases de NodeJs
@rodrigoquintero38553 жыл бұрын
excelente!... estoy haciendo un curso pago... pero estoy aprendiendo mas con tus videos que con el curso, una sola sugerencia: habla mas despacio, vas muy rapido, respira!!! :-)