Lecciones impartidas en clase (curso 2024/25)

Introducción

Esta lección contiene un índice de las lecciones que estoy impartiendo en clase durante el primer trimestre (y parte del segundo) del curso 2024/25, así como los ejercicios que han realizado los alumnos.

Para elaborar este índice utilizo como base las guías de estudio que ofrezco a mis alumnos de la modalidad semipresencial en la plataforma Moodle de la Conselleria de Educación. El trabajo propuesto a estos alumnos es el mismo que siguen en clase mis alumnos de la modalidad presencial, aunque la distribución temporal no sea exactamente la misma.

La información se ofrece distribuida en semanas, ya que es así como está organizada la modalidad semipresencial.

También se pueden consultar las lecciones impartidas en el curso pasado, 2023/24.

¡Atención! Nota: Por diferentes motivos, este curso 2024/25 estoy acumulando bastante retraso respecto a la planificación inicial. Los principales motivos son, por un lado, que estoy teniendo que añadir más ejercicios y lecciones para intentar compensar las lagunas en conocimientos de programación básica de los alumnos y, por otro lado, que me cuesta más preparar material nuevo que actualizar o mejorar material ya preparado. En cualquier caso, creo que esta página sigue siendo útil porque muestra el orden en el que estamos trabajando los temas, aunque no lo estamos haciendo en las fechas indicadas.

IAW Semana S01: del 09/09/24 al 15/09/24

Presentación del curso Programación web en PHP

  1. Leed la lección Presentación de los apuntes.

¿Qué es PHP?

  1. Leed la lección Lenguajes de programación.
  2. Leed la lección Qué es PHP.

Instalación de XAMPP

  1. Leed la lección Qué es XAMPP.
  2. Leed la lección Instalación de XAMPP en Windows.
  3. Descargad XAMPP 8.2.12 (150 MB).
  4. Instalad XAMPP 8.2.12 de acuerdo con la lección Instalación de XAMPP en Windows.

    Nota: Una vez instalado XAMPP, haced una copia de seguridad de la carpeta /xampp/apache/conf/ y de los archivos /xampp/php/php.ini y /xampp/phpMyAdmin/config.inc.php por si necesitáis recuperarlos si cometéis errores al configurar XAMPP.

Configuración de Apache y PHP

  1. Leed la lección Configuración de Apache y PHP.

    En esta lección se tratan dos puntos muy importantes:

    1. los Alias de Apache, que utilizaremos durante todo el curso.
    2. las opciones de configuración de PHP, que deben modificarse como se indica en la lección para que el comportamiento sea el mismo en los ordenadores de todos los alumnos.
  2. Configurad php.ini de acuerdo con la lección Configuración de Apache y PHP.
  3. Para familiarizaros con la creación de Alias en Apache, haced los ejercicios Apache (1) 1 y 2.

    Podéis consultar unas posibles soluciones de estos ejercicios.

  4. [Opcional] Para ver más opciones de configuración de Apache, leed la lección Configuración de Apache y PHP.
  5. [Opcional] Para practicar más opciones de configuración de Apache, haced los ejercicios Apache (2).

Visual Studio Code

Este curso vamos a utilizar Visual Studio Code (VSCode) como editor para PHP. A lo largo del curso iré completando y ampliando estas lecciones dedicadas a VSCode

IAW Semana S02: del 16/09/24 al 22/09/24

Visual Studio Code

  1. Para familiarizaros con la configuración de VSCode y con la creación de Alias en Apache, haced los ejercicios Apache 3 y 4.

    Podéis consultar unas posibles soluciones de estos ejercicios.

  2. El ejercicio Apache 5 corresponde a la configuración que recomiendo a los alumnos para tener tanto en clase como en casa.

Comprobación de la configuración de Visual Studio Code, Apache y PHP

  1. Haced los ejercicios Puesta en marcha de VScode, descomprimiendo el fichero de plantillas en la carpeta ejercicios.

    Estos ejercicios están pensados para comprobar que se ha hecho correctamente la configuración tanto de Visual Studio Code como de Apache y PHP. Si algún ejercicio no da el resultado indicado, revisad la instalación y configuración del perfil, de Apache o de PHP.

Cómo hacer los ejercicios (1)

  1. Leed la lección Cómo realizar los ejercicios
  2. Leed la lección Ejemplos de resolución de ejercicios - Sin formularios

En la primera parte del curso de PHP vamos a hacer un pequeño repaso general de PHP, tocando los temas vistos el año pasado en el módulo LMSGI: variables, operaciones, if ... else .. y for ... además de las matrices, un tipo de variable que permite almacenar varios datos distintos en una sola variable. Esta parte la he llamado PHP, sin formularios porque las páginas no contienen formularios, por lo que el usuario no puede proporcionar información a los programas. Para que cada vez que se ejecuten los programas los resultados sean distintos, recurriremos a números aleatorios.

Primeras páginas en PHP

  1. Leed la lección Primeras páginas en PHP
  2. Leed la lección Cadenas
  3. Leed la lección Guía de estilo.

    El estilo que se recomienda en esta lección es el que tenéis que utilizar en vuestros programas.

  4. Haced los ejercicios 1 a 3 de Primeras páginas.

    Estos ejercicios se pueden hacer de muchas maneras, incluyendo más o menos líneas en cada uno de los fragmentos PHP o HTML.

    Podéis consultar unas posibles soluciones de estos ejercicios. También podéis descargar unas posibles soluciones completas de estos ejercicios.

  5. Haced los ejercicios 4 a 8 de Primeras páginas.

    En estos ejercicios se necesita la función rand() que genera números aleatorios que se comenta en la lección Operaciones aritméticas (apartado Números aleatorios).

    Podéis consultar unas posibles soluciones de estos ejercicios. También podéis descargar unas posibles soluciones completas de estos ejercicios.

Variables

  1. Leed la lección Variables 1

    Esta semana no os pido hacer ejercicios con variables, pero quiero que leáis esta lección.

IAW Semana S03: del 23/09/24 al 29/09/24

Variables y operaciones

  1. Leed los apartados de la lección Tipos de variables: enteras y decimales.
  2. Leed la lección Operaciones aritméticas.
  3. [básico] Haced los ejercicios Variables 0.
    1. Estos ejercicios son ejercicios muy básicos que he añadido este curso para alumnos que no han dado la parte de programación del módulo LMSGI de 1º de ASIR. Hacedlos si lo consideráis conveniente.
    2. En estos ejercicios se puede utilizar la función rand() que genera números aleatorios y que se comenta en el apartado Números aleatorios de la lección Operaciones aritméticas.
    3. Los valores aleatorios se utilizan en varios lugares de la página web, por lo que se deben guardar en una variable y después utilizar la variable el número de veces necesario. En algunos ejercicios también es necesario hacer cálculos adicionales con esas variables.

    Podéis consultar unas posibles soluciones de estos ejercicios. También podéis descargar unas posibles soluciones completas de estos ejercicios.

  4. Haced los ejercicios Variables 1.
    1. En estos ejercicios se puede utilizar la función rand() que genera números aleatorios y que se comenta en el apartado Números aleatorios de la lección Operaciones aritméticas.
    2. Los valores aleatorios se utilizan en varios lugares de la página web, por lo que se deben guardar en una variable y después utilizar la variable el número de veces necesario. En algunos ejercicios también es necesario hacer cálculos adicionales con esas variables.
    3. Los dados y las cartas que aparecen en algún ejercicio son imágenes SVG que están incluidas en las plantillas de los ejercicios. El resto de imágenes SVG están incluidas en la propia página web. Recordad que debéis mirar el código fuente del ejemplo de ejercicio.
    4. Los ejercicios 1 al 5 son fáciles, porque en realidad los programas sólo tienen que generar algunos valores numéricos del código SVG.
    5. Los ejercicios 11 al 15 son más difíciles porque se necesita expresar fórmulas para obtener algunos valores del dibujo. En los ejercicios 11, 12 y 13 las fórmulas pueden deducirse del propio dibujo (en la ayuda que acompaña a los ejercicios hay dibujos explicativos). En los ejercicios 14 y 15 la fórmulas se pueden deducir fácilmente a partir de los valores por ser fórmulas de sucesiones aritméticas (del estilo de las que vimos en Python en LMSGI el curso pasado, Teoría y ejercicios tipo test).

    Podéis consultar unas posibles soluciones de estos ejercicios. También podéis descargar unas posibles soluciones completas de estos ejercicios.

IAW Semana S04: del 30/09/24 al 06/10/24

Estructuras de control: Sentencia condicional if ... elseif ... else ...

  1. Leed el apartado Variables lógicas de la lección Tipos de variables (solamente el apartado Variables lógicas).
  2. Leed la lección Operaciones lógicas.
  3. Leed los dos primeros apartados (Bloques de instrucciones e if ... elseif ... else ...) de la lección Estructuras de control.
  4. Leed la lección Sentencia condicional if ... elseif ... else ....
  5. Leed la lección HTML Tablas (apuntes HTML/CSS).

    En los ejercicios de esta semana aparecen tablas HTML, así que conviene que conozcáis las etiquetas que las definen. Básicamente, una tabla (<table>) está formada por filas (<tr>) que a su vez están formadas por celdas (<td> o <th>), aunque suelen aparecer más etiquetas que se explican en la lección.

  6. [básico] Haced los ejercicios if ... else ... (0).

    Estos ejercicios son ejercicios muy básicos que he añadido este curso para alumnos que no han dado la parte de programación del módulo LMSGI de 1º de ASIR. Hacedlos si lo consideráis conveniente.

    Podéis consultar unas posibles soluciones de estos ejercicios. También podéis descargar unas posibles soluciones completas de estos ejercicios.

  7. Haced los ejercicios if ... else ... (1). Los ejercicios 1, 2 y 3 son fáciles. El 4 y el 5 son más difíciles. Antes de hacer los ejercicios 4 y 5, mirad la solución propuesta del ejercicio 3, en la que se comenta un enfoque del ejercicio 3 que podéis aplicar al ejercicio 5.

    Podéis consultar unas posibles soluciones de estos ejercicios. También podéis descargar unas posibles soluciones completas de estos ejercicios.

  8. [repaso] Podéis hacer también los ejercicios extra if ... else ... (1). Son cuatro ejercicios que puse en exámenes de años anteriores (por eso no hay soluciones disponibles).

    En estos ejercicios se utilizan entidades numéricas para mostrar emojis, como vimos en el módulo Lenguaje de Marcas. Para refrescar la memoria podéis releer las lecciones UTF-8 y Entidades (en los apuntes HTML/CSS).

IAW Semana S05: del 07/10/24 al 13/10/24

Estructuras de control: Bucle for

PHP dispone de varias estructuras de control para definir bucles. Empezaremos por la estructura for y después de ver matrices veremos la estructura foreach. Tened en cuenta que la estructura for de Python que vimos en el módulo de Lenguaje de Marcas se parece más a la estructura foreach de PHP que a la estructura for de PHP.

  1. Leed la lección Bucle for.
  2. Repasad el apartado colores HWB de la lección Colores de los apuntes de HTML/CSS.

    Tradicionalmente los colores en las páginas web se han definido mediante nombres de colores o códigos RGB, pero los navegadores actuales permiten usar códigos HWB que son más intuitivos que los códigos RGB. En esta lección se explica cómo se expresan los colores mediante códigos HWB.

  3. Haced los ejercicios 1 a 5 de Bucle for (1).

    En estos primeros ejercicios, es fácil identificar el papel de los bucles porque la página contiene elementos html repetidos que son precisamente los que tienen que generar los bucles.

    Podéis consultar unas posibles soluciones de estos ejercicios. También podéis descargar unas posibles soluciones completas de estos ejercicios.

  4. Leed la lección Testigos, contadores y acumuladores.
  5. Haced los ejercicios 11 a 15 de Bucle for (1).

    Estos ejercicios son un poco más difíciles porque el papel de los bucles es también el cálculo de contadores y acumuladores, lo que no es tan obvio como la generación de elementos html repetidos.

    Podéis consultar unas posibles soluciones de estos ejercicios. También podéis descargar unas posibles soluciones completas de estos ejercicios.

  6. [optativo] Haced los ejercicios Bucle for (2).

    Se trata de unos ejercicios sencillos desde el punto de vista de los bucles, pero en los que es necesario escribir fórmulas que relacionen la variable de control de los bucles con elementos de la página.

    Podéis consultar unas posibles soluciones de estos ejercicios. También podéis descargar unas posibles soluciones completas de estos ejercicios.

IAW Semana S06: del 14/10/24 al 20/10/24

Matrices

  1. Leed la lección Matrices.

    Las matrices son un tipo de variable muy flexible que utilizaremos mucho a partir de ahora. En los ejercicios de esta semana, los índices de las matrices son numéricos y correlativos. En las próximas semanas trabajaremos con matrices asociativas, es decir, de índices no numéricos o no correlativos.

  2. Haced los ejercicios del primer apartado ("Sin bucles") de Matrices (1).

    En estos ejercicios no hace falta utilizar bucles ni if ... else ..., pero sí que hay que definir una o varias matrices.

    Podéis consultar unas posibles soluciones de estos ejercicios. También podéis descargar unas posibles soluciones completas de estos ejercicios.

Estructuras de control: Bucle foreach

  1. Leed las lecciones Resumen bucle foreach y Bucle foreach

    Los bucles foreach permiten recorrer estructuras (matrices, recursos, etc) sin preocuparse por el número de elementos, lo que los hace muy útiles cuando se deben recorrer estructuras no generadas por el propio programa, como información proveniente de formularios o consultas a bases de datos.

  2. Haced los ejercicios del segundo apartado ("Con bucles") de Matrices (1).

    En estos ejercicios se deben utilizar bucles, tanto for como foreach (aunque en varios se podrían utilizar solamente bucles for, por supuesto). La idea es la siguiente:

    • En cada ejercicio hay que crear una o varias matrices para almacenar los datos
    • Para generar las matrices, se deben utilizar bucles for.
    • Para recorrer las matrices creadas (por ejemplo para mostrarlas), se aconseja utilizar bucles foreach. Se podrían utilizar también bucles for, pero los bucles foreach son más sencillos.
    • Para modificar las matrices o para crear nuevas matrices a partir de otras, se suele tener que utilizar bucles for, pero en bastantes casos se pueden utilizar bucles foreach. En caso de que la situación lo permita, se aconseja utilizar bucles foreach.

    Podéis consultar unas posibles soluciones de estos ejercicios. También podéis descargar unas posibles soluciones completas de estos ejercicios.

IAW Semana S07: del 21/10/24 al 27/10/24

Ejercicios: Bucles for con fórmulas

En estos ejercicios se necesita escribir fórmulas para generar series de números que permiten crear dibujos. Mirando el código fuente de los programas de ejemplo se pueden ver los números, pero las fórmulas se os tienen que ocurrir a vosotros. En realidad, es más fácil de lo que parece, porque las series de números forman sucesiones aritméticas por lo que las fórmulas son (casi) siempre del tipo a * x + b, donde a y b son números enteros.

  1. Leed la lección Sucesiones aritméticas (esta lección está en los apuntes Temas de informática).
  2. Practicad la deducción de fórmulas haciendo los ejercicios Sucesiones aritméticas

    Son ejercicios que podéis repetir las veces que queráis. El primero es trivial, pero el segundo exige bastante cálculo mental (aunque podéis empezar haciéndolo con papel y lápiz y calculadora), sobre todo si se elige el mayor nivel de dificultad.

  3. Haced los ejercicios Bucle for (2).

    Podéis consultar unas posibles soluciones de estos ejercicios. También podéis descargar unas posibles soluciones completas de estos ejercicios.

Funciones de matrices

  1. Leed la lección Funciones de matrices.

    Esta lección comenta algunas de las funciones disponibles en PHP para trabajar con matrices. Estas funciones simplifican mucho la manipulación de matrices.

  2. Haced los ejercicios Matrices (3): Funciones.
    • Cada ejercicio ilustra el funcionamiento de una o varias de las funciones de matrices disponibles en PHP.
    • Estos ejercicios se pueden hacer también sin recurrir a las funciones, pero en algunos casos (por ejemplo, cuando se debe ordenar una matriz) el ejercicio sería bastante más difícil.

    Podéis consultar unas posibles soluciones de estos ejercicios. También podéis descargar unas posibles soluciones completas de estos ejercicios.

IAW Semana S08: del 28/10/24 al 03/11/24

[opcional] Ejercicios de examen

Los ejercicios del examen consistirán en la realización de páginas sin formularios. En la página de Exámenes de cursos anteriores de los apuntes, tenéis exámenes de los últimos tres cursos, que podéis hacer como ejercicios y como preparación de cara al examen. Por cierto, en los apuntes no se incluyen soluciones de ejercicios de examen.

Para cada curso (2023/24, 2022/23 y 2021/22), los ejercicios están ordenados por apartados. Los ejercicios Sin Formularios (Juego de cartas, Monedas, etc.) se encuentran en un apartado específico. Los ejercicios no están ordenados por orden de dificultad.

[opcional] Ejercicios de ampliación: Matrices de dos dimensiones

  1. Haced los ejercicios Matrices (2).

    En estos ejercicios aparecen matrices de dos dimensiones. No son ejercicios muy difíciles, pero cuando se trabaja por primera vez con matrices de varias dimensiones, es fácil liarse. Normalmente, os ayudará pensar las matrices de dos dimensiones como tablas de bases de datos, en las que el primer índice indica el registro y el segundo índice indica la columna.

    Podéis consultar unas posibles soluciones de estos ejercicios. También podéis descargar unas posibles soluciones completas de estos ejercicios.

IAW Semana S09: del 04/11/24 al 10/11/24

Funciones

Las funciones permiten aislar fragmentos de código para reutilizar en un programa. Hasta ahora sólo hemos utilizado las funciones que ofrece PHP, pero esta semana veremos cómo podemos crear nuestras propias funciones.

  1. Leed la lección Funciones (1).

    Esta lección trata los aspectos básicos de las funciones: cómo definir funciones (funciones sin argumentos, funciones con argumentos, funciones que devuelven datos, ámbito de las variables, paso de argumentos por valor) y algunos de nivel intermedio (paso de valor por referencia, tipos de los argumentos, tipo de los datos devueltos, nombres de argumentos, número de argumentos indeterminado). Esta lección no aborda aspectos más avanzados (recursividad, variables estáticas o funciones anónimas/de flecha, etc.)

  2. Haced los ejercicios Funciones (1).

    Podéis descargar unas posibles soluciones completas de estos ejercicios.

IAW Semana S10: del 11/11/24 al 17/11/24

Esta semana y la siguiente vamos a ver el uso de formularios en PHP. Lo haremos en dos pasos:

  1. Recogida de datos sin comprobación posterior

    En esta parte se trata de aprender a utilizar formularios y a recoger los datos introducidos en ellos, pero no haremos ninguna comprobación sobre los datos recogidos.

  2. Recogida de datos con comprobación posterior

    En esta parte veremos cómo comprobar los datos recibidos y cómo mostrar mensajes al usuario en caso de que no sean correctos.

Esta semana vamos a hacer programas sin comprobación posterior y la semana siguiente ya haremos la comprobación de los datos. Los ejercicios son fáciles, pero esta semana hay bastante que leer.

Estas son las actividades a realizar durante esta semana.

Formularios (I)

El mecanismo de HTML para recoger información del usuario son los formularios, que nos permitirán crear páginas web interactivas.

  1. Leed la lección Formularios (1) (apuntes HTML/CSS).

    Esta lección forma parte de los apuntes de HTML y trata los aspectos de los formularios relacionados con la presentación del formulario. Comenta las etiquetas y atributos más básicos y que más vamos a utilizar.

  2. Leed la lección Formularios (2) (apuntes HTML/CSS).

    Esta lección completa la lección anterior. Comenta etiquetas y atributos que vamos a utilizar mucho menos, pero que ocasionalmente podéis encontrar en algún ejercicio.

  3. Leed la lección Formularios.

    Esta lección es una presentación de los formularios desde el punto de vista de PHP, es decir, cómo llegan los datos desde un formulario a un programa PHP y qué consideraciones de seguridad tenemos que tener en cuenta.

  4. Leed la lección Controles en formularios.

    Esta lección trata los aspectos de los formularios relacionados con el tratamiento de los datos. Faltan por contar los tipos de controles nuevos en HTML 5, pero su tratamiento no difiere de los controles de HTML 4.

  5. Leed la lección Recogida de datos.

    Esta lección es bastante densa porque aborda los problemas y riesgos de los programas que recogen datos. El problema consiste básicamente en que no podemos saber a priori qué datos van a llegar al programa y probablemente llegarán datos con mala intención. La solución es que los programa no trabajen directamente con $_REQUEST, sino con variables que contengan los datos recibidos una vez "limpiados" y comprobados. Para ello, usaremos una función recoge().

    En resumen, todo lo que se cuenta en esta lección es para justificar el uso de la función recoge() básica que se encuentra en la lección La función recoge().

  6. Leed la lección La función recoge().
  7. Leed los dos primeros apartados (Estructura general y Sin comprobación de datos) de la lección Ejemplo de ejercicio.

    En esta lección se explica cómo realizar los ejercicios con formularios. El ejemplo del apartado recogida de datos sin comprobación os puede servir de guía para la página de ejercicios de esta semana.

  8. Haced los ejercicios Controles en formularios (1).

    Podéis consultar unas posibles soluciones de estos ejercicios. También podéis descargar unas posibles soluciones completas de estos ejercicios.