Una necesidad trivial de un formulario suele ser la carga de un archivo. Un PDF, una foto, etc. Cuando requieres de este tipo de Inputs, tienes que considerar que este archivo está compuesto por datos binarios que tienes que enviar al servidor.
Guardado de binarios en un servidor
En las API REST, el envío de información se realiza en formato JSON con el header Content-type: application/json. Pero para el envío de archivos binarios, se utiliza el header Content-type: multipart/form-data.
Veamos a continuación cómo enviar este tipo de dato con Angular.
1. Formulario para envio de datos
Utilizando la clase FormData, puedes instanciar un formulario de este tipo y adjuntarle con append() el Blob del archivo que quieres enviar el servidor
// services/files.services.tsexportclassFilesService{constructor(privatehttp:HttpClient,){}uploadFile(file:Blob):Observable<any>{const form =newFormData(); form.append('file', file);returnthis.http.post(`https://example.com/api/files`, form,{headers:{'Content-type':'multipart/form-data'}});}}
2. Capturando el archivo
Ahora, desde el componente, tienes que crear un Input que capture el archivo y una función que lo manipule y realice la solicitud.
onLoad(event:Event):void{const element = event.targetasHTMLInputElement;const file = element.files?.item(0);if(file){this.filesService.uploadFile(file).subscribe(res=>{console.log(res);});}}
Cada vez que el usuario cargue un archivo, se ejecutará el método uploadFile() y a través del evento puedes manipular el elemento HTML y capturar el archivo en formato Blob.
Apóyate de la interfaz HTMLInputElement para tipar el elemento y capturar así el archivo.
No te desanimes, esta bien sentirte frustrado, esta bien todo eso, vas a tu ritmo y no tienes carrera con nadie, si de algo te sirve, conseguí trabajo gracias a este capo llamado Nicolas Molina y de echo sigo utilizando los vídeos incluso si necesito recordar algo.
Ahora estoy haciendo un registro con subida de archivos obligatorios y literal este vídeo hoy por hoy lo utilicé para trabajar, recordar.
Recuerda, no tienes que saber de todo o todo a la perfección, lo que tienes que tener en cuenta es ser recursivo, buscar información y al final, resolver problemas.
No te digo que es fácil, pero valdrá la pena, echale ganas.
#Nunca Pares De Aprender
Necesitaba este comentario, gracias Darwing!
Gracias por los ánimos, Darwing, solo una pregunta, qué quieres decir con recursivo, me interesa de verdad pués siempre los ánimos decaen y me gusta seguir los consejos de la gente positiva, los necesito. Que es recursivo?
Que buen curso.
Vamos a por la siguiente clase.
xdd
este curso es una cosa de locos, 10/10 !
Que lindo es ver los cursos de Angular de seguido, se aprende mucho, siento que ya me ciento preparado para agregar Angular a mi kit de habilidades <3
Si tienen _error _en la funcion onUpload, parsean el file con as Blob:
onUpload(event:Event){const element = event.targetasHTMLInputElement;const file = element.files?.item(0)asBlob;this.filesService.uploadFile(file).subscribe(rta=>{console.log('upload', rta)this.imgRta= rta.location;})}
gracias!
Epaaaa, ya casi acabo el curso
No me deja subir la imagenme sale internal server error sera que se cayo ese endpoint?
Febrero 2023, al parece ya sirve.
Febrero 16-2023, sigue sin funcionar, error 503 ;(
Me estaba saliendo problemas de CORS. Asi lo solucione:
Excelente clase, una pregunta ¿Funcionaría igual para subir vídeos? Entiendo que sería un archivo más pesado y debería de existir una forma de mostrarle al usuario el procentaje del vídeo subido
Recibo error 503, aun esta disponible el endpoint?
Obtuve el mismo error, el endPoint esta en Swagger, pero, parece que no esta funcionando
Para cambiar de ambiente si estaban trabajando con el local
ng serve --configuration=production --port=3500
Una consulta les funciona el endpoint a la hora de subir una nueva imagen?
🟢 Hello!
¿Podrías subir tu código para guiarte de una manera precisa? 🤗
Un abrazo de gol! 🦾
Aqui no habria que extraer la base 64, en que casos aplicaria esto ?
Tienen algun ejemplo pero usando el upload de ng prime ?
Se puede usar como parametro del servicio upload el tipo de dato = File?