Descripción: Tutorial paso a paso para aprender ASP .NET MVC 4 en 6 días
Descripción completa
Conceptos Basicos e Visual Basic .NET
Tema 1. INTRODUCCIÓN AL DESARROLLO DE APLICACIONES WEB _______ 1 Tema 2. REQUISITOS DEL ASP.NET (.NET FRAMEWORK) _______________ 11 Tema 3. CONCEPTOS DE LA PROGRAMACIÓN ORIENTADA A OBJETOS ___ 19 Tema 4. CREANDO UNA PÁGINA BÁSICA ____________________________ 31 Tema 5. CONCEPTOS DE WEB FORMS ______________________________ 55 Tema 6. COMPONENTES (DATALIST, DATAGRID) ______________________ 83 Tema 7. DIRECTIVAS DE PÁGINA ___________________________________ 91 Tema 8. CONFIGURACIÓN DE IIS ___________________________________ 99 Tema 9. EL ARCHIVO GLOBAL.ASAX_______________________________ 111 Tema 10. EL ARCHIVO WEB.CONFIG ______________________________ 119 Tema 11. MÓDULOS Y MANEJADORES http_________________________ 129 Tema 12. SEGURIDAD EN ASP.NET ________________________________ 135 GLOSARIO_______________________________________________________ 143
El desarrollo de aplicaciones para el entorno Internet ha cambiado mucho desde su aparición hace algunos años. El mundo de la informática avanza rápidamente, y las necesidades básicas de un sitio Web han cambiado. Al principio, el desarrollo de páginas Web se limitaba prácticamente al uso del lenguaje de marcado HTML (lenguaje de marcado de hipertexto), un HTML sencillo basado en la especificación 3.2, sin capas ni estilos, con lo que se obtenían páginas estáticas cuya labor únicamente era suministrar información personal del autor o de la empresa (de forma textual o a través de imágenes), pero, sin proporcionar ninguna interacción con el usuario. Actualmente, un sitio Web suele soportar la recogida de datos a través de formularios, inclusiones de archivos (subir ficheros al servidor, como imágenes o documentos), envío de correos electrónicos, acceso a bases de datos, redireccionamiento de acuerdo al perfil del usuario, etc. En definitiva, hoy día, las aplicaciones Web se diseñan con el propósito de suministrar al usuario una serie de servicios más complejos. Como ejemplo podemos citar una plataforma de teleformación que soporte matriculación de alumnos, subida de cursos, exámenes, almacenamiento de notas, estadísticas de tiempos sobre conexiones al centro virtual, visitas por curso y alumno, etc. Cada vez que el alumno entra en la plataforma y se loga (introduce su nombre de usuario y contraseña), se le presenta una página personalizada (con acceso a cada uno de los cursos en que está matriculado), y cada vez que el alumno realiza un ejercicio o examen, el sistema puede comprobar los resultados introducidos y otorgarle una nota, que almacena para él en una base de datos, y del que va formando un expediente. Estos son ejemplos de páginas dinámicas, cuyo aspecto final va a depender de las acciones del usuario, de la forma de interactuar que tenga con la aplicación (en cuántos cursos se ha matriculado, si ha aprobado o suspendido un examen, los temas o respuestas que ha dado en los foros de su curso, etc.). Entre las aplicaciones típicas desarrolladas en la actualidad, se encuentran los portales, las tiendas o comercios virtuales, B2C (Business-To-Consumer, proveedor y cliente), aplicaciones publicitarias, de venta (de billetes de avión, subastas), de ocio (portales de juegos) ... Estos desarrollos se caracterizan por el alto número de usuarios que tienen que soportar y por la calidad de la interfaz de usuario, el diseño y el sistema de navegación presentados.
-3-
Ejemplo de aplicación Web actual: Plataforma de Teleformación
Los desarrollos Internet se implementan sobre los protocolos y lenguajes de Internet. A su vez, estos protocolos son estándares que implementan una serie de mecanismos básicos para permitir el paso de información entre los equipos clientes de los usuarios (que contienen los navegadores de Internet) y los equipos servidores (que contienen la aplicación), y son principalmente, TCP/IP (Protocolo de Control de Transmisión / Protocolo de Internet y HTTP (Protocolo de Transmisión de Hipertexto). A mayor complejidad de aplicaciones, mayor complejidad y potencia de herramientas y nuevas tecnologías usadas en su programación. A continuación, vamos a ver una serie de tecnologías de desarrollo Web utilizadas en la actualidad:
-4-
1.1. ASP 3 Es la versión previa a la tecnología ASP.NET, y por tanto, también la solución inicial de Microsoft a la programación Web. Sus siglas se correponden con Active Server Pages en su versión 3 (Páginas Activas de Servidor), y funcionaban bajo las versiones del servidor Web de Microsoft, IIS (Internet Information Server, Servidor de Información de Internet) en sus versiones 3, 4 y 5. Este sistema se basaba en la ejecución de una serie de lenguajes de script (principalmente, VBScript y Jscript) embebidos en páginas HTML. La extensión de estas páginas es .asp (son las comúnmente llamadas páginas ASP, y que aún hoy siguen utilizándose en la programación de multitud de sitios Web). Su proceso de desarrollo es relativamente rápido, está integrado con el modelo COM (Modelo de Objetos Componentes) de Windows y se encuentra muy extendido (ha sido uno de los más utilizados en los últimos tiempos). Sin embargo, su modelo de desarrollo es más bien funcional, y no totalmente orientado a objetos.
En esta dirección puede encontrarse abundante documentación sobre ASP
-5-
A partir de la versión 5 de su servidor Web, IIS, Microsoft da soporte a su nueva solución de programación Web, ASP.NET, (aunque existe compatibilidad con el código ASP anterior). ASP.NET mejora en los lenguajes y herramientas de desarrollo, asume el modelo de programación orientada a objetos, mejora el rendimiento general del sistema, etc. (a lo largo del manual veremos las técnicas más comunes utilizadas con esta tecnología).
Uno de los sitios Web más populares dedicados a ASP.NET
1.2. JAVA (JSP, SERVLETS) Es la solución de SUN Microsystems para el desarrollo de aplicaciones Web. Consta de un conjunto de librerías y API (Interfaz de Programación de Aplicaciones) de desarrollo, que incluye un conjunto de objetos de servidor o Servlets, y un sistema de programación de páginas con un modelo similar al de ASP (introduciendo código java embebido en páginas HTML), páginas JSP (Java Server Pages, Páginas de Servidor Java).
-6-
Este modelo de Servlets y páginas JSP, al estar directamente basado en Java, presenta todas las ventajas de este lenguaje, como la orientación a objetos, disponibilidad de todas las librerías adicionales de Java (generación de imágenes, comunicaciones, seguridad, encriptación, etc). Podríamos decir que esta solución es más potente y completa para desarrollar aplicaciones Web que la solución de páginas ASP.
Sitio Web de SUN Microsystems dedicado a Java Java continúa siendo la gran alternativa al desarrollo de aplicaciones Web con tecnología Microsoft (ASP, ASP.NET). 1.3. PHP PHP corresponde a las iniciales de Personal Home Page, Procesador de Hipertexto. Este lenguaje de programación tiene una sintaxis similar a los lenguajes C y Perl, se interpreta por un servidor Web Apache bajo sistemas Unix/Linux (también han salido al mercado versiones para sistemas Windows, aunque no siempre podremos utilizar todas sus características bajo este sistema operativo). -7-
Presenta una técnica similar a las páginas ASP de Microsoft, es decir, las páginas HTML incluyen el código PHP embebido en ellas, y al ejecutarlas, se genera código HTML dinámicamente. Por otro lado, es preciso mencionar que soporta clases, pero no está orientado a objetos, aunque dispone de una gran número de librerías de funciones para realizar operaciones avanzadas como acceso a bases de datos, correo electrónico, transferencia de ficheros, comunicaciones, etc. Las páginas PHP también se han extendido mucho en los últimos años (son las páginas Web que vemos con extensión .php o .phtml), aunque parece ser que se tiende a utilizar las soluciones de Java y ASP.NET en las nuevas aplicaciones.
En esta dirección podemos encontrar toda documentación necesaria sobre PHP, como manuales, la referencia del lenguaje, entornos, etc. y además en varios idiomas.
-8-
1.4. DHTML Sus siglas significan Dinamic HTML (HTML dinámico). Se forma de una conjunción de HTML, hojas de estilo en cascada (CSS) y lenguajes de script como JavaScript o VBScript. Estos lenguajes de script se ejecutan en la máquina cliente (en el navegador del usuario que solicita una página). De hecho, ésta es una gran diferencia con el resto de las anteriores tecnologías que hemos visto en los apartados anteriores. Normalmente, un desarrollador Web, utilizará alguna de las tecnologías anteriores, basadas en servidor, que implementa la lógica principal y fundamental de la aplicación, en conjunción con el HTML dinámico, ya que gracias a éste, podemos conseguir efectos muy vistosos en nuestras páginas, como formateo más completo al HTML, alternancia de imágenes, capas (contenido de la página cuya posición y tamaño puede cambiar), con lo que obtenemos desplazamiento de imágenes, banners, cambios de visibilidad en los elementos de la página (partes de la página que aparecen o desaparecen en función de los eventos o acciones del usuario), validaciones de entradas del usuario antes de enviar los datos al servidor, etc.
En esta dirección podemos encontrar una referencia muy completa del lenguaje JavaScript
-9-
RECUERDE
-
El desarrollo de aplicaciones Web ha evolucionado rápidamente en los últimos años. Las páginas estáticas que usaban únicamente el lenguaje HTML 3.2, han pasado a sitios Web interactivos que ofrecen multitud de servicios a los usuarios.
-
Actualmente se utilizan tecnologías como DHTML (HTML, CSS y lenguajes de script, como VBScript o JavaScript, que se ejecutan en el cliente), y ASP 3, PHP, JSP y Servlets, y ASP.NET (tecnologías que se ejecutan en el servidor).
- 10 -
Tema 2
REQUISITOS DEL ASP.NET
(.NET FRAMEWORK)
2.1. MICROSOFT .NET FRAMEWORK _________________________ 14 2.2. CLS ________________________________________________ 16 2.3. CTS ________________________________________________ 16 2.4. IL (MSIL) ____________________________________________ 17
- 11 -
En este capítulo vamos a comentar los programas necesarios para poder desarrollar aplicaciones ASP.NET: -
Sistema operativo Windows 2000 Server/Professional. (ASP.NET no es soportado por Windows NT ni por Windows 9x).
-
El Servidor Web Internet Information Server 5.0 (IIS 5.0). (Viene incluido como parte del sistema operativo Windows 2000, debemos dejarlo incluido como parte de la instalación del sistema operativo).
-
Microsoft .NET Framework SDK (Software Development Kit): es la implementación de la plataforma .NET sobre la que se ejecutarán las páginas ASP.NET. Es decir, el .NET Framework SDK contiene todas las clases que componen la plataforma .NET. Para poder instalarlo necesitamos tener instalado, al menos, el navegador Internet Explorer 6.0 y el Service Pack 2 de Windows 2000. Su distribución es gratuita y podemos descargárnoslo del sitio Web de desarrolladores de Microsoft en http://msdn.microsoft.com. Además, en esta dirección podemos encontrar abundante documentación sobre el tema.
También es recomendable, aunque no obligatorio, disponer de la aplicación Visual Studio .NET, que es un entorno de desarrollo para la plataforma .NET. Este entorno integrado ofrece una serie de ayudas visuales y utilidades muy interesantes, además de valiosa documentación que nos ayudarán en el desarrollo, prueba y depuración de nuestras aplicaciones ASP.NET. Además, las distribuciones de la aplicación de Visual Studio .NET, suelen incluir el paquete Microsoft .NET Framework SDK, como parte opcional de la instalación, por si el equipo donde va a ser instalado el Visual Studio .NET, no lo tiene todavía. También podemos conseguir una versión de evaluación de Visual Studio .NET en el sitio Web de MSDN (http://msdn.microsoft.com/vstudio/productinfo/trial.asp). Este entorno es muy recomendable, pero no imprescindible para escribir nuestras aplicaciones ASP.NET. De hecho, también puede usarse cualquier otro editor de texto común, como el bloc de notas de Windows, o la aplicación EditPlus, aunque éstos no proporcionan las utilidades del entorno Visual Studio. NET.
- 13 -
En el sitio Web de Microsoft podemos descargarnos gratuitamente el paquete .NET Framework
2.1. MICROSOFT .NET FRAMEWORK ASP.NET se engloba dentro de la tecnología denominada Microsoft .NET, que, aparte de la tecnología Web, nos ofrece toda una gama de tecnologías para el desarrollo y explotación de aplicaciones. Es decir, ASP.NET es un subconjunto de la tecnología .NET de Microsoft, la parte relativa a la programación Web. Pero, el paquete .NET también incluye las clases necesarias para soportar las aplicaciones tradicionales de Windows, las denominadas aplicaciones Windows Forms (generación de formularios, con características avanzadas), y también las aplicaciones que son servicios del sistema, que no requieren interfaz del usuario. Así, por ejemplo, con el paquete .NET, también es posible la creación de servicios para Windows 2000. .NET Framework permite el desarrollo de aplicaciones a través del uso de un conjunto de herramientas y servicios que proporciona, y que podemos agrupar en tres bloques principales:
- 14 -
-
El Entorno de Ejecución Común o Common Language Runtime (CLR). Es el núcleo de .NET Framework, se encarga de la gestión del código, su ejecución, los temas de manipulación de memoria, etc.
-
La jerarquía de clases básicas de la plataforma o .NET Framework Base Classes. Constituyen un API de servicios para usar en la programación de nuestras aplicaciones, por ejemplo, las clases para acceder a bases de datos (ADO.NET), para gestionar ficheros XML, gestión de hilos (threading), etc.
-
El motor de generación de interfaz de usuario, que permite crear interfaces para la web (con la tecnología ASP.NET) o para el tradicional entorno Windows (Windows Forms).
Podemos ver esta estructura de una forma más representativa a través del siguiente esquema de componentes de la plataforma .NET Framework:
ASP.NET
Windows Forms
.NET Framework Basse Classes (clases básicas de la plataforma) ADO.NET
XML
THREADING
Etc.
CLR, Common Language Runtime (Entorno común de ejecución de lenguajes) CTS
CLS
MSIL
Gestión de memoria
En este manual vamos a centrarnos en la parte de ASP.NET, que, como hemos dicho, constituye la solución de Microsoft para desarrollar aplicaciones Web, aunque su base sobre la que se apoya, el paquete .NET, es común para desarrollar otro tipo de aplicaciones para Windows.
- 15 -
A continuación, vamos a ver una serie de términos relacionados con el CLR del .NET, que le dan la funcionalidad para permitir ser un entorno común de ejecución de lenguajes:
2.2. CLS Como vemos, el CLR es la base del sistema Microsoft .NET. Este motor hace que sea posible el desarrollo basado en múltiples lenguajes, y que sea posible la integración y ejecución de todos ellos en el entorno .NET. Esto se realiza gracias al seguimiento de las especificaciones del CLR por parte de los creadores de lenguajes y herramientas de desarrollo. Esta Especificación Común de Lenguajes se conoce como CLS (Common Language Specification), y consiste en un conjunto de características comunes que deben cumplir todos los lenguajes de la plataforma, para poder integrarse entre sí. Esta integración se refiere a que, por ejemplo, es posible escribir una clase en C#, y heredar de dicha clase desde VB.NET. Esto se produce gracias a que el entorno de ejecución es común, y el código compilado no pasa directamente a código ejecutable puro, sino a un código intermedio (como veremos en el apartado de IL). Por ello, podemos decir que la plataforma .NET tiene soporte multi-lenguaje. Actualmente, están soportados los lenguajes VB.NET, C#, C++ y Jscript.NET.
2.3. CTS Estas siglas corresponden a Common Type System, Sistema Común de Tipos. Es el mecanismo del CLR que permite definir el modo en que los tipos serán creados y manipulados por el entorno de ejecución de .NET Framework. Así, todos los lenguajes pueden trabajar basándose en una serie de especificaciones de datos que hacen posible el intercambio de información y trabajo con las librerías básicas de la plataforma .NET.
- 16 -
2.4. IL (MSIL) Estas siglas corresponden a Microsoft Intermediate Languaje, Lenguaje Intermedio de Microsoft. Es un lenguaje parecido al bytecode de Java, hacia el cual cualquier compilador integrado con Microsot .NET deberá compilar su código fuente, ya que es el único entendible por el CLR. Este código es independiente de la plataforma y del lenguaje que lo haya originado. La siguiente figura muestra un diagrama con el proceso de generación de lenguaje intermedio a partir del código fuente:
Código fuente (C#, VB.NET,C++,...)
Compilador
Código IL
- 17 -
RECUERDE
-
Para desarrollar aplicaciones ASP.NET necesitamos: el sistema operativo Windows 2000 Server/Professional, el servidor Web Internet Information Server 5.0 y el paquete Microsoft .NET Framework SDK (Software Development Kit) (además del navegador Internet Explorer 6.0 y el Service Pack 2 de Windows 2000).
-
También es recomendable disponer de la aplicación Visual Studio .NET, que es un entorno de desarrollo para la plataforma .NET. Aunque no es imprescindible, nuestras páginas ASP.NET podemos escribirlas en cualquier editor de textos.
-
ASP.NET es un subconjunto de la tecnología .NET de Microsoft, la parte relativa a la programación Web. El paquete .NET también incluye las clases necesarias para soportar las aplicaciones tradicionales de Windows, las denominadas aplicaciones Windows Forms.
-
La plataforma .NET tiene soporte multi-lenguaje. Actualmente, están soportados los lenguajes VB.NET, C#, C++ y Jscript.NET.
- 18 -
Tema 3
CONCEPTOS DE LA PROGRAMACIÓN ORIENTADA A OBJETOS
3.1. OBJETOS ____________________________________________ 21 3.2. ENCAPSULACIÓN ______________________________________ 21 3.2. ABSTRACCIÓN ________________________________________ 22 3.3. MENSAJES ___________________________________________ 23 3.4. CLASES______________________________________________ 23 3.5. HERENCIA____________________________________________ 24 3.6. MÉTODOS ____________________________________________ 26 3.7. POLIMORFISMO _______________________________________ 26 3.8. SOBRECARGA ________________________________________ 26 3.9. MODELO DE OBJETOS__________________________________ 27 3.10. RELACIONES ENTRE CLASES ___________________________ 27 3.11. VENTAJAS DE LA POO_________________________________ 28 3.12. INCONVENIENTES DE LA POO___________________________ 28
- 19 -
En este capítulo vamos a tratar aspectos genéricos de la Programación Orientada a Objetos (POO), necesarios para poder utilizar correctamente el lenguaje en que vamos a programar nuestras páginas ASP.NET, es decir, el lenguaje C#. 3.1. OBJETOS El objeto es el concepto principal sobre el cual se fundamenta la tecnología orientada a objetos. Un objeto puede ser visto como una entidad que posee un conjunto de atributos y que es capaz de realizar una serie de acciones. Esto es lo que define al objeto. También podemos verlo como una representación o modelización de un objeto real perteneciente a nuestro mundo. Por ejemplo, podemos tener un objeto bicicleta que represente a una bicicleta dentro de nuestra realidad, o bien un objeto factura, automóvil o persona. Estos objetos son casos particulares de entidades llamadas clases en donde se definen las características comunes a tales objetos. Veamos el caso particular del objeto automóvil, podemos mencionar como atributos de éste: el modelo, la marca, el color, el número de matrícula, número de bastidor, entre otros. Algunas acciones que es capaz de realizar un automóvil son: frenar, acelerar y cambiar la velocidad. Este objeto automóvil, es una instancia particular de la clase automóvil. Los parámetros o variables que definen el estado de un objeto se denominan atributos o variables miembro, y las acciones que pueden realizar los objetos, se denominan métodos o funciones miembro. Si lo comparamos con la programación estructurada podríamos hacer la siguiente aproximación: los atributos, propiedades o variables miembro serían variables y los métodos o funciones miembro serían procedimientos y funciones. 3.2. ENCAPSULACIÓN Es la técnica de ocultar la implementación interna de un objeto, es decir, cómo está construido y de qué se compone. Los atributos de un objeto deben encontrarse ocultos al resto de los objetos, esto es, no podemos acceder directamente a los atributos de un objeto para modificar su estado o consultarlo. Para acceder a los atributos de un objeto debemos utilizar métodos. Normalmente, un objeto ofrece una parte pública que será utilizada por otros objetos para interactuar entre sí, pero también contiene una parte oculta para encapsular los detalles de implementación del objeto.
- 21 -
Por tanto, podemos ver un objeto como una “caja negra” que tiene un estado determinado que podemos conocer y cambiar mediante una serie de métodos públicos, que representan la interfaz del objeto. Como los atributos y la implementación de cada objeto queda oculta a los demás objetos que interaccionan en el programa, se favorece la protección de los datos y la localización de errores en los programas (ya que cada objeto está altamente especializado, y sólo se encarga de su tarea). Esto consigue una mayor modularidad y facilita el diseño en equipo de programas y la reutilización de clases (componentes), ya que podemos escribir código de manera independiente de cómo se encuentren construidos los diferentes objetos que vamos a utilizar. Ocultando los detalles de implementación, podremos realizar cambios en el código interno de los objetos sin que ello afecte a otros objetos que los utilicen o dependan de ellos. 3.2. ABSTRACCIÓN Es la capacidad de ignorar los aspectos de implementación de los objetos en los pasos iniciales, con lo que sólo necesitamos conocer qué es lo que hace un objeto, y no cómo lo hace, para definir un objeto y establecer las relaciones de éste con otros objetos. Por ejemplo, cuando necesitemos indicarle al objeto automóvil que mencionábamos antes, que acelere, no nos interesa conocer cómo realiza este proceso internamente el objeto (a través de un cambio de marcha, mayor consumo de gasolina, etc.) sino únicamente la forma de indicarle que realice dicho comportamiento. Un objeto lo podemos representar como dos circunferencias, una interna que contiene todos los detalles de implementación (variables y métodos privados), y que permanece oculta al resto de objetos, y otra circunferencia concéntrica externa, que representa lo que el objeto muestra al mundo exterior, la interfaz pública que permite interactuar con él. Dicho de otro modo, no es necesario entender la implementación interna de un objeto para poder utilizarlo.
Métodos Públicos (interfaz del objeto) Atributos y Métodos Privados (encapsulados)
- 22 -
3.3. MENSAJES Son el mecanismo mediante el cual dos objetos pueden interactuar, comunicarse entre sí. Un objeto solitario generalmente no es muy útil. En cambio, casi siempre aparece como un componente de un programa mayor o una aplicación que contiene muchos otros objetos. A través de la interacción de esos objetos, conseguimos una funcionalidad mayor. Los objetos interactúan y se comunican mediante el envío de mensajes. Así, cuando un objeto A quiere que otro objeto B realice una acción (un método de la interfaz de B), el objeto A envía un mensaje al objeto B. Por tanto, un mensaje enviado a un objeto representa la invocación de un determinado método sobre dicho objeto, es decir, la ejecución de una operación sobre el objeto. De esta forma, los dos objetos implicados se comunican, ya que la ejecución de ese método devolverá el estado del objeto invocado o lo modificará (cambiará su estado). Los mensajes a los que un objeto puede responder representan el comportamiento, las acciones que dicho objeto puede realizar. En nuestro ejemplo, el objeto coche es capaz de realizar la acción de cambiar de marchar, pero necesita de otro objeto (por ejemplo, un objeto persona) que interactúe con él, que le indique la acción a realizar (también podrá frenar, acelerar, etc.), y además necesitará recibir la marcha a la que deseamos cambiar. Por tanto, para enviar un mensaje necesitamos: -
El objeto al que vamos a enviar el mensaje, en nuestro ejemplo, el objeto automóvil,
-
El nombre del método (acción o comportamiento que queremos que realice), cambiar de marcha en nuestro automóvil, etc.
-
Los parámetros necesarios para el método en cuestión, la marcha a la que deseamos cambiar.
3.4. CLASES Una clase es una plantilla, molde o prototipo en el que se definen los atributos (variables) y las acciones (métodos) comunes para todos los objetos de un tipo determinado. Mediante las clases podremos crear (instanciar) objetos de un mismo tipo, estos objetos se distinguirán unos de otros a través de su estado, es decir, el valor de sus atributos.
- 23 -
Siguiendo con el mismo ejemplo, nuestro coche es una instancia de la clase de objetos denominada Coches. Esta clase tiene algunos estados (marcha actual, número de marchas, color, potencia...) y comportamiento (frenar, girar, encender luces...) en común. Sin embargo, el estado de cada objeto coche es independiente y puede ser diferente al del resto de objetos coche. La especificación común para todos los objetos del mismo tipo es lo que denominamos clase. Dicho de otro modo, la clase la vamos a utilizar para definir la estructura de un objeto, es decir, estado (atributos) y comportamiento (métodos). Una vez implementada una clase podremos instanciar (crear) objetos que pertenezcan a esa clase. Utilizaremos la misma clase para crear distintos objetos. 3.5. HERENCIA Es el mecanismo mediante el cual podemos reutilizar clases ya definidas. Una vez definida una clase, podemos usarla como base para complicarla o especializarla. Es decir, los métodos y atributos de una clase pueden transmitirse a las clases que descienden de ella. La clase hija puede añadir atributos, métodos y redefinir los métodos de la clase padre. Por eso, podemos ver la herencia como una sucesiva especialización de las clases. La clase de la que se hereda se denomina clase padre o superclase, y la clase que hereda se denomina clase hija o subclase. A través de este mecanismo de la POO, podemos agregar funcionalidades nuevas a una clase existente, reutilizando todo el código que ya teníamos disponible en la clase padre. Por ejemplo, un turismo y una limusina son distintos tipos de coches. En una aplicación orientada a objetos, el turismo y la limusina podrían ser subclases de la clase coche. El turismo y la limusina comparten los atributos ‘velocidad actual’, ‘marcha actual’, ‘número de plazas’, etc. definidos en la clase Coche. Igualmente, cada subclase también hereda el mismo comportamiento definido en la superclase, por lo que, un turismo y una limusina también pueden realizar las acciones (métodos) definidos en la clase Coche: frenar, cambiar de marcha, girar, etc. Para verificar que la herencia entre dos clases es correcta, debemos hacernos la pregunta “¿es un tipo de ...?”. En nuestro ejemplo tenemos una clase Limusina que hereda de la clase Coche. Esta herencia contesta claramente a esta pregunta: ¿una limusina es también un coche?, cierto. Cada subclase puede definir atributos y métodos propios para ella, que permiten diferenciar a la subclase de su superclase. Por ejemplo, una limusina puede incluir un teléfono incorporado, una nevera o una televisión, características que no tiene un coche normal.
- 24 -
Las subclases también pueden sobrescribir métodos de la superclase para proporcionar un comportamiento
especial.
Por
ejemplo,
la
clase
Coche
puede
contener
un
método
ObtenerNúmeroDeMarchas() que siempre devuelva 5, mientras que un fórmula 1 puede tener hasta 6 marchas, por lo que sobrescribiría este método para devolver 6 en lugar de 5. No hay límite en cuanto al nivel de herencia. Podríamos seguir definiendo nuevas clases que hereden de la clase Turismo, por ejemplo, las clases Monovolumen o Deportivo. Esto da lugar a una jerarquía de clases. La herencia puede ser simple, si la clase hija hereda de una única clase padre, o múltiple, si hereda de varias clases. El lenguaje que usaremos en la programación de las páginas ASP.NET de este manual, C#, soporta herencia simple. También podemos definir clases abstractas, que son clases que definen comportamientos genéricos, y en las que algunos métodos no han sido implementados (son métodos abstractos). El comportamiento de estos métodos es totalmente libre para las subclases que hereden de ésta y que deberán implementar dichos métodos abstractos para poder ser instanciadas.
Ejemplo de jerarquía de clases (herencia simple) Coche
Turismo
Deportivo
Limusina
Monovolumen
- 25 -
3.6. MÉTODOS Como ya hemos comentado anteriormente, los métodos son las acciones que se pueden realizar con los objetos. También podemos considerar un método como la implementación de un mensaje. Dentro de un objeto existen métodos de uso interno, ocultos (privados), y métodos públicos, que constituyen la interfaz del objeto con el resto de objetos con quienes puede interaccionar. Cuando un objeto le envía un mensaje a otro, se produce la llamada o invocación de un método de dicho objeto. Los métodos consultan o modifican el estado de un objeto. Son funciones dentro de un objeto, y como tales, pueden retornar un valor (información sobre el estado del objeto), o realizar una acción sobre el estado del mismo. 3.7. POLIMORFISMO Es otra más de las características propias de la POO. Expresa la posibilidad de que el mismo mensaje, enviado a objetos distintos, ejecute métodos distintos. Por lo tanto, es posible definir operaciones con el mismo nombre dentro de clases distintas. Cada operación tendrá la implementación necesaria y propia para cada clase. Esto nos permite crear un interfaz común para una serie de clases. Por ejemplo, supongamos que tenemos en nuestra aplicación, una clase Enteros para modelar un número entero, y una clase Matrices, para modelar una matriz matemática. Ambas clases necesitarán saber cómo se suman (cómo se suman dos objetos enteros, y cómo se suman dos objetos matrices). Podemos definir un método suma() para la clase Enteros y otro método suma() para la clase Matrices (ambas clases comparten el mismo nombre para esa operación, pero la implementación de estos métodos será distinta en cada clase, ya que no es lo mismo sumar enteros que matrices). 3.8. SOBRECARGA Otra de las técnicas usadas en la POO. Se refiere a la posibilidad de tener en una misma clase, métodos con el mismo nombre, pero que difieren en el tipo de los parámetros que reciben, en el número de ellos, o bien en el tipo y número de parámetros.
- 26 -
Por ejemplo, podemos tener, en la clase Matriz, dos métodos sumar(), uno de ellos recibiría un entero para sumar a la matriz, y el otro método sumar(), podría recibir otro objeto matriz. El primer método implementa la suma matemática entre un entero y una matriz, y el segundo, la suma de matrices. 3.9. MODELO DE OBJETOS Una vez definido e identificado el problema que deseamos solucionar en nuestra aplicación, debemos realizar una representación lógica de los objetos que forman parte del problema en el mundo real, y utilizar en nuestro programa estos objetos computacionales (objetos dentro de nuestro código), y las relaciones existentes entre dichos objetos, para que nuestra aplicación funcione adecuadamente. Para ello, debemos aplicar los principios de la POO que hemos introducido en los apartados anteriores: abstracción, encapsulación, herencia y polimorfismo. 3.10. RELACIONES ENTRE CLASES Cada clase en nuestra aplicación estará especializada en una función o tarea específica, es decir, cada clase tiene su cometido. Para ofrecer una mayor funcionalidad y realizar tareas más complejas es necesario que exista una relación entre distintas clases, una forma de interacción o comunicación entre ellas. Así, una clase puede relacionarse con otra a través de: -
Una relación de composición: cuando una clase está compuesta de otras clases. Esto ocurre cuando los atributos de una clase se implementan como objetos de otra clase. Por ejemplo, la clase Coche tiene atributos como son la clase Puerta, Motor, Rueda, Chasis, etc.
-
Una relación de uso: cuando una clase se relaciona con otra a través de los mensajes que le envía, pasándole una instancia de una clase como parámetro del método invocado por el mensaje. Por ejemplo, al invocar al método suma de una matriz, le pasamos un objeto entero para que lo sume a un objeto matriz.
-
Una relación de herencia: ya la hemos visto en el apartado de la Herencia. Consiste en que una clase hereda de una clase padre o superclase, obteniendo así toda la funcionalidad ofrecida por la clase padre y pudiendo añadir nuevas funcionalidades. Con esta forma de relación conseguimos una mayor reutilización del código y una mayor especialización a través de la jerarquía de clases. Las clases iniciales en esta jerarquía son más generales, y a medida que profundizamos en la jerarquía de la descendencia, las clases hijas están más especializadas, implementan tareas más concretas.
- 27 -
3.11. VENTAJAS DE LA POO -
Facilita la reutilización del software, como ya hemos comentado, a través de la herencia. Además, la encapsulación nos facilita el uso de objetos que no hemos implementado todavía, pero de los que conocemos qué hacen.
-
Facilita el mantenimiento de los programas y la detección de errores. La encapsulación nos garantiza que las modificaciones realizadas en el núcleo de un objeto tendrán un efecto limitado y localizado, su interfaz de comunicación con el resto de objetos se mantendrá, por lo que podremos seguir comunicándonos con él de igual forma.
-
Las tareas de análisis, diseño e implementación son más intuitivas, ya que los objetos en nuestros diseños van a representar objetos presentes en el mundo real.
3.12. INCONVENIENTES DE LA POO -
La curva de aprendizaje suele ser más larga que la necesaria en la programación estructurada, debido principalmente a que implica un cambio de mentalidad además de aprender un nuevo lenguaje orientado a objetos.
-
Dificultad en determinar las características de un objeto, porque debemos tener en cuenta las relaciones con otros objetos. A veces, el establecimiento de nuevas relaciones puede implicar un cambio en la definición del objeto.
-
Jerarquías de herencia complejas, que pueden llegar a ser confusas, en el caso de la herencia múltiple (una clase puede heredar de más de una clase). C#, el lenguaje que usaremos en nuestras páginas ASP.NET, soporta herencia simple (cada clase sólo puede heredar de una única superclase).
- 28 -
RECUERDE
-
Los lenguajes de programación orientados a objetos permiten el encapsulamiento, la abstracción, la herencia y el polimorfismo.
-
El encapsulamiento separa la interfaz de la implementación ocultando los datos dentro del objeto y permitiendo el acceso a los datos de dicho objeto a través de funciones miembro (métodos).
-
Las subclases heredan las funciones miembro y las variables de sus clases padre, haciendo sencilla la reutilización de las funcionalidades de las clases padre.
-
El polimorfismo permite crear código genérico y reutilizable que podrá funcionar con una amplia gama de clases diferentes.
- 29 -
Tema 4
CREANDO UNA PÁGINA BÁSICA
4.1. COMENTANDO EL EJEMPLO_____________________________ 34 4.2. SINTAXIS DE C# _______________________________________ 36 4.3. DECLARACIÓN DE VARIABLES ___________________________ 37 4.4. COMENTARIOS ________________________________________ 37 4.5. SENTENCIAS CONDICIONALES ___________________________ 38 4.5.1. Condicional if .. else______________________________ 38 4.5.2. Condicional múltiple switch ________________________ 38 4.6. BUCLES______________________________________________ 40 4.6.1. Bucle do .. while _________________________________ 40 4.6.2. Bucle while _____________________________________ 40 4.6.3. Bucle for _______________________________________ 41 4.6.4. Bucle foreach .. in ________________________________ 41 4.7. OPERADORES ________________________________________ 42 4.7.1. Operadores aritméticos____________________________ 42 4.7.2. Operadores lógicos_______________________________ 42 4.7.3. Operadores de asignación _________________________ 43 4.7.4. Operadores de comparación________________________ 43 4.7.5. Operador de concatenación ________________________ 43 4.7.6. Otros operadores ________________________________ 43 4.8. MANEJADORES DE EVENTOS ____________________________ 44 4.9. TRATAMIENTO DE ERRORES ____________________________ 44 4.10. DEFINICIÓN DE CLASES________________________________ 46 4.11. INSTANCIACIÓN DE CLASES ____________________________ 47 4.12. MODIFICADORES _____________________________________ 51 4.12.1. Modificadores de acceso__________________________ 51 4.12.2. Otros modificadores _____________________________ 52
- 31 -
En este capítulo vamos a realizar una página ASP.NET que muestra el famoso mensaje “Hola Mundo” cuando pulsemos sobre el botón incluido en la página. Utilizaremos el lenguaje C# a lo largo del manual, por ser un lenguaje de última generación, pensado para los desarrolladores Web, y que se adapta mejor a los estándares de C++ y Java. Por tanto, tras comentar nuestro primer ejemplo, veremos una introducción a la sintaxis de C#. Nuestra primera página ASP.NET: holaMundo.aspx Mi primera página ASP.NET <script language=”C#” runat=”server”> void pulsado (Object origen, EventArgs args) { etiqueta.Style[“font-size”]=”20”; etiqueta.Text=”¡Hola Mundo!”; } Para poder ejecutar esta página ASP.NET, debemos escribir el código anterior en un fichero con extensión .aspx, colocarlo en un directorio de publicación en Internet (que además posea el permiso de ejecución de secuencias de comandos) y ejecutar la página a través del servidor Web (por ejemplo, escribiendo en nuestro navegador http://localhost/holaMundo.aspx).
- 33 -
Al hacerlo, aparecerá una página vacía que presenta únicamente un botón con el texto ‘Púlsame’. Si hacemos click sobre él, se mostrará el mensaje ‘¡Hola Mundo!’.
Editando el código de nuestra primera página ASP.NET en el entorno Visual Studio .Net 4.1. COMENTANDO EL EJEMPLO El fragmento de código que aparece entre las etiquetas <script>, donde se especifica que dicho código está escrito en C# (si hubiésemos utilizado otro lenguaje de los soportados por la plataforma .NET, se indicaría aquí, como por ejemplo, VB.NET), define un método que se ejecutará cuando el usuario pulse el botón que pertenece al Web Form (formulario Web en ASP.NET). Este método trata el evento de pulsación del botón (onclick=”pulsado” en la definición del control ). Este método no devuelve ningún valor (void) y recibe dos parámetros, que ofrecen información acerca del evento que se ha producido (aunque en este ejemplo no usamos dichos parámetros porque no es necesario para mostrar nuestro mensaje). Dentro del método accedemos al estilo de la etiqueta , para darle un tamaño determinado, y a continuación, establecemos el valor de la propiedad Text de la etiqueta con el mensaje “¡Hola Mundo!”.
- 34 -
Podemos observar que, el delimitador de sentencias en C# es el punto y coma (;), y el delimitador de bloques de código, los corchetes ({}). A continuación de la definición del método y del cierre de las etiquetas <script>, nos encontramos con la definición de un Web Form (formulario Web), que será el que va a contener la etiqueta y el botón. Podemos ver que las sintaxis es muy similar a la utilizada para definir un formulario típico HTML, la diferencia está en la inclusión de la propiedad runat que posee el valor server, para indicar que se trata de un formulario de servidor. Dentro del formulario se encuentran dos controles Web que pertenencen a las clases Label y Button (en el capítulo 5 veremos los controles Web con más detalle). El control Label representa a la etiqueta que mostrará el mensaje en la página, y el objeto Button es el botón que invocará el método pulsado( ) cuando el usuario haga click sobre él. Estos dos controles tienen un atributo id, que es el nombre a través del cual podremos acceder a sus propiedades. Así, en el método pulsado utilizamos el identificador “etiqueta” para acceder al objeto Label, y modificar su propiedad Text, que inicialmente no tenía valor. El control Button posee la propiedad onclick, en la que podemos indicar el método responsable de tratar el evento de pulsación. Mediante los Web Forms de ASP.NET, tenemos acceso a todos los controles, ya que forman parte de la página y se comportan como propiedades de la misma.
Resultado de la ejecución de nuestra página holaMundo.aspx en el navegador
- 35 -
4.2. SINTAXIS DE C# El lenguaje C# presenta una serie de palabras básicas reservadas para el propio lenguaje, y que por tanto, no podremos usar en nuestros nombres de clases, variables, propiedades, funciones o métodos. Estas palabras reservadas son: abstract
event
new
struct
as
explicit
null
switch
base
extern
object
this
bool
false
operator
throw
break
finally
out
true
byte
fixed
override
try
case
float
params
typeof
catch
for
private
uint
char
foreach
protected
ulong
checked
goto
public
unchecked
class
if
readonly
unsafe
const
implicit
ref
ushort
continue
in
return
using
decimal
int
sbyte
virtual
default
interface
sealed
volatile
delegate
internal
short
while
do
is
sizeof
double
lock
stackalloc
else
long
static
enum
namespace
string
C# se asimila bastante a lenguajes como C++ o Java. Distingue entre mayúsculas y minúsculas. Por lo tanto, debemos tener cuidado al escribir nuestro código, por ejemplo, si queremos declarar una variable de tipo “long”, debemos escribir “long” y no “Long” o “LONG” (para el compilador del lenguaje estas tres palabras son palabras distintas). Por convención, los nombres de métodos y las clases tienen la primera letra de cada una de sus partes en mayúsculas, así por ejemplo, tenemos la clase DropDownList. Los tipos simples del lenguaje C# se escriben con todas sus letras en minúscula.
- 36 -
Todas las instrucciones en C# acaban con un punto y coma “;”. El separador de bloques de código, como ya hemos mencionado, son los corchetes ({}). 4.3. DECLARACIÓN DE VARIABLES Para declarar una variable (tanto si es una referencia a un objeto o a un tipo simple), primero indicamos el tipo de la variable, es decir, el tipo simple o clase, y a continuación el nombre de la variable. Si la variable posee algún modificador de acceso (como private o public) o de otro tipo, este modificador debe aparecer antes del tipo de la variable. (Veremos los modificadores al final del capítulo). Ejemplo: <script language=”C#” runat=”server”> string cadena; int num_aleatorio; public DateTime fechaActual; 4.4. COMENTARIOS Podemos usar comentarios de línea simple o de un grupo de líneas: // Código comentado de línea simple /* Código comentado que ocupa varias líneas. Siguiente línea de comentario. El código comentado no se ejecutará. */
- 37 -
4.5. SENTENCIAS CONDICIONALES 4.5.1. Condicional if .. else Su sintaxis es la siguiente (la inclusión de la sentencia “else” es opcional, por eso va entre corchetes): if (expresión) { código para expresión “verdadera” } [else { código para expresión “falsa” }] Veamos un ejemplo de su uso: <%@ Page language=”C#” %> <% string color1= “rojo”; string color2= “azul”; if ( color1.Equals(color2) ) { Response.Write (“Los colores son iguales”); }else { Response.Write (“Los colores son distintos”); } %> 4.5.2. Condicional múltiple switch switch (expresión) { case expresión_constante1: código break;
- 38 -
case expresión_constante2: código break; ... [default: código break; ] } Veamos un ejemplo de su uso: <%@ Page language=”C#” %> <% int respuesta = 3; switch (respuesta) { case 1: Response.Write (“Ha elegido la respuesta 1”); break; case 2: Response.Write (“Ha elegido la respuesta 2”); break; case 3: Response.Write (“Ha elegido la respuesta 3”); break; default: Response.Write (“Debe elegir una de estas respuestas: 1, 2, 3”); break; } %>
- 39 -
4.6. BUCLES 4.6.1. Bucle do .. while do { código } while (expresión) Ejemplo de su uso: <% int contador= 7; do { Response.Write (“Quedan “ + contador + ”segundos para el final ”); contador = contador – 1; } while (contador > 0); %>
4.6.2. Bucle while while (expresión) { código } Ejemplo de su uso: <% int contador= 0; while (contador <= 10) { Response.Write ( contador + “ ”); contador++; } %>
- 40 -
4.6.3. Bucle for for (inicialización; expresión; iteradores) { código } Ejemplo de su uso: <% for (int i=0; i<=10; i++) { Response.Write ( i + “ ”); } %> 4.6.4. Bucle foreach .. in foreach (tipo identificador in expresión) { código } Este bucle suele utilizarse para recorrer los elementos de un array o de una colección, y por tanto, la expresión en este bucle será el nombre de un array o colección. Ejemplo de su uso: <% string [] colores = {“rojo”,”azul”,”negro”,”naranja”,”blanco” }; foreach (string color in colores) { Response.Write ( color + “ ”); } %>
- 41 -
4.7. OPERADORES En este apartado veremos los principales operadores del lenguaje C#, algunos de los cuales ya hemos usado en los ejemplos anteriores para formar sentencias o expresiones condicionales.
4.7.1. Operadores aritméticos + Suma. -
Resta.
*
Multiplicación.
/
División.
% Módulo (resto de la división). ++ Operador de incremento. --
Operador de decremento.
4.7.2. Operadores lógicos
&
Devuelve true si las dos expresiones son verdaderas.
|
Devuelve true si una de las dos expresiones es verdadera.
^
Devuelve true si sólo una de las expresiones es verdadera.
¡
Cambia una expresión de verdadera a falsa y viceversa.
&&
Similar a &, pero en el caso de que no se cumpla alguna expresión, el resto de las
comparaciones (tomándolas de izquierda a derecha) no se evaluarán y devolverá false. | |
Similar a |, pero en el caso de que se cumpla alguna expresión, el resto de las
comparaciones (tomándolas de izquierda a derecha) no se evaluarán y devolverá true. true Literal y operador que devuelve el valor booleano de “verdadero”. false Literal y operador que devuelve el valor booleano de “falso”.
- 42 -
4.7.3. Operadores de asignación =
Operador básico de asignación.
^= Operador de potencia. *=
Operador de multiplicación.
/=
Operador de división.
+= Operador de suma. -=
Operador de resta.
&=
Operador de concatenación de cadenas.
%=
Operador de módulo.
4.7.4. Operadores de comparación == Igual que. ¡= Distinto que. >
Mayor que.
<
Menor que.
>= Mayor o igual que. <= Menor o igual que.
4.7.5. Operador de concatenación Este operador sirve para unir dos cadenas de texto (tipo string) en una sola, y es el operador “más” (+). 4.7.6. Otros operadores
.
Acceso a miembros de objetos (propiedades y métodos).
[]
Operador de índice, para acceder a los distintos elementos de un array.
?:
Realiza una operación condicional en una sola línea. Su formato es: expresion? Caso-si-verdadero : caso-si-falso
is
Para ver si un objeto es de un determinado tipo (o es compatible con dicho tipo
debido a la herencia). sizeof Devuelve el tamaño en bytes de un tipo de datos. typeof Devuelve el tipo de un objeto.
- 43 -
4.8. MANEJADORES DE EVENTOS Estos son métodos especiales que se encargan del tratamiento de eventos en el cliente (por ejemplo, pulsar un botón o cambiar la opción de un desplegable), pero que ejecutarán código de servidor. Estos métodos para el tratamiento de eventos poseen parámetros (recordemos el método “pulsado” de nuestra primera página ASP.NET, que mostraba el mensaje “Hola mundo” al hacer click sobre el botón “púlsame”, al comienzo de este capítulo). El primero de estos parámetros es el control que generó el evento (en dicho ejemplo, el botón “púlsame”), y el segundo parámetro serán los argumentos adicionales que necesite el método, y que normalmente dependerán del tipo de evento a tratar. La sintaxis general de un método para el tratamiento de eventos es la siguiente: void NombreMétodo (Object origen, EventArgs argumentos) { código de tratamiento del evento } Veremos con más detalle este tipo de métodos en el capítulo siguiente, en el que trataremos los Web Forms y los controles de ASP.NET. 4.9. TRATAMIENTO DE ERRORES C# dispone de una serie de sentencias y mecanismos orientados a capturar los errores o situaciones anómalas que puedan ocurrir dentro de nuestros programas, para poder tratarlos de forma adecuada. Este tratamiento se conoce como gestión estructurada de excepciones, que manejamos con las siguientes palabras reservadas: -
try: Con esta palabra clave definimos la zona de nuestro código que va a ser inspeccionada y tratada bajo la gestión estructurada de excepciones.
-
catch: Con esta palabra clave definimos el código que debe ejecutarse cuando se produce la excepción o situación anómala. Podemos tener múltiples catch para un solo try, se
- 44 -
ejecutará aquel catch que tenga el tipo de excepción u error que se haya producido en la zona del try para esa ejecución. -
finally: Esta palabra clave define el código que se ejecutará siempre después de ejecutar un código dentro de una sentencia try, es decir, el código que pongamos en este bloque, se ejecutará siempre, independientemente de si se ha producido o no una excepción.
-
throw: Esta sentencia se utiliza para “lanzar” una excepción, debe ir seguida de un objeto que representa la excepción que se ha producido (debe ser un objeto que hereda de la clase System.Exception). Lanzar la excepción significa que dicho error puede propagarse y ser tratado en otro punto de la secuencia de llamadas a métodos.
La sintaxis de un bloque try-catch-finally es la siguiente: try { código a inspeccionar } catch (tipo de excepción variable) { tratamiento de esta excepción } catch (tipo de excepción variable) { tratamiento de esta excepción } [ ... ] finally { código que siempre se ejecutará, se produzca o no una excepción en el bloque try } Veamos un ejemplo. En el siguiente código se intenta realizar una operación matemática de división de un número por cero, lo que dentro del entorno de ejecución causará una excepción del tipo “System.DivideByZeroException”, que deriva directamente de la clase “System.Exception”, y que nos encargaremos de capturar de forma adecuada mediante una sentencia “catch” para presentar al usuario un mensaje de error controlado. <%@ Page language=”C#” %>
- 45 -
<% int numero1 = 50; int numero2 = 0; int resultado; try { resultado = numero1 / numero2; }catch ( System.DivideByZeroException error ) { Response.Write (“Se ha producido un error. No se puede dividir por cero. Excepcion: ” + error.Message); } %> 4.10. DEFINICIÓN DE CLASES La sintaxis general para declarar una clase en C# es: using Namespace; namespace NombreDeEspacio { modificadores class NombreDeClase : ClasePadre { implementación de la clase } } Incluiremos una sentencia using por cada uno de los espacios con nombre (NameSpace) que necesitemos. Un namespace es una forma de clasificar y organizar clases, para evitar conflictos de nombres (podemos tener clases con igual nombre en distintos namespaces). Cada namespace contiene un conjunto de clases relacionadas (como una librería). Podemos definir nuestra clase dentro de un Namespace, para ello utilizaremos la palabra clave namespace seguida del nombre que le damos a nuestro espacio con nombre.
- 46 -
Entre las llaves del Namespace incluimos la declaración de la clase. En esta declaración aparecen los modificadores de la clase (veremos lo modificadores en el siguiente apartado, sirven para definir las características de nuestra clase), la palabra reservada class y el nombre que hemos elegido para la clase que estamos definiendo. Si nuestra clase hereda de una clase padre (superclase), lo indicaremos poniendo los dos puntos ( : ) y a continuación, el nombre de la clase de la que heredamos. Después, entre las dos llaves escribimos la implementación de la clase, donde definimos sus propiedades y métodos. 4.11. INSTANCIACIÓN DE CLASES Para crear una nueva instancia de una clase (nuestra o de las proporcionadas por el entorno), utilizamos el operador new. Este operador informa al sistema de que queremos crear un nuevo objeto y asignarlo a un nombre de objeto que elegimos. Cuando se utiliza este operador, el sistema llama automáticamente al constructor de la clase, donde se inicializan las propiedades de la actual instancia (objeto) que estamos creando. Su sintaxis es la siguiente: Clase nombre_objeto = new Clase ( ); El operador new se utiliza para crear nuevos objetos, no para tipos básicos como int, long, bool, char, etc. Para los tipos básicos es suficiente una declaración indicando el tipo de la variable, seguido del nombre dado a la variable, por ejemplo: int numero; string cadena=”Hola mundo”; El CLR de Microsoft .NET cuenta con un recolector de basura que se encarga de liberar automáticamente todos los objetos creados mediante el operador new cuando detecta que el objeto deja de ser utilizado. Veamos un ejemplo de clases. Vamos a utilizar dos archivos distintos. Por un lado, el archivo “vehiculo.cs” que contiene una clase denominada “vehiculo”, dentro del espacio de nombres “aplicacionWeb” y, por otro lado, la página ASP.NET pagina.aspx.
- 47 -
Esta técnica de separación de código es muy utilizada en la plataforma ASP.NET (se denomina CodeBehind, código por detrás o código oculto), consiste en separar la interfaz de usuario de la lógica de la aplicación. La lógica se encuentra en el archivo .cs (la definición de la clase), y la interfaz de usuario (la presentación de la aplicación) en el archivo .aspx. Archivo vehiculo.cs using System; namespace aplicacionWeb { public class vehiculo { private int n_puertas = 0; private string marca = ” ”; public vehiculo (int num_puertas, string nombre_marca) n_puertas = num_puertas; marca = nombre_marca; } public string getMarca( )
{
return marca; } public int getNumeroPuertas( )
{
return n_puertas; } } }
- 48 -
{
Editando el código del archivo vehículo.cs en Visual Studio .NET Archivo pagina.aspx <%@ Page language=”c#” %> <%@ Assembly src=”vehiculo.cs” %> <%@ import namespace=”aplicacionWeb” %> Ejemplo de clases <% vehiculo coche1 = new vehiculo(5,”Renault”); %> La marca del coche es: <% =coche1.getMarca() %> - 49 -
El número de puertas es: <% =coche1.getNumeroPuertas() %>
Editando el código del archivo pagina.aspx en Visual Studio .NET La directiva Assembly indica la localización del código fuente (en el archivo vehiculo.cs), y la directiva import especifica el espacio de nombres utilizado. En este ejemplo, creamos una nueva instancia de la clase “vehiculo” mediante el operador new. Lo inicializamos con 5 puertas y marca Renault (valor para sus propiedades), y una vez que ya tenemos creado nuestro objeto, podemos acceder a sus métodos miembro disponibles (getMarca y getNumeroPuertas).
- 50 -
Resultado de la ejecución de nuestro ejemplo de clases 4.12. MODIFICADORES Los modificadores son palabras clave cuya función es especificar el ámbito o cualidades de nuestras clases, objetos, variables o métodos. 4.12.1. Modificadores de acceso Estos modificadores se encargan de especificar el nivel de accesibilidad de los miembros de las clases (propiedades y métodos). Disponemos de los siguientes: -
public: Informa al entorno de que la propiedad o método es accesible desde cualquier clase o parte del programa. Este modificador otorga el máximo nivel de accesibilidad.
-
private: Con este modificador informamos al sistema de que la propiedad o método únicamente es accesible desde los métodos internos de la misma clase (es decir, sólo podemos acceder a un miembro private desde la propia clase, no desde otras clases, ni siquiera desde las subclases que hereden de la clase que contiene los miembros private).
- 51 -
-
protected: Los miembros protected son accesibles desde la propia clase donde se encuentran, y desde las clases derivadas de ella.
-
internal: Los miembros que llevan este modificador sólo son accesibles desde los archivos del mismo proyecto.
4.12.2. Otros modificadores El lenguaje C# dispone de otra serie de modificadores, aplicables a clases o miembros de clase: -
abstract: Las clases abstractas son aquellas que no tienen la implementación de todos sus métodos, sino que contienen algún método no implementado. Las clases abstractas no pueden ser instanciadas directamente (mediante el operador new), sino que sirven como clase base a otras clases, donde se proporcionará la implementación de esos métodos no implementados.
-
const: Este modificador indica que la propiedad de clase o variable es una constante, es decir, tiene carácter de sólo lectura, y su valor no puede modificarse.
-
extern: Este modificador se aplica a un método, e indica que la implementación de dicho método es realizada de forma externa, mediante la inclusión de alguna librería externa a .NET Framework.
-
readonly: Este modificador marca a una propiedad como de sólo lectura (pero puede inicializarse dentro de un constructor de dicha clase).
-
sealed: Es aplicable exclusivamente a las clases, y significa que la clase no se puede heredar.
-
static: Este modificador indica que la propiedad o método de una clase pertenece al propio tipo o clase, es decir, el elemento static no se crea por cada instancia de la clase. Podemos acceder a los miembros estáticos a través de su clase, sin tener que crear un nuevo objeto de esa clase.
- 52 -
-
virtual: Este modificador marca a un método para que las clases derivadas puedan implementarlo.
-
override: Se utiliza para generar una nueva implementación de una función virtual de una clase. Aparece en las clases derivadas de una clase base (abstracta) para implementar funcionalidad específica a dichas clases derivadas.
- 53 -
RECUERDE
-
C# es uno de los lenguajes más utilizados en la plataforma .NET.
-
Es un lenguaje orientado a objetos, que permite aplicar los mecanismos propios de la POO, como derivación, abstracción o encapsulamiento.
-
Su sintaxis es bastante similar a C++ o Java.
-
Distingue entre mayúsculas y minúsculas.
-
Cuenta con las estructuras típicas (sentencias condicionales, bucles, operadores, modificadores, etc).
-
Permite una gestión estructurada de excepciones, con la que controlar los errores o las situaciones anómalas que puedan ocurrir durante la ejecución de nuestra aplicación.
-
Permite separar la interfaz de usuario de la lógica de la aplicación (técnica Code-Behind).
- 54 -
Tema 5
CONCEPTOS DE WEB FORMS
5.1. LA CLASE PAGE _______________________________________ 57 5.1.1. Eventos de la página _____________________________ 57 5.1.2. Propiedades de la clase Page ______________________ 59 5.1.3. Métodos de la clase Page __________________________ 61 5.2. WEB FORMS __________________________________________ 61 5.3. INTRODUCCIÓN A LOS CONTROLES DE SERVIDOR DE ASP.NET 63 5.4. INTRODUCCIÓN A LOS CONTROLES HTML _________________ 64 5.5. EJEMPLOS CON CONTROLES HTML ______________________ 66 5.6. INTRODUCCIÓN A LOS CONTROLES WEB __________________ 71 5.7. EJEMPLOS CON CONTROLES WEB _______________________ 74
- 55 -
En este capítulo veremos una introducción a los controles Web que pueden utilizarse en un Web Form (formulario ASP.NET). Estos controles los incluiremos en una página ASP.NET, por lo que antes vamos a ver la clase Page, ya que podemos representar a la página ASP.NET actual como un objeto de esta clase. 5.1. LA CLASE PAGE Cada vez que pedimos una página ASP.NET a un servidor Web, es decir, un cliente a través de un navegador Web solicita una URL que indica un fichero .ASPX en el servidor, se crean una serie de componentes que constituyen la página solicitada y que se compilan en una unidad. Estos componentes pueden ser: el fichero .ASPX solicitado, los controles de la página, las clases que contiene el código de la página, etc. Los
distintos
componentes
compilados
dan
lugar
a
un
objeto
de
la
clase
Object.Control.TemplateControl.Page. Esta clase se crea de forma dinámica, y se instanciará cada vez que se realice una petición del fichero .ASPX. Dentro del código de una página siempre vamos a tener acceso a la clase Page, ya que podemos decir que el objeto instancia de esta clase Page, representa a la página ASP.NET actual. Este objeto nos sirve como contenedor de todos los componentes que constituyen la página, y nos permite acceder a sus propiedades, métodos y eventos. A continuación, vamos a comentar los principales eventos, propiedades y métodos que nos ofrece la clase Page: 5.1.1. Eventos de la página ASP.NET nos ofrece una serie de eventos que nos permiten estructurar el código en las páginas. Estos eventos no existían en la versión anterior de ASP. Los eventos se producen en un orden determinado a lo largo de la carga de la página: -
Init: este evento es lanzado cuando la página es inicializada. En ese momento, todavía no se han creado por completo los distintos controles de la página. Este evento es tratado en el método Page_Init.
- 57 -
-
Load: este evento se lanza a continuación del método Init y tiene lugar cuando la página se ha cargado. En este momento, todos los controles de la página ya han sido creados. Este evento se lanzará cada vez que la página es ejecutada. Este evento lo tratamos en el método Page_Load.
-
PreRender: este evento tiene lugar justo antes de enviar la información al cliente. Siempre es lanzado después del evento Load. Lo tratamos en el método Page_PreRender.
-
UnLoad: este evento se lanzará en último lugar, después de haber tenido lugar todos los anteriores. En este momento, la página ha finalizado de procesarse, se ha terminado la ejecución de la página y toda la información ha sido enviada al cliente. Este evento lo tratamos en el método Page_UnLoad
Veamos un sencillo ejemplo de uso de estos métodos: ejemploEventos.aspx Ejemplo de ejecución de los eventos en una página ASP.NET <script language=”C#” runat=”server”> void Page_Init (Object origen, EventArgs args) { Page.Response.Write (“Se ha lanzado el Evento Init ”); } void Page_Load (Object origen, EventArgs args) { Page.Response.Write (“Se ha lanzado el Evento Load ”); } void Page_PreRender (Object origen, EventArgs args) { Page.Response.Write (“Se ha lanzado el Evento PreRender ”); } Al ejecutar este ejemplo veremos una serie de mensajes que ilustran el orden de ejecución de los distintos eventos que tratamos:
5.1.2. Propiedades de la clase Page Para acceder a una propiedad de la clase Page podemos indicar delante de la propiedad la clase Page o utilizar la propiedad directamente, por ejemplo: Page.Response.Write (“Hola Mundo”); es equivalente a: Response.Write (“Hola Mundo”); - 59 -
Las propiedades principales de la clase Page son: -
Application:
esta
propiedad
es
una
referencia
a
un
objeto
de
la
clase
System.Web.HttpApplicationState. Nos permite almacenar y acceder a información compartida y común a toda la aplicación Web. Esta propiedad es equivalente al objeto integrado Application de ASP 3. -
ClientTarget: es un objeto de la clase String, nos permite sobrescribir la detección automática de navegador Web ofrecida por ASP.NET.
-
EnableViewState: propiedad de tipo Boolean, nos permite desactivar el mantenimiento del estado entre distintas llamadas de los controles Web de la página. Por defecto, su valor es true.
-
IsPostBack: propiedad de tipo Boolean, devuelve true si la página actual ya ha sido enviada al servidor en alguna ocasión. Si tiene el valor false significa que es la primera vez que se carga la página. Este indicador nos servirá para inicializar los controles Web y propiedades de la página.
-
Request: esta propiedad es una referencia a un objeto de la clase System.Web.HttpRequest (es equivalente al antiguo objeto integrado Request del ASP 3). Esta propiedad nos permite acceder a toda la información necesaria de la petición del protocolo HTTP que ha sido utilizada para solicitar la página del servidor Web.
-
Response:
esta
propiedad
es
una
referencia
a
un
objeto
de
la
clase
System.Web.HttpResponse (es equivalente al antiguo objeto integrado Response del ASP 3). Esta propiedad nos permite manipular la respuesta devuelta al cliente que ha realizado la petición de la página, es decir, este objeto representa la respuesta HTTP que se envía al cliente. -
Server: este atributo es una referencia a un objeto de la clase System.Web.HttpServerUtility (tiene la misma funcionalidad del antiguo objeto integrado Server del ASP 3). Entre sus principales funcionalidades estaba la creación de componentes existentes en el servidor. En ASP.NET los objetos se crean de distinta manera, importamos el espacio de nombres
- 60 -
necesario (para tener acceso a todas sus clases) y a través del operador new creamos nuevas instancias de objetos. -
Session:
esta
propiedad
es
una
referencia
a
un
objeto
de
la
clase
System.Web.SessionState.HttpSessionState. Nos permite almacenar información entre diferentes páginas incluidas en una misma aplicación ASP.NET para cada usuario. Esta propiedad es equivalente al objeto integrado Session de ASP 3. -
User: esta propiedad devuelve información sobre el usuario que ha solicitado la página ASP.NET.
5.1.3. Métodos de la clase Page Veamos una descripción de algunos de los métodos que nos ofrece la clase Page: -
FindControl: este método realiza una búsqueda en la página del control Web cuyo nombre se pasa como parámetro, y devuelve dicho control (si lo encuentra). El parámetro que recibe es un objeto de la clase String que representa el nombre del control buscado, y el objeto devuelto corresponde a la clase Control. Sobre este objeto debemos aplicar el casting al control Web esperado para poder acceder a sus miembros.
-
MapPath: este método devuelve un objeto de la clase String que representa una ruta virtual construida a partir de la ruta física que se le pasa como parámetro, que también es un objeto de la clase String.
-
ResolveUrl: método que convierte una URL virtual, que le pasamos como parámetro, en una URL absoluta.
5.2. WEB FORMS Los Web Forms (formularios Web) son una característica de ASP.NET que ofrece un nuevo modelo programación (no existía en versiones anteriores de ASP), y nos va a permitir generar contenidos dinámicos de una forma más sencilla.
- 61 -
Los Web Forms sustituyen a los formularios HTML dentro del entorno de programación de ASP.NET. Es un Web Form quien va a generar el código HTML correspondiente al formulario que estamos diseñando. Permiten el tratamiento de los eventos del cliente con código ASP.NET, es decir, con código que será ejecutado en el servidor Web. Este modelo de programación ofrece algunas ventajas con respecto al modelo anterior de ASP: -
Ofrece un modelo de programación más visual (en el entorno Visual Studio .NET podemos usar los distintos controles que nos suministran distintas paletas, y arrastrarlos y soltarlos hasta la vista de diseño). Se ahorra tiempo de desarrollo en crear la interfaz de usuario y además podemos reutilizar estos controles que encapsulan su funcionalidad.
-
El código resultante es más limpio en la página, ya que no aparece mezclado con código HTML como ocurría en las versiones anteriores de ASP (donde lo habitual es mezclar código HTML con código ASP). ASP.NET ofrece una mayor separación entre la lógica de la aplicación y la presentación de la misma.
-
Integra el tratamiento de eventos del cliente con el código correspondiente en el servidor.
-
Lleva a cabo el mantenimiento del estado del formulario de forma automática entre peticiones, esto significa que, si seleccionamos una serie de valores en el Web Form, al enviarlo, de forma automática se van a mantener estos valores en el caso de que se vuelva a recargar el formulario.
Para crear un formulario Web únicamente debemos utilizar una etiqueta Dentro del formulario Web colocaremos los distintos controles de servidor de ASP.NET que necesitemos para recoger la información correspondiente. Estos controles van a realizar las mismas funciones que los típicos controles del lenguaje HTML que constituían los campos de un formulario.
- 62 -
5.3. INTRODUCCIÓN A LOS CONTROLES DE SERVIDOR DE ASP.NET Los controles ASP.NET son una serie de objetos de servidor que generarán el correspondiente código HTML para que el usuario pueda visualizarlos y utilizarlos en la página cargada en su navegador. Estos controles se encargan de manejar los eventos generados por el cliente (como la pulsación de un botón, selección de una opción en un desplegable, etc). Con este nuevo modelo, ya no es necesario utilizar los típicos campos de formulario de HTML que usábamos junto con ASP 3. Cada control de servidor se corresponde con una clase determinada perteneciente a un espacio de nombres determinado. Existe un gran número de controles de servidor y cada uno de ellos pertenece a una clase del paquete .NET Framework. Podemos realizar la siguiente clasificación: -
Controles HTML: representan controles puramente HTML, los que este lenguaje define para su uso en formularios.
-
Controles Web: son otros componentes que ASP.NET trae preconfigurados y que implementan elementos más complejos.
-
Controles de lista: utilizados para distribuir y mostrar datos en una página (son los controles DataList y DataGrid, éstos los veremos en el próximo capítulo).
-
Controles avanzados : cada vez se desarrollan más controles de este tipo, que ofrecen funcionalidades avanzadas, como controles para rotar anuncios en nuestras páginas o para simular un calendario completo.
Cuando utilizamos Visual Studio .NET para diseñar nuestras páginas Web, podemos utilizar dos formas distintas de definir el posicionamiento de nuestros controles: -
GridLayout: permite un posicionamiento dinámico de los elementos, mediante coordenadas X e Y. Se realiza gracias a la integración en los navegadores de las hojas de estilo en cascada y su posicionamiento dinámico de elementos HTML.
-
FlowLayout: este sistema utiliza el método tradicional de HTML de posicionamiento, mediante párrafos y tablas, colocando los elementos de forma secuencial.
- 63 -
5.4. INTRODUCCIÓN A LOS CONTROLES HTML La sintaxis que ofrecen los controles HTML de servidor es muy similar a la sintaxis de los controles clásicos del lenguaje HTML. Estos controles ofrecen la potencia de los Web Forms y mantienen la familiaridad y facilidad de uso de las etiquetas HTML que representan los campos de un formulario. Estos controles tienen el mismo aspecto que una etiqueta HTML, a excepción de que presentan el atributo runat con el valor server. Otra diferencia es que posee un atributo especial para el tratamiento de eventos del cliente con código del servidor. Para realizar el tratamiento de eventos de estos controles con código de servidor, utilizaremos el atributo onserverevento. A este atributo se le indica como valor el nombre del método que queremos ejecutar. Para identificar de forma única un control ASP.NET, debemos utilizar la propiedad id. Mediante este identificador podemos hacer referencia al objeto correspondiente en la página, y así utilizar el código de servidor para acceder a sus métodos o manipular sus propiedades. Cada control del formulario es un objeto (objetos de la página ASP.NET), es decir, una instancia de una clase determinada, y por lo tanto cada uno de ellos poseerá sus propiedades y métodos. Así, la sintaxis general de un control HTML es: Los controles HTML están disponibles para mantener la compatibilidad con versiones anteriores de ASP, de manera que, si queremos que una etiqueta HTML pase a ser un control HTML, simplemente debemos indicar la propiedad runat con el valor server. Normalmente, se utilizan el siguiente tipo de controles, los controles Web (que también veremos en este capítulo). A continuación vamos a ver una descripción de las distintas clases que se corresponden con los controles HTML. Estas clases se encuentran dentro del espacio de nombres System.Web.UI.HtmlControls. Éstas son las clases que ofrecen al desarrollador el acceso en el servidor a las distintas etiquetas HTML que finalmente se enviarán al cliente Web como resultado de la ejecución de la página ASP.NET correspondiente. La lista de los controles HTML que vienen predefinidos en el sistema ASP.NET son los siguientes: