Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/jesparzarom/diario_web_demo

Portal de noticias Fullstack con PHP, MySQL y Bootstrap. Gestión de usuarios y noticias, filtrado avanzado, y sistema de inicio de sesión basado en roles.
https://github.com/jesparzarom/diario_web_demo

000webhostapp authentication bootstrap5 crud css3 html5 mysql newsapp php phpmyadmin role users

Last synced: 1 day ago
JSON representation

Portal de noticias Fullstack con PHP, MySQL y Bootstrap. Gestión de usuarios y noticias, filtrado avanzado, y sistema de inicio de sesión basado en roles.

Awesome Lists containing this project

README

        

# Proyecto Final: Página Web de Diario - Curso de Fullstack Jr (UNLPam, Argentina Programa 4.0)

Este documento proporciona una descripción detallada del proyecto final desarrollado como parte del Curso de Fullstack Jr ofrecido por la Universidad Nacional de La Pampa (UNLPam) en el programa Argentina Programa 4.0. El proyecto consiste en la creación de una página web de un diario con funcionalidades de Frontend y Backend utilizando:

- Bootstrap 5
- estilos css personalizados
- FontAwesome
- Google Fonts
- PHP
- MySQL.

## Estructura del Proyecto

El proyecto se organiza de manera eficiente y está compuesto por las siguientes carpetas y archivos clave:

```yaml
diario/
admin/
agregar_usuario.php: Nuevo usuario.
form_login.php: Formulario de inicio de sesión.
menu.php: Menú de navegación.
publicaciones.php: Página para administrar las publicaciones de noticias.
usuarios.php: Página para gestionar usuarios del sistema.
editar_usuario.php: Permite editar la información de un usuario existente.
index.php: Página principal del sistema administrativo.
mis_publicaciones.php: Página que muestra todas las publicaciones de un autor.
todas_publicaciones.php: Página que muestra todas las publicaciones en el sistema.

backend/
admin_mis_noticias.php: Permite gestionar sus propias noticias.
admin_usuarios.php: Administración de usuarios, incluyendo la edición y eliminación.
agregar_usuario.php: Agregar un nuevo usuario al sistema.
borrar_usuario.php: Elimina un usuario existente.
editar_noticia.php: Permite editar una noticia existente.
login.php: Proceso de inicio de sesión.
usuario_disponible.php: Utilizado para verificar la disponibilidad de nombres de usuario.
admin_noticias.php: Administración completa de noticias, incluyendo listar, crear y eliminar.
agregar_noticia.php: Permite agregar una nueva noticia.
borrar_noticia.php: Elimina una noticia existente.
conexion.php: Configuración de conexión a la base de datos.
editar_usuario.php: Permite editar información de usuario.
logout.php: Proceso de cierre de sesión.
ver_noticia.php: Visualización de una noticia completa.

estaticos/
css/
style.css: Archivo de estilo CSS para el diseño de la aplicación.
js/
scripts.js: Archivo JavaScript para funciones interactivas.

imagenes/
logos/: Carpeta que almacena los logotipos y gráficos.
subidas/: Directorio para cargar imágenes y archivos.

noticias/
footer.php: Pie de página común para las noticias.
form_agregar.php: Formulario para agregar una nueva noticia.
form_editar.php: Formulario para editar una noticia existente.
index.php: Página principal del portal de noticias.
menu.php: Menú de navegación.
noticia.php: Página individual de una noticia.
```

## Base de Datos

La aplicación utiliza una base de datos MySQL denominada `diariodb`, que consta de al menos dos tablas fundamentales:

1. **usuarios**: Almacena la información de los administradores del sistema, incluyendo campos como id_usuario, usuario, nombre, apellido, contraseña encriptada, roles (admin, autor).

2. **news**: Contiene la información sobre las noticias, con campos como id_noticia, título, fecha, autor (id_usuario), copete, cuerpo, imagen principal.

## Características Principales

El proyecto incluye las siguientes características destacadas:

- **URL Distintas**: El portal y el sistema administrativo tienen URLs separadas para un acceso diferenciado.

- **Administradores del Sistema**: Los administradores se almacenan en la base de datos y pueden realizar diversas acciones, como listar, dar de alta, eliminar, editar y resetear contraseñas.

- **Gestión de Noticias**: Permite la administración completa de noticias, incluyendo listar, crear, editar y eliminar.

- **Orden de Noticias**: Las noticias en el portal se presentan desde la más reciente hasta la más antigua.

- **Límite de Noticias**: En el portal, se muestran hasta un máximo de 10 noticias, con las más nuevas reemplazando automáticamente a las más antiguas si existen más de 10 noticias en la base de datos.

- **Página de Noticia Completa**: Permite ver una noticia completa en una página separada, respetando el diseño del portal de inicio. Incluye la visualización del autor de la noticia.

- **Contraseñas Encriptadas**: Las contraseñas de los administradores se almacenan en la base de datos de forma segura mediante encriptación.

## Innovación Creativa Libre:
- Se implementó un sistema de inicio de sesión basado en roles, redirigiendo a los administradores a una página de administración de usuarios y a los autores a la página de "mis publicaciones", donde se muestran sus propias noticias.
- Además, se añadieron filtros por categoría y autor en diferentes páginas y se incorporaron tablas interactivas para la gestión de noticias y usuarios.
- Se utilizó tecnología Ajax para verificar la disponibilidad de nombres de usuario en tiempo real al crear nuevos usuarios.

## Conclusiones

Este proyecto final representa un logro significativo en la implementación de una página web de un diario con funcionalidades Fullstack utilizando PHP y MySQL. Las características cumplen con las consignas del curso, y se ha agregado valor a través de innovaciones creativas como el inicio de sesión basado en roles y los filtros avanzados.

Este proyecto ha sido realizado como parte del Curso de Fullstack Jr en el marco del programa Argentina Programa 4.0, proporcionando una valiosa experiencia en el desarrollo de aplicaciones web Fullstack.
https://diariofakes.000webhostapp.com/diario/noticias/
**Equipo de Desarrollo:**
Juan Esparza