Ir al contenido

Diferencia entre revisiones de «ASP.NET»

De Wikipedia, la enciclopedia libre
Contenido eliminado Contenido añadido
Laop77 (discusión · contribs.)
Función de sugerencias de enlaces: 3 enlaces añadidos.
 
(No se muestran 387 ediciones intermedias de más de 100 usuarios)
Línea 1: Línea 1:
{{Ficha de software
'''ASP.NET''' es un conjunto de tecnologías de desarrollo de aplicaciones web comercializado por [[Microsoft]]. Es usado por programadores para construir sitios web domésticos, aplicaciones web y servicios XML. Forma parte de la plataforma .NET de [[Microsoft]] y es la tecnología sucesora de la tecnología Active Server Pages (ASP).
| nombre = ASP.NET
| logo =
| captura =
| pie =
| autor =
| desarrollador = [[Microsoft]]
| última_versión = 4.5
| fecha_última_versión = 15 de agosto de 2012
| última_versión_prueba = 5.0
| fecha_última_versión_prueba = 12 de octubre de 2015
| lenguaje_programación = [[.NET]]
| sistema_operativo = [[Microsoft Windows]]
| género = [[Framework]]
| licencia = [[EULA]]
| sitio_web = [http://www.asp.net/ http://www.asp.net/]
| idiomas =
| español =
}}


'''ASP.NET''' es un [[entorno para aplicaciones web]] desarrollado y comercializado por [[Microsoft]]. Los programadores o también diseñadores pueden utilizar este framework para construir [[Sitio web|sitios web]] dinámicos, [[Aplicación web|aplicaciones web]] y [[Servicio Web|servicios web]].<ref>{{Cita web|url=https://www.ionos.es/digitalguide/paginas-web/desarrollo-web/que-es-aspnet/|título=¿Qué es ASP.NET?|fechaacceso=2022-03-11|sitioweb=IONOS Digitalguide|idioma=es}}</ref> Apareció en enero de 2002 con la versión 1.0 del [[.NET Framework]], y es la tecnología sucesora de la tecnología [[Active Server Pages]] (ASP). ASP.NET está construido sobre el [[Common Language Runtime]], permitiendo a los programadores escribir código ASP.NET usando cualquier lenguaje admitido por el [[.NET Framework]].
Cualquier persona que este familiarizada con el desarrollo de aplicaciones Web sabrá que el desarrollo Web no es una tarea simple. Ya que mientras que un modelo de programación para aplicaciones de uso común está muy bien establecido y soportado por un gran número de lenguajes, herramientas de desarrollo, la programación Web es una mezcla de varios lenguajes de etiquetas, un gran uso de scripting y plataformas de servidor. Desafortunadamente para el programador de nivel intermedio, el conocimiento y habilidades que se necesitan para desarrollar aplicaciones WEB tienen muy poco en común con las que son necesarias en el desarrollo tradicional de aplicaciones.


== Introduccion ==
== Historia ==
Microsoft introdujo la tecnología llamada Active Server Pages en diciembre de 1996. Es parte de [[Internet Information Services]] ([[IIS]]) desde la versión 3.0 y es una tecnología de páginas activas que permite el uso de diferentes scripts y componentes en conjunto con el tradicional [[HTML]] para mostrar páginas generadas dinámicamente. La definición contextual de Microsoft es que "''Las Active Server Pages son un ambiente de aplicación abierto y gratuito en el que se puede combinar código HTML, scripts y componentes [[ActiveX]] del servidor para crear soluciones dinámicas y poderosas para la web''".
'''Desarrollo de páginas web dinámicas con ASP.NET'''


Después del lanzamiento del Internet Information Services 4.0 en 1997, Microsoft comenzó a investigar las posibilidades para un nuevo modelo de aplicaciones web que pudiera resolver las quejas comunes sobre ASP, especialmente aquellas con respecto a la separación de la presentación y el contenido y ser capaz de escribir código "limpio".<ref name="architecturejournal">{{cita web
Microsoft introdujo esta tecnología llamada Active Server Pages en diciembre de [[1996]], por lo que no es nada nueva. Es parte del Internet Information Server (IIS) desde la versión 3.0 y es una tecnología de páginas activas que permite el uso de diferentes scripts y componentes en conjunto con el tradicional HTML para mostrar páginas generadas dinámicamente. La definición contextual de Microsoft es que "''Las Active Server Pages son un ambiente de aplicación abierto y gratuito en el que se puede combinar código HTML, scripts y componentes ActiveX del servidor para crear soluciones dinámicas y poderosas para el web''".
| url=http://msdn2.microsoft.com/en-us/library/bb266332.aspx
| título=Architecture Journal Profile: Scott Guthrie
| fecha=Enero de 2007
| fechaacceso=20 de abril de 2008
| obra=The Architecture Journal
| editor=[[Microsoft]]
| idioma=inglés
}}</ref> A Mark Anders, un administrador del equipo de IIS y [[Scott Guthrie]], quien se había unido a Microsoft en 1997 después de graduarse de la Universidad Duke, se les dio la tarea de determinar cómo debería ser ese modelo. El diseño inicial fue desarrollado en el curso de dos meses por Anders y Guthrie, y Guthrie codificó los prototipos iniciales durante las celebraciones navideñas de 1997.<ref name="otegem">{{cita web
|url = http://www.vanotegem.nl/PermaLink,guid,d9826145-408c-4fb9-8939-79d7e6a19218.aspx
|título = Interview with Scott Guthrie, creator of ASP.NET
|autor = Michiel van Otegem
|fecha = 24 de julio de 2007
|fechaacceso = 20 de abril de 2008
|idioma = inglés
|urlarchivo = https://web.archive.org/web/20071109084859/http://www.vanotegem.nl/PermaLink%2Cguid%2Cd9826145-408c-4fb9-8939-79d7e6a19218.aspx
|fechaarchivo = 9 de noviembre de 2007
}}</ref>
[[Archivo:MIX Keynote-Scott Guthrie 09 MS 05 2007.jpg|left|thumb|[[Scott Guthrie]] en 2007.]]
El prototipo inicial fue llamado "XSP"; Guthrie explicó en una entrevista en el año 2007 que,
{{cita|"''People would always ask what the X stood for. At the time it really didn't stand for anything. XML started with that; XSLT started with that. Everything cool seemed to start with an X, so that's what we originally named it".<ref name="architecturejournal" />
|col2=
"La gente siempre se preguntaba qué significaba la X. En ese momento, realmente no significaba nada. XML comenzaba así, al igual que XSLT. Todo lo novedoso parecía empezar con una X, así que ese es el motivo por el que originalmente lo llamamos así."''}}


El desarrollo inicial de XSP fue hecho usando [[Lenguaje de programación Java|Java]],<ref name="anderselreg">{{cita web
== '''Definición de ASP.NET''' ==
| url=http://www.regdeveloper.co.uk/2007/10/30/asp_net_java_project_cool/
Microsoft ha desarrollado una nueva tecnología denominada ASP.NET, como parte de la estrategia .NET para el desarrollo Web, con el objetivo de resolver las limitaciones de ASP y posibilitar la creación de software como servicio. ASP.NET es la plataforma unificada de desarrollo Web que proporciona a los desarrolladores los servicios necesarios para crear aplicaciones Web empresariales.
| título=How ASP.NET began in Java
| autor=Tim Anderson
| fecha=30 de octubre de 2007
| fechaacceso=20 de abril de 2008
| editor=The Register
| idioma=inglés
}}</ref> pero pronto se decidió construir una nueva plataforma sobre el [[Common Language Runtime]] (CLR), pues ofrecía un [[Programación orientada a objetos|ambiente orientado a objetos]], [[recolección de basura]] y otras características que fueron vistas como características deseables. Guthrie describió esta decisión como un "alto riesgo", pues el éxito de su nueva plataforma de [[desarrollo web]] estaría atado al éxito del CLR, que, como XSP, aún estaba en etapas tempranas de desarrollo, tanto así que el equipo XSP fue el primer equipo en Microsoft en enfocarse en el CLR.


Con el cambio al Common Language Runtime, XSP fue implementado en [[C Sharp|C#]] (conocido internamente como "Project Cool" pero mantenido en secreto para el público), y fue renombrado a ASP+, en este punto la nueva plataforma fue vista como el sucesor de Active Server Pages, y la intención fue proporcionar un medio fácil de migración para los desarrolladores ASP.<ref name="msdnshow9">{{cita web
== '''Aspectos importantes''' ==
|url = http://msdn.microsoft.com/archive/default.asp?url=/archive/en-us/theshow/Episode009/default.asp
Para tener una idea más clara de lo que implica el desarrollo de las aplicaciones utilizadas y distribuidas por Internet y las características que representan a la plataforma ASP.NET, es importante hacer mención de algunos aspectos con los que cuentan las aplicaciones actuales:
|título = Show #9 - ASP.NET
|fecha = 20 de diciembre de 2000
|fechaacceso = 20 de abril de 2008
|obra = The MSDN Show
|editor = [[Microsoft]]
|idioma = inglés
|urlarchivo = https://web.archive.org/web/20051022113118/http://www.msdn.microsoft.com/archive/default.asp?url=%2Farchive%2Fen-us%2Ftheshow%2FEpisode009%2Fdefault.asp
|fechaarchivo = 22 de octubre de 2005
}}</ref>


La primera demostración pública y la liberación de la primera [[versión beta|beta]] de ASP+ (y el resto del .NET Framework) se realizó en el Microsoft's [[Professional Developers Conference]] (PDC) el 11 de julio de 2000 en [[Orlando (Florida)|Orlando]]. Durante la presentación de [[Bill Gates]], [[Fujitsu]] demostró ASP+ usado en conjunción con [[COBOL]],<ref>{{cita web
|url = http://www.microsoft.com/presspass/exec/billg/speeches/2000/07-12pdc.aspx
|título = Bill Gates speech transcript - Professional Developers Conference 2000
|fecha = 11 de julio de 2000
|fechaacceso = 20 de abril de 2008
|editor = [[Microsoft]]
|urlarchivo = https://web.archive.org/web/20080410001737/http://www.microsoft.com/presspass/exec/billg/speeches/2000/07-12pdc.aspx
|fechaarchivo = 10 de abril de 2008
}}</ref> y el soporte para una variedad de otros lenguajes fue anunciada, incluyendo los nuevos lenguajes de Microsoft, [[Visual Basic .NET]] y C#, así como también el soporte por medio de herramientas de interoperabilidad para [[Python]] y [[Perl]] creadas por la empresa canadiense [[ActiveState]].<ref>{{cita web
|url = http://findarticles.com/p/articles/mi_m0EIN/is_2000_July_11/ai_63287204
|título = ActiveState Supports Microsoft .NET Framework; Perl .NET & Python .NET Cross-Language Interoperability
|fecha = 11 de julio de 2000
|fechaacceso = 20 de abril de 2008
|editor = Business Wire
|idioma = inglés
|urlarchivo = https://archive.today/20120709205010/http://findarticles.com/p/articles/mi_m0EIN/is_2000_July_11/ai_63287204/
|fechaarchivo = 9 de julio de 2012
}}</ref>


Una vez que la marca ".NET" fue seleccionada en la segunda mitad del 2000. se cambió el nombre de ASP+ a ASP.NET. Mark Anders explicó en una aparición en ''The MSDN Show'' en ese año, {{cita|"''The .NET initiative is really about a number of factors, it’s about delivering software as a service, it's about XML and web services and really enhancing the Internet in terms of what it can do .... we really wanted to bring its name more in line with the rest of the platform pieces that make up the .NET framework.''"<ref name="msdnshow9" />|col2="''La iniciativa .NET comprende un número de factores, trata sobre la entrega de software como servicio, sobre XML y servicios web y la mejora real del Internet en términos de qué puede hacer... de verdad queremos llevar su nombre (de ASP+) mas alineado con el resto de las piezas de la plataforma que componen el .NET framework''"}}
'''Aplicaciones cliente/servidor'''
Estas aplicaciones son típicamente en un formato de ejecutables compilados. Estos pueden integrar toda la riqueza de una interfaz de usuario, tal es el caso de las aplicaciones de desempeño y productividad, pero no se reúne la lògica de negocio como un recurso que se pueda reutilizar. Además acostumbran ser menos gestionables y escalables que las demás aplicaciones.


Después de cuatro años de desarrollo, y una serie de versiones de evaluación en los años 2000 y 2001, ASP.NET 1.0 fue liberado el 5 de enero de 2002 como parte de la versión 1.0 del [[.NET Framework]]. Incluso antes de su liberación, docenas de libros habían sido escritos sobre ASP.NET<ref>{{Enlace roto|1={{cita web
'''Aplicaciones que utilizan el navegador'''
|url = http://msdn.microsoft.com/library/shared/deeptree/asp/rightframe.asp?dtcfg=/archive/deeptreeconfig.xml&url=/archive/en-us/theshow/Episode019/default.asp
Dichas aplicaciones están caracterizadas por contar con una interfaz de web rica y muy útil. La interfaz gráfica integra varias tecnologías, las cuales son el HTML, XHTML, scripting, etc; siempre y cuando el navegador que se esté utilizando soporte estas tecnologías.
|título = S! from the PDC
|fecha = 15 de noviembre de 2001
|fechaacceso = 20 de abril de 2008
|obra = The MSDN Show
|editor = [[Microsoft]]
}} |2=http://msdn.microsoft.com/library/shared/deeptree/asp/rightframe.asp?dtcfg=%2Farchive%2Fdeeptreeconfig.xml&url=%2Farchive%2Fen-us%2Ftheshow%2FEpisode019%2Fdefault.asp |bot=InternetArchiveBot }}</ref>


== Características ==
Dado que estas aplicaciones tienen la capacidad de ser compatibles entre navegadores, no se incluyen funcionalidades que pueden estar incorporadas únicamente en un determinado navegador, y se restringe el uso a tecnologías comunes o estandares como es el caso del HTML o el Java.
=== Páginas ===
Las páginas de ASP.NET, conocidas oficialmente como "''web forms''" (formularios web), son el principal medio de construcción para el desarrollo de aplicaciones web.<ref name="macdonald63">{{harv|MacDonald|Szpuszta|2005|p=63}}</ref> Los formularios web están contenidos en archivos con una extensión '''ASPX'''; en jerga de programación, estos archivos típicamente contienen etiquetas [[HTML]] o [[XHTML]] estático, y también etiquetas definiendo ''Controles Web'' que se procesan del lado del servidor y ''Controles de Usuario'' donde los desarrolladores colocan todo el código estático y dinámico requerido por la página web. Adicionalmente, el código dinámico que se ejecuta en el servidor puede ser colocado en una página dentro de un bloque '''<code><nowiki><% -- código dinámico -- %></nowiki></code>''' que es muy similar a otras tecnologías de desarrollo como [[PHP]], [[Java Server Pages|JSP]] y [[Active Server Pages|ASP]], pero esta práctica es, generalmente, desaconsejada excepto para propósitos de enlace de datos pues requiere más llamadas cuando se genera la página.<br /><br />
ASP.NET no sólo funciona sobre el servidor de Microsoft [[IIS]], también lo hace sobre [[Servidor HTTP Apache|Apache]].


==== Formulario web de ejemplo ====
www.joio.com
Este es un ejemplo que utiliza código "en línea", opuesto al código independiente (code-behind).


<syntaxhighlight lang="html">
== '''Limitaciones del ASP''' ==
<%@ Page Language="C#" %>
En el modelo de desarrollo Web basado en páginas activas, la programación ASP actual tiene diversas limitaciones:


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
*Para que todo ocurra en una página Web, es habitual escribir una gran cantidad de código para resolver necesidades sencillas. ASP.NET incorpora un modelo declarativo a la programación Web: los controles de servidor funcionan en una página Web simplemente declarándolos. Cuando se carga la página ASP.NET, se instancian los controles listados en la página ASP y es responsabilidad del control emitir código HTML que el navegador pueda entender.
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">


<script runat="server">
*ASP es un tanto desorganizado. En una página ASP podemos incluir casi todo: [[HTML]] plano, código de scripting, objetos COM y texto. No hay una distinción formal entre el contenido de una página y su comportamiento: simplemente, insertamos código en la página, y a ver qué pasa. ASP.NET impone un cierto orden sobre el modelo de programación estándar ASP.

protected void Page_Load(object sender, EventArgs e)
{
Label1.Text = DateTime.Now.ToLongDateString();
}

</script>

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>Página de Ejemplo</title>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:Label runat="server" id="Label1" />
</div>
</form>

</body>
</html>
</syntaxhighlight>

=== El modelo Code-behind ===
Microsoft recomienda que para realizar programación dinámica se use el modelo '''code-behind''', o de respaldo, que coloca el código en un archivo separado o en una etiqueta de [[Guion (informática)|script]] especialmente diseñada. Los nombres de los archivos ''code-behind'' están basados en el nombre del archivo ASPX tales como ''MiPagina.aspx.cs'' o ''MiPagina.aspx.vb'' (esta práctica se realiza automáticamente en [[Microsoft Visual Studio]] y otros [[Integrated development environment|entornos de desarrollo]]). Cuando se usa este estilo de programación, el desarrollador escribe el código correspondiente a diferentes eventos, como la carga de la página, o el clic en un control, en vez de un recorrido lineal a través del documento.

El modelo ''code-behind'' de ASP.NET marca la separación del ASP clásico y alienta a los desarrolladores a construir aplicaciones con la idea de presentación y contenido separados en mente. En teoría, esto permite a un diseñador web, por ejemplo, enfocarse en la creación del diseño con menos posibilidades de alterar el código de programación mientras lo hace. Esto es similar a la separación en el [[Modelo Vista Controlador]]

==== Ejemplo ====
<syntaxhighlight lang="html">
<%@ Page Language="C#" CodeFile="EjemploCodeBehind.aspx.cs" Inherits="SitioWeb.EjemploCodeBehind"
AutoEventWireup="true" %>
</syntaxhighlight>

La etiqueta superior es colocada al inicio del archivo ASPX. La propiedad ''CodeFile'' de la directiva ''@ Page'' especifica qué archivo (.cs o .vb) contiene el código code-behind mientras que la propiedad ''Inherits'' especifica la clase de la cual deriva la página. En este ejemplo, la directiva ''@ Page'' está incluida en EjemploCodeBehind.aspx y el archivo EjemploCodeBehind.aspx.cs contendrá el código para esta página:

<syntaxhighlight lang="csharp">
using System;

namespace SitioWeb
{
public partial class EjemploCodeBehind: System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{

}
}
}
</syntaxhighlight>

En este caso, el método Page_Load() será llamado cada vez que la página ASPX sea solicitada al servidor. El programador puede implementar manejadores de eventos en varias etapas del proceso de ejecución de la página..

=== Controles de usuario ===
ASP.NET permite la creación de componentes reutilizables a través de la creación de Controles de Usuario (User Controls). Un control de usuario sigue la misma estructura que un formulario web, excepto que los controles derivan de la clase <code>System.Web.UI.UserControl</code>, y son almacenados en archivos '''ASCX'''. Como los archivos ASPX, un ASCX contiene etiquetas HTML o XHTML, además de etiquetas para definir controles web y otros controles de usuario. También pueden usar el modelo code-behind.

Los programadores pueden agregar sus propias propiedades y métodos,<ref>http://msdn2.microsoft.com/en-us/library/ms972975.aspx#usercontrols_topic6 Adding Properties and Methods to a User Control
</ref> y manejadores de eventos.<ref>http://msdn2.microsoft.com/en-us/library/ms972975.aspx#usercontrols_topic9 Creating and Raising a Custom Event</ref> Un mecanismo de eventos en burbuja proporciona la capacidad de pasar un evento disparado por un control de usuario a la página que lo contiene .

=== Administración del estado ===
Las aplicaciones ASP.NET son alojadas en un [[servidor web]] y se tiene acceso a ellas mediante el protocolo sin estado [[HTTP]], que no guarda ninguna información sobre conexiones anteriores. Por lo tanto, si la aplicación requiere interacción entre conexiones, tiene que implementar su propia administración del estado. ASP.NET proporciona varias maneras de administrar el estado de las aplicaciones ASP.NET.

==== Estado de la aplicación ====
El estado de la aplicación (Application state) es una colección de variables definidas por el usuario que son compartidas por todas las invocaciones de una aplicación ASP.NET. Estas son establecidas e inicializadas cuando el evento <code>Application_OnStart</code> se dispara en la carga de la primera instancia de las aplicaciones y están disponible hasta que la última instancia termina. Las variables de estado o variables de sesión de la aplicación son identificadas por nombres.<ref name="state">{{cita web | url = http://support.microsoft.com/kb/307598 | título= INFO: ASP.NET State Management Overview | fechaacceso= 23 de octubre de 2007| idioma = inglés}}</ref>

==== Estado de la sesión ====
El estado de la sesión (Session state) es una colección de variables definidas por el usuario, las cuales persisten durante la sesión de un usuario. Estas variables son únicas para diferentes instancias de una sesión de usuario, y son accedidas usando la colección <code>Session</code>. Las variables de sesión pueden ser preparadas para ser automáticamente destruidas después de un determinado tiempo de inactividad, incluso si la sesión no ha terminado. Del lado del cliente, una sesión de usuario es identificada por una [[Cookie (informática)|cookie]] o codificando el ID de la sesión en la misma URL.<ref name="state" />

ASP.NET proporciona tres modos de persistencia para variables de sesión:<ref name="state" />

;InProc: Las variables de sesión son mantenidas dentro del [[Proceso (informática)|proceso]]. Sin embargo, en este modo, las variables son destruidas cuando el proceso ASP.NET es reciclado o terminado.
;StateServer: En este modo, ASP.NET ejecuta un servicio de Windows separado que mantiene las variables de estado. Como esta administración de estado ocurre fuera del proceso ASP.NET, tiene un impacto negativo en el rendimiento, pero permite a múltiples instancias de ASP.NET compartir el mismo estado del servidor, permitiendo que una aplicación ASP.NET pueda tener su carga balanceada y escalada en múltiples servidores. También, como el servicio de administración del estado se ejecuta independiente de ASP.NET, las variables pueden persistir a través de las finalizaciones del proceso ASP.NET.
;SqlServer: En este modo, las variables de estado son almacenadas en un [[servidor de base de datos]], accesible usando [[SQL]]. Las variables de sesión pueden persistir a través de finalizaciones de procesos también en este modo.

==== Estado de la vista ====
El estado de la vista (View state) se refiere al mecanismo de administración de estado a nivel de página, que es utilizado por las páginas HTML generadas por las aplicaciones ASP.NET para mantener el estado de los controles de los formularios web y los [[widget]]s. El estado de los controles es codificado y mandado al servidor en cada envío del formulario en un campo oculto conocido como <code>__VIEWSTATE</code>. El servidor envía de regreso las variables para que cuando la página sea renderizada de nuevo, los controles volverán a su último estado. Del lado del servidor, la aplicación puede cambiar el estado de la vista, si los resultados del procesamiento actualizan el estado de cualquier control. El estado de los controles individuales son decodificados en el servidor, y están disponibles para su uso en ASP.NET usando la colección <code>ViewState</code>.<ref>{{cita web | url = http://www.extremeexperts.com/Net/Articles/ViewState.aspx | título = ViewState in ASP.NET | fechaacceso = 23 de octubre de 2007 | urlarchivo = https://web.archive.org/web/20071014005507/http://www.extremeexperts.com/Net/Articles/ViewState.aspx | fechaarchivo = 14 de octubre de 2007 }}</ref>
<ref>{{cita web| url = http://www.dotnetrobert.com/dotnet/Home/tabid/37/Default.aspx| título = ASP.Net ViewState Overview| idioma = inglés| urlarchivo = https://web.archive.org/web/20080916082043/http://www.dotnetrobert.com/dotnet/Home/tabid/37/Default.aspx| fechaarchivo = 16 de septiembre de 2008}}</ref>

=== Motor de plantillas ===
Al ser liberado, ASP.NET carecía de un [[motor de plantillas]]. Debido a que [[.NET framework]] es [[orientado a objetos]] y permite [[herencia (programación orientada a objetos)|herencia]], muchos desarrolladores podrían definir una nueva clase que herede desde "System.Web. UI.Page", escribir [[método (programación orientada a objetos)|métodos]] en ella que generen HTML y hacer que las páginas de su aplicación hereden de esta clase. Aunque esto permite que haya elementos comunes dentro de un sitio web, añade complejidad y mezcla [[código fuente]] con [[lenguaje de marcado|lenguaje de etiquetas]]. Además, este método puede visualizarse únicamente al ejecutar la aplicación, no mientras se está diseñando. Otros desarrolladores usan la [[archivos incluidos|inclusión de archivos]] y otros trucos para evitar la implementación de enlaces de navegación y otros elementos en cada página.

ASP.NET 2.0 presentó el concepto de ''página maestra'' (Master Page), que permite el desarrollo de páginas basado en [[plantillas web]]. Una aplicación web puede tener una o más páginas maestras, las cuales pueden ser anidadas.<ref>[http://msdn2.microsoft.com/en-us/library/wtxbf3hh.aspx ASP.NET Master Pages Overview (Microsoft Developer Network)]</ref> Las plantillas maestras contienen controles contenedores, llamados ''ContentPlaceHolders'' para indicar donde irá el contenido dinámico, además de [[HTML]] y [[JavaScript]] que será compartido a través de las páginas hijas.

Las páginas hijas también usan esos controles ContentPlaceHolder, que deben ser relacionados con el ContentPlaceHolder de la página maestra que contiene a esta página hija. El resto de la página está definido por las partes compartidas de la página maestra. Todo el lenguaje de marcado y controles de [[servidor]] en la página de contenido deben ser colocadas dentro del control ContentPlaceHolder.

Cuando una solicitud es hecha por una página de contenido, ASP.NET mezcla la salida de la página de contenido con la salida de la página maestra, y envía el resultado al usuario.

La página maestra permanece completamente accesible a la página del contenido. Esto significa que la página de contenidos puede manipular los encabezados, cambiar el título, configurar la caché, etc. Si la página maestra expone propiedades públicas o métodos, el contenido de la página puede utilizar estos también.

Hoy en día con el nuevo producto de Microsoft WebMatrix, se dio a conocer el nuevo motor de plantillas conocido como Razor. Ya antes el IDE de [[Visual Studio]] incluía otros motores. Facilitando a las páginas ASP.NET [[Modelo Vista Controlador]].

=== Otros archivos ===
Otras extensiones de archivo asociadas con las diferentes versiones de ASP.NET incluyen:

{| class="wikitable"
|-
! Extensión !! Versión requerida !! Descripción
|-
| asax || 1.0 || [[Global.asax]], usada para la lógica a nivel de aplicación<ref>[http://msdn2.microsoft.com/en-us/library/2027ewzw.aspx Global.asax Syntax]</ref>
|-
| ascx || 1.0 || Controles de usuario web: [[Widget|Controles]] personalizados para ser colocados en páginas web
|-
| ashx || 1.0 || Manejadores [[Hypertext Transfer Protocol|HTTP]] personalizados
|-
| asmx || 1.0 || Páginas de [[Servicio web|servicios web]]
|-
| axd || 1.0 || Cuando está habilitado en el [[web.config]] la solicitud de trace.axd genera trazas de salida a nivel de aplicación. También es usado para el manejador especial webresource.axd que permite a los desarrolladores de controles/componentes empacar un control/componente con imágenes, script, CSS, etc. para el desarrollo de un archivo único (un 'ensamblado')
|-
| browser || 2.0 || Archivos de capacidades del navegador almacenadas en formato [[XML]]; introducido en la versión 2.0. ASP.NET incluye muchos de estos por defecto, para admitir a los navegadores web comunes. Estos especifican que navegadores tienen que capacidades, así que ASP.NET 2 puede automáticamente personalizar y optimizar su salida de acuerdo al navegador. Los archivos especiales .browser están disponibles en descarga libre para manejar, por ejemplo, el validador de la W3C. Reemplaza la sección BrowserCaps que se encontraba en el archivo [[machine.config]] en ASP.NET 1.x
|-
| config || 1.0 || [[web.config]] es el único archivo en una aplicación web especifica que usa esta extensión por defecto ([[machine.config]] tiene efectos similares en un servidor web y todas las aplicaciones en el), sin embargo ASP.NET proporciona la facilidad de crear y utilizar otros archivos config. Son almacenados en formato [[XML]]
|-
| cs/vb || 1.0 || Archivos de código fuente (cs indica [[C Sharp|C#]], vb indica [[Visual Basic]]). Los archivos code-behind predominantemente tienen la extensión ".aspx.cs" o ".aspx.vb" para los dos lenguajes más comunes. Otros archivos de código (que frecuentemente contienen bibliotecas de clases) pueden también existir en las carpetas web con las extensiones cs/vb. En ASP.NET 2 estos deberían estar colocados dentro de la carpeta App_Code donde son dinámicamente compilados y están disponibles para toda la aplicación
|-
| dbml || 3.5 || Archivo de clases de datos [[Language Integrated Query|LINQ a SQL]]
|-
| master || 2.0 || Archivo de página maestra
|-
| resx || 1.0 || Archivos de recursos para localización y globalización. Los archivos de recursos pueden ser globales (por ejemplo, mensajes) o locales, que están hechos específicamente para un solo archivo aspx o ascx.
|-
| sitemap || 2.0 || Archivos de configuración sitemap
|-
| skin || 2.0 || Archivos de temas
|-
| svc || 3.0 || Archivos de servicio de [[Windows Communication Foundation]]
|}

=== Estructura de directorios ===
En general, la estructura de directorios de ASP.NET puede ser determinada por las preferencias del desarrollador. Aparte de unos pocos nombres de directorios reservados, el sitio puede expandirse a cualquier número de directorios. La estructura es típicamente reflejada directamente en las [[Localizador Uniforme de Recursos|urls]].

Los nombres de directorios especiales (a partir de ASP.NET 2.0 son):<ref>http://msdn2.microsoft.com/en-us/library/ex526337.aspx ASP.NET Web Site Layout from MSDN</ref>

; App_Browsers: Contiene archivos de definición específicos para navegadores.
; App_Code: Es un directorio para códigos. El servidor ASP.NET automáticamente compilará los archivos (y subdirectorios) en esta carpeta en un ensamblado que es accesible desde cualquier página del sitio. App_Code es típicamente usada para código de acceso a datos, código de modelo o código de negocios. También cualquier manejador http específico para el sitio e implementación de módulos y servicios web van este directorio. Como alternativa a utilizar App_Code el desarrollador puede optar por proporcionar un ensamblado independiente con código precompilado.
; App_Data: Directorio por defecto para las [[base de datos]], tales como archivos mdb de [[Microsoft Access]] y archivos mdf de [[Microsoft SQL Server]]. Este directorio es usualmente el único con permisos de escritura en la aplicación.
; App_LocalResources: Contiene archivos de recursos localizados para páginas individuales del sitio.
; App_GlobalResources: Contiene archivos '''resx''' con recursos localizados disponibles para cada página del sitio. Este es donde el desarrollador ASP.NET típicamente almacenara mensajes que serán usados en más de una página.
; App_Themes: usado para temas alternativos del sitio.
; App_WebReferences: Usado para archivos de descubrimiento y archivos [[WSDL]] para referencias a [[servicio web|servicios web]] para ser consumidos en el sitio.
; Bin: Contiene código compilado (archivos .dll) para controles, componentes, y otro código que pueda ser referenciado por la aplicación. Cualquier clase representada por código en la carpeta Bin es automáticamente referenciada en la aplicación. Son archivos o librerías que tienen como principal acción ejecutar una función cuando estas son llamadas o se invocan.

== Evolución respecto al ASP clásico ==
En el modelo de desarrollo web basado en páginas activas, la programación ASP actual tiene diversas limitaciones:

* Para que todo ocurra en una página web, es habitual escribir una gran cantidad de código para resolver necesidades sencillas. ASP.NET incorpora un modelo declarativo a la programación web: los controles de servidor funcionan en una página Web simplemente declarándolos. Cuando se carga la página ASP.NET, se instancian los controles listados en la página ASP y es responsabilidad del control emitir código HTML que el navegador pueda entender.

* ASP clásico es un tanto desorganizado. En una página ASP podemos incluir casi todo: HTML plano, código script, objetos [[COM]] y texto. No hay una distinción formal entre el contenido de una página y su comportamiento: simplemente, insertamos código en la página, y a ver qué pasa. ASP.NET impone un cierto orden sobre el modelo de programación estándar ASP. En cierto modo, esta "desorganización" puede evitarse fácilmente usando el sentido común y algunas de las nuevas tecnologías. Por ejemplo, podemos escribir en nuestras páginas ASP únicamente código VBScript. Dicho código generaría un mensaje [[XML]], que luego sería interpretado por un archivo [[XSLT]]. De esta forma conseguimos evitar el llamado "código spaguetti", aumentando la claridad del código y la velocidad de ejecución de las páginas ASP. Sin embargo, en la medida en que el programador deba trabajar con código escrito por otros, se enfrentará a menudo con las malas prácticas que son en gran medida acentuadas por la permisividad del ASP clásico.

* La tercera limitación en el desarrollo con ASP es que con el tradicional utilizamos lenguajes de scripting no tipados como [[VBScript]] o [[JScript]]. Podemos instalar otros motores de scripting que impongan verificación de tipos; sin embargo, no son universalmente conocidos o utilizados como los anteriores. ASP.NET claramente separa la porción basada en script de una página web de su contenido.

* ASP.Net, puede decirse que es un nuevo nivel de abstracción en la construcción de sitios web, porque se pueden crear rápidamente aplicaciones web, basándose en los controles incluidos en el ''frameWork'' o muchos gratuitos que hay en la red, ocultando el código de mucho Ej: Puedes crear fácilmente un ''grid'' o tabla, y esta se auto-ordena, página, etc, obteniendo sus datos desde cualquier base de datos. Incluye una gran herramienta para la construcción de reportes, y esto incluyen medios automáticos para exportarlos a XLS o PDF, y de igual forma incluye CristalReport. Además permite separar completamente la interfaz de la [[lógica de negocio]]. Excelente para desarrollo de aplicaciones multicapas.

* Es muy sencilla la creación de páginas con [[AJAX]], sólo incluyendo unos controles, así como descargar gratuitamente el ToolKit de ASP.Net Ajax.

== Extensiones ==

=== ASP.NET AJAX ===
{{AP|ASP.NET AJAX}}

'''ASP.NET AJAX''', anteriormente llamado Atlas, es un conjunto de extensiones para ASP.NET desarrollado por [[Microsoft]] para implementar la funcionalidad de [[AJAX|Ajax]].

ASP.NET AJAX fue liberado en enero de 2007 después de un largo periodo de pruebas. Fue subsecuentemente incluido con la versión 3.5 del .NET Framework, que fue liberada junto con Visual Studio 2008 en noviembre de 2007.

=== ASP.NET MVC Framework ===
{{AP|ASP.NET MVC Framework}}

Es una extensión de páginas ASP.NET utilizando la arquitectura [[Modelo Vista Controlador|MVC]].

==== ASP.NET Razor ====
{{AP|ASP.NET Razor}}

También conocido como ASP.NET Web Pages, es una alternativa a Web Forms diseñada para ser utilizada con MVC.

=== ASP.NET Dynamic Data ===
{{AP|ASP.NET Dynamic Data}}

Es un Framework inspirado en [[Ruby on Rails]] para la plataforma de Microsoft, que viene como una extensión de ASP.NET, que se puede utilizar para construir aplicaciones web orientadas a los datos. Expone las tablas de una base de datos mediante la codificación en la URI del servicio web ASP.NET, y los datos de la tabla se representan automáticamente a HTML. El proceso de renderizado se puede controlar con el uso de plantillas de diseño personalizadas. Internamente, se descubre el esquema de base de datos mediante el uso de los metadatos de la base de datos.

=== ASP.NET Web API ===
{{AP|ASP.NET Web API}}

Es un API HTTP para exposición de servicios Web RESTful.

=== ASP.NET SignaIR ===
{{AP|ASP.NET SignaIR}}

Es una nueva biblioteca para desarrolladores ASP.NET que hace el desarrollo Web en tiempo real funcionalmente fácil. Permite una comunicación bidireccional entre el cliente y el servidor. Los servidores ahora pueden insertar el contenido a los clientes conectados al instante cuando estén disponible. Soporta Web Sockets. Incluye APIs para la gestión de la conexión (por ejemplo, conectar y desconectar eventos), agrupación de conexiones y autorización.

== Modelos de programación en ASP.NET ==
Actualmente, ASP.NET soporta tres modelos de programación: ASP.NET Web Forms, ASP.NET MVC y ASP.NET Web Pages. Aunque los tres modelos de programación se ejecutan sobre la misma base de ASP.NET, cada uno de ellos estructura la aplicación de maneras completamente distintas, promueve metodologías de desarrollo diferentes y se adapta a perfiles de desarrolladores distintos. Algunas características que son virtudes en unos modelos de programación, pueden ser consideradas debilidades en el otro. ¿Qué es más importante, desarrollar a un gran nivel de abstracción o tener control total cada uno de los aspectos de la aplicación? Simplicidad vs. Control. Flexibilidad vs. Eficiencia. Estas son las compensaciones que hay que baremar a la hora de elegir. En esta serie de artículos repasaremos las diferencias entre los tres modelos de programación, y los escenarios favorables a cada uno de ellos.

Es importante recalcar que el hecho de elegir uno de los modelos de programación al comenzar un proyecto de ASP.NET no excluye necesariamente a los otros, sino que es posible tener aplicaciones “híbridas” y en muchos casos tendrá todo el sentido desarrollar ciertas partes de la aplicación con un modelo de programación y otras partes con otro modelo distinto.

'''ASP.NET Web Forms''' fue el primero de los tres modelos de programación en existir, y proporciona un gran nivel de abstracción con un modelo de programación familiar basado en eventos y controles que favorece la productividad mediante la programación declarativa reduciendo la cantidad de código necesaria para implementar una determinada funcionalidad.

'''ASP.NET MVC''' se concibió como alternativa a Web Forms y proporciona un modelo de programación basado en el popular patrón de arquitectura MVC. Entre sus principales características destacan su completa integración con pruebas unitarias y su separación más clara entre la lógica de presentación, la lógica de negocio y la lógica de acceso a datos.

Comunidad ASP.NET MVC en español: https://groups.google.com/d/forum/mundoaspnetmvc

'''ASP.NET Web Pages''' es el más reciente de los tres modelos de programación, y fue creado como respuesta a una creciente demanda de desarrolladores web sin experiencia previa con ASP.NET, cuya iniciación en ASP.NET Web Forms o MVC les suponía una inversión inicial de tiempo demasiado grande. Web Pages proporciona un modelo de programación más simple y rápido de aprender, sin renunciar a toda la funcionalidad y flexibilidad de ASP.NET.

== Uso actual del lenguaje ==
En la actualidad una aplicación .NET puede ejecutarse de dos formas distintas:

'''Aplicaciones cliente/servidor''':
Estas aplicaciones están típicamente en formato de [[ejecutable]]s [[código compilado|compilados]]. Estos pueden integrar toda la riqueza de una interfaz de usuario, tal es el caso de las aplicaciones de desempeño y productividad, pero no se reúne la lógica de negocio como un recurso que se pueda reutilizar. Además acostumbran ser menos gestionables y escalables que las demás aplicaciones.

'''Aplicaciones que utilizan el navegador''':
Dichas aplicaciones están caracterizadas por contar con una interfaz de web rica y muy útil. La interfaz gráfica integra varias tecnologías, las cuales son el HTML, [[XHTML]], scripting, etc; siempre y cuando el navegador que se esté utilizando soporte estas tecnologías.

== Véase también ==
* [[Página web]]
* [[Active Server Pages]]
* [[PHP]]
* [[Script]]
* [[Servidor web]]

== Referencias ==
{{Listaref}}


*La tercera limitación en el desarrollo con ASP es que con el tradicional utilizamos lenguajes de scripting no tipados como [[VBScript]] o [[JScript]]. Podemos instalar otros motores de scripting que impongan verificación de tipos; sin embargo, no son universalmente conocidos o utilizados como los anteriores. ASP.NET claramente separa la porción basada en script de una página Web de su contenido.
== Enlaces externos ==
== Enlaces externos ==
* [http://www.es-asp.net/ es-asp.net] - El mayor portal de ASP.NET en castellano.
* [http://www.asp.net ASP.NET Tutorial] - Web en inglés y Español? de tecnología ASP.NET
* [http://www.subgurim.net/ Subgurim] - Blog de ASP.NET 2.0 con C# en castellano.
* [http://www.solowindows.com/ Hosting ASP.NET] - Alojamiento Web ASP.NET
[[Categoría:Internet]]


{{Control de autoridades}}
[[cs:ASP.NET]]
[[da:ASP.NET]]
[[Categoría:Plataforma .NET]]
[[Categoría:Frameworks para aplicaciones web]]
[[de:ASP.NET]]
[[Categoría:Software libre y de código abierto]]
[[en:ASP.NET]]
[[fr:ASP.NET]]
[[he:ASP.NET]]
[[hu:ASP.NET]]
[[it:ASP.NET]]
[[ms:ASP.NET]]
[[nl:ASP.NET]]
[[no:ASP.NET]]
[[pt:ASP.NET]]
[[ro:ASP.NET]]
[[ru:ASP.NET]]
[[sq:ASP.NET]]
[[sv:ASP.NET]]
[[th:เอเอสพีดอตเน็ต]]
[[tr:Asp.net]]
[[zh:ASP.NET]]
[[zh-min-nan:ASP.NET]]

Revisión actual - 16:28 15 ago 2024

ASP.NET
Información general
Tipo de programa Framework
Desarrollador Microsoft
Lanzamiento inicial enero de 2002
Licencia EULA
Información técnica
Programado en .NET
Versiones
Última versión estable 4.5 ( 15 de agosto de 2012)
Última versión en pruebas 5.0 ( 12 de octubre de 2015)
Lanzamientos
Active Server Pages
ASP.NET
ASP.NET Core
Enlaces

ASP.NET es un entorno para aplicaciones web desarrollado y comercializado por Microsoft. Los programadores o también diseñadores pueden utilizar este framework para construir sitios web dinámicos, aplicaciones web y servicios web.[1]​ Apareció en enero de 2002 con la versión 1.0 del .NET Framework, y es la tecnología sucesora de la tecnología Active Server Pages (ASP). ASP.NET está construido sobre el Common Language Runtime, permitiendo a los programadores escribir código ASP.NET usando cualquier lenguaje admitido por el .NET Framework.

Historia

[editar]

Microsoft introdujo la tecnología llamada Active Server Pages en diciembre de 1996. Es parte de Internet Information Services (IIS) desde la versión 3.0 y es una tecnología de páginas activas que permite el uso de diferentes scripts y componentes en conjunto con el tradicional HTML para mostrar páginas generadas dinámicamente. La definición contextual de Microsoft es que "Las Active Server Pages son un ambiente de aplicación abierto y gratuito en el que se puede combinar código HTML, scripts y componentes ActiveX del servidor para crear soluciones dinámicas y poderosas para la web".

Después del lanzamiento del Internet Information Services 4.0 en 1997, Microsoft comenzó a investigar las posibilidades para un nuevo modelo de aplicaciones web que pudiera resolver las quejas comunes sobre ASP, especialmente aquellas con respecto a la separación de la presentación y el contenido y ser capaz de escribir código "limpio".[2]​ A Mark Anders, un administrador del equipo de IIS y Scott Guthrie, quien se había unido a Microsoft en 1997 después de graduarse de la Universidad Duke, se les dio la tarea de determinar cómo debería ser ese modelo. El diseño inicial fue desarrollado en el curso de dos meses por Anders y Guthrie, y Guthrie codificó los prototipos iniciales durante las celebraciones navideñas de 1997.[3]

Scott Guthrie en 2007.

El prototipo inicial fue llamado "XSP"; Guthrie explicó en una entrevista en el año 2007 que,

"People would always ask what the X stood for. At the time it really didn't stand for anything. XML started with that; XSLT started with that. Everything cool seemed to start with an X, so that's what we originally named it".[2]
"La gente siempre se preguntaba qué significaba la X. En ese momento, realmente no significaba nada. XML comenzaba así, al igual que XSLT. Todo lo novedoso parecía empezar con una X, así que ese es el motivo por el que originalmente lo llamamos así."

El desarrollo inicial de XSP fue hecho usando Java,[4]​ pero pronto se decidió construir una nueva plataforma sobre el Common Language Runtime (CLR), pues ofrecía un ambiente orientado a objetos, recolección de basura y otras características que fueron vistas como características deseables. Guthrie describió esta decisión como un "alto riesgo", pues el éxito de su nueva plataforma de desarrollo web estaría atado al éxito del CLR, que, como XSP, aún estaba en etapas tempranas de desarrollo, tanto así que el equipo XSP fue el primer equipo en Microsoft en enfocarse en el CLR.

Con el cambio al Common Language Runtime, XSP fue implementado en C# (conocido internamente como "Project Cool" pero mantenido en secreto para el público), y fue renombrado a ASP+, en este punto la nueva plataforma fue vista como el sucesor de Active Server Pages, y la intención fue proporcionar un medio fácil de migración para los desarrolladores ASP.[5]

La primera demostración pública y la liberación de la primera beta de ASP+ (y el resto del .NET Framework) se realizó en el Microsoft's Professional Developers Conference (PDC) el 11 de julio de 2000 en Orlando. Durante la presentación de Bill Gates, Fujitsu demostró ASP+ usado en conjunción con COBOL,[6]​ y el soporte para una variedad de otros lenguajes fue anunciada, incluyendo los nuevos lenguajes de Microsoft, Visual Basic .NET y C#, así como también el soporte por medio de herramientas de interoperabilidad para Python y Perl creadas por la empresa canadiense ActiveState.[7]

Una vez que la marca ".NET" fue seleccionada en la segunda mitad del 2000. se cambió el nombre de ASP+ a ASP.NET. Mark Anders explicó en una aparición en The MSDN Show en ese año,

"The .NET initiative is really about a number of factors, it’s about delivering software as a service, it's about XML and web services and really enhancing the Internet in terms of what it can do .... we really wanted to bring its name more in line with the rest of the platform pieces that make up the .NET framework."[5]
"La iniciativa .NET comprende un número de factores, trata sobre la entrega de software como servicio, sobre XML y servicios web y la mejora real del Internet en términos de qué puede hacer... de verdad queremos llevar su nombre (de ASP+) mas alineado con el resto de las piezas de la plataforma que componen el .NET framework"

Después de cuatro años de desarrollo, y una serie de versiones de evaluación en los años 2000 y 2001, ASP.NET 1.0 fue liberado el 5 de enero de 2002 como parte de la versión 1.0 del .NET Framework. Incluso antes de su liberación, docenas de libros habían sido escritos sobre ASP.NET[8]

Características

[editar]

Páginas

[editar]

Las páginas de ASP.NET, conocidas oficialmente como "web forms" (formularios web), son el principal medio de construcción para el desarrollo de aplicaciones web.[9]​ Los formularios web están contenidos en archivos con una extensión ASPX; en jerga de programación, estos archivos típicamente contienen etiquetas HTML o XHTML estático, y también etiquetas definiendo Controles Web que se procesan del lado del servidor y Controles de Usuario donde los desarrolladores colocan todo el código estático y dinámico requerido por la página web. Adicionalmente, el código dinámico que se ejecuta en el servidor puede ser colocado en una página dentro de un bloque <% -- código dinámico -- %> que es muy similar a otras tecnologías de desarrollo como PHP, JSP y ASP, pero esta práctica es, generalmente, desaconsejada excepto para propósitos de enlace de datos pues requiere más llamadas cuando se genera la página.

ASP.NET no sólo funciona sobre el servidor de Microsoft IIS, también lo hace sobre Apache.

Formulario web de ejemplo

[editar]

Este es un ejemplo que utiliza código "en línea", opuesto al código independiente (code-behind).

<%@ Page Language="C#" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<script runat="server">

    protected void Page_Load(object sender, EventArgs e)
    {
        Label1.Text = DateTime.Now.ToLongDateString();
    }

</script>

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>Página de Ejemplo</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:Label runat="server" id="Label1" />
    </div>
    </form>

</body>
</html>

El modelo Code-behind

[editar]

Microsoft recomienda que para realizar programación dinámica se use el modelo code-behind, o de respaldo, que coloca el código en un archivo separado o en una etiqueta de script especialmente diseñada. Los nombres de los archivos code-behind están basados en el nombre del archivo ASPX tales como MiPagina.aspx.cs o MiPagina.aspx.vb (esta práctica se realiza automáticamente en Microsoft Visual Studio y otros entornos de desarrollo). Cuando se usa este estilo de programación, el desarrollador escribe el código correspondiente a diferentes eventos, como la carga de la página, o el clic en un control, en vez de un recorrido lineal a través del documento.

El modelo code-behind de ASP.NET marca la separación del ASP clásico y alienta a los desarrolladores a construir aplicaciones con la idea de presentación y contenido separados en mente. En teoría, esto permite a un diseñador web, por ejemplo, enfocarse en la creación del diseño con menos posibilidades de alterar el código de programación mientras lo hace. Esto es similar a la separación en el Modelo Vista Controlador

Ejemplo

[editar]
<%@ Page Language="C#" CodeFile="EjemploCodeBehind.aspx.cs" Inherits="SitioWeb.EjemploCodeBehind" 
AutoEventWireup="true" %>

La etiqueta superior es colocada al inicio del archivo ASPX. La propiedad CodeFile de la directiva @ Page especifica qué archivo (.cs o .vb) contiene el código code-behind mientras que la propiedad Inherits especifica la clase de la cual deriva la página. En este ejemplo, la directiva @ Page está incluida en EjemploCodeBehind.aspx y el archivo EjemploCodeBehind.aspx.cs contendrá el código para esta página:

using System;

namespace SitioWeb
{
	public partial class EjemploCodeBehind: System.Web.UI.Page
	{
		protected void Page_Load(object sender, EventArgs e)
		{

		}
	}
}

En este caso, el método Page_Load() será llamado cada vez que la página ASPX sea solicitada al servidor. El programador puede implementar manejadores de eventos en varias etapas del proceso de ejecución de la página..

Controles de usuario

[editar]

ASP.NET permite la creación de componentes reutilizables a través de la creación de Controles de Usuario (User Controls). Un control de usuario sigue la misma estructura que un formulario web, excepto que los controles derivan de la clase System.Web.UI.UserControl, y son almacenados en archivos ASCX. Como los archivos ASPX, un ASCX contiene etiquetas HTML o XHTML, además de etiquetas para definir controles web y otros controles de usuario. También pueden usar el modelo code-behind.

Los programadores pueden agregar sus propias propiedades y métodos,[10]​ y manejadores de eventos.[11]​ Un mecanismo de eventos en burbuja proporciona la capacidad de pasar un evento disparado por un control de usuario a la página que lo contiene .

Administración del estado

[editar]

Las aplicaciones ASP.NET son alojadas en un servidor web y se tiene acceso a ellas mediante el protocolo sin estado HTTP, que no guarda ninguna información sobre conexiones anteriores. Por lo tanto, si la aplicación requiere interacción entre conexiones, tiene que implementar su propia administración del estado. ASP.NET proporciona varias maneras de administrar el estado de las aplicaciones ASP.NET.

Estado de la aplicación

[editar]

El estado de la aplicación (Application state) es una colección de variables definidas por el usuario que son compartidas por todas las invocaciones de una aplicación ASP.NET. Estas son establecidas e inicializadas cuando el evento Application_OnStart se dispara en la carga de la primera instancia de las aplicaciones y están disponible hasta que la última instancia termina. Las variables de estado o variables de sesión de la aplicación son identificadas por nombres.[12]

Estado de la sesión

[editar]

El estado de la sesión (Session state) es una colección de variables definidas por el usuario, las cuales persisten durante la sesión de un usuario. Estas variables son únicas para diferentes instancias de una sesión de usuario, y son accedidas usando la colección Session. Las variables de sesión pueden ser preparadas para ser automáticamente destruidas después de un determinado tiempo de inactividad, incluso si la sesión no ha terminado. Del lado del cliente, una sesión de usuario es identificada por una cookie o codificando el ID de la sesión en la misma URL.[12]

ASP.NET proporciona tres modos de persistencia para variables de sesión:[12]

InProc
Las variables de sesión son mantenidas dentro del proceso. Sin embargo, en este modo, las variables son destruidas cuando el proceso ASP.NET es reciclado o terminado.
StateServer
En este modo, ASP.NET ejecuta un servicio de Windows separado que mantiene las variables de estado. Como esta administración de estado ocurre fuera del proceso ASP.NET, tiene un impacto negativo en el rendimiento, pero permite a múltiples instancias de ASP.NET compartir el mismo estado del servidor, permitiendo que una aplicación ASP.NET pueda tener su carga balanceada y escalada en múltiples servidores. También, como el servicio de administración del estado se ejecuta independiente de ASP.NET, las variables pueden persistir a través de las finalizaciones del proceso ASP.NET.
SqlServer
En este modo, las variables de estado son almacenadas en un servidor de base de datos, accesible usando SQL. Las variables de sesión pueden persistir a través de finalizaciones de procesos también en este modo.

Estado de la vista

[editar]

El estado de la vista (View state) se refiere al mecanismo de administración de estado a nivel de página, que es utilizado por las páginas HTML generadas por las aplicaciones ASP.NET para mantener el estado de los controles de los formularios web y los widgets. El estado de los controles es codificado y mandado al servidor en cada envío del formulario en un campo oculto conocido como __VIEWSTATE. El servidor envía de regreso las variables para que cuando la página sea renderizada de nuevo, los controles volverán a su último estado. Del lado del servidor, la aplicación puede cambiar el estado de la vista, si los resultados del procesamiento actualizan el estado de cualquier control. El estado de los controles individuales son decodificados en el servidor, y están disponibles para su uso en ASP.NET usando la colección ViewState.[13][14]

Motor de plantillas

[editar]

Al ser liberado, ASP.NET carecía de un motor de plantillas. Debido a que .NET framework es orientado a objetos y permite herencia, muchos desarrolladores podrían definir una nueva clase que herede desde "System.Web. UI.Page", escribir métodos en ella que generen HTML y hacer que las páginas de su aplicación hereden de esta clase. Aunque esto permite que haya elementos comunes dentro de un sitio web, añade complejidad y mezcla código fuente con lenguaje de etiquetas. Además, este método puede visualizarse únicamente al ejecutar la aplicación, no mientras se está diseñando. Otros desarrolladores usan la inclusión de archivos y otros trucos para evitar la implementación de enlaces de navegación y otros elementos en cada página.

ASP.NET 2.0 presentó el concepto de página maestra (Master Page), que permite el desarrollo de páginas basado en plantillas web. Una aplicación web puede tener una o más páginas maestras, las cuales pueden ser anidadas.[15]​ Las plantillas maestras contienen controles contenedores, llamados ContentPlaceHolders para indicar donde irá el contenido dinámico, además de HTML y JavaScript que será compartido a través de las páginas hijas.

Las páginas hijas también usan esos controles ContentPlaceHolder, que deben ser relacionados con el ContentPlaceHolder de la página maestra que contiene a esta página hija. El resto de la página está definido por las partes compartidas de la página maestra. Todo el lenguaje de marcado y controles de servidor en la página de contenido deben ser colocadas dentro del control ContentPlaceHolder.

Cuando una solicitud es hecha por una página de contenido, ASP.NET mezcla la salida de la página de contenido con la salida de la página maestra, y envía el resultado al usuario.

La página maestra permanece completamente accesible a la página del contenido. Esto significa que la página de contenidos puede manipular los encabezados, cambiar el título, configurar la caché, etc. Si la página maestra expone propiedades públicas o métodos, el contenido de la página puede utilizar estos también.

Hoy en día con el nuevo producto de Microsoft WebMatrix, se dio a conocer el nuevo motor de plantillas conocido como Razor. Ya antes el IDE de Visual Studio incluía otros motores. Facilitando a las páginas ASP.NET Modelo Vista Controlador.

Otros archivos

[editar]

Otras extensiones de archivo asociadas con las diferentes versiones de ASP.NET incluyen:

Extensión Versión requerida Descripción
asax 1.0 Global.asax, usada para la lógica a nivel de aplicación[16]
ascx 1.0 Controles de usuario web: Controles personalizados para ser colocados en páginas web
ashx 1.0 Manejadores HTTP personalizados
asmx 1.0 Páginas de servicios web
axd 1.0 Cuando está habilitado en el web.config la solicitud de trace.axd genera trazas de salida a nivel de aplicación. También es usado para el manejador especial webresource.axd que permite a los desarrolladores de controles/componentes empacar un control/componente con imágenes, script, CSS, etc. para el desarrollo de un archivo único (un 'ensamblado')
browser 2.0 Archivos de capacidades del navegador almacenadas en formato XML; introducido en la versión 2.0. ASP.NET incluye muchos de estos por defecto, para admitir a los navegadores web comunes. Estos especifican que navegadores tienen que capacidades, así que ASP.NET 2 puede automáticamente personalizar y optimizar su salida de acuerdo al navegador. Los archivos especiales .browser están disponibles en descarga libre para manejar, por ejemplo, el validador de la W3C. Reemplaza la sección BrowserCaps que se encontraba en el archivo machine.config en ASP.NET 1.x
config 1.0 web.config es el único archivo en una aplicación web especifica que usa esta extensión por defecto (machine.config tiene efectos similares en un servidor web y todas las aplicaciones en el), sin embargo ASP.NET proporciona la facilidad de crear y utilizar otros archivos config. Son almacenados en formato XML
cs/vb 1.0 Archivos de código fuente (cs indica C#, vb indica Visual Basic). Los archivos code-behind predominantemente tienen la extensión ".aspx.cs" o ".aspx.vb" para los dos lenguajes más comunes. Otros archivos de código (que frecuentemente contienen bibliotecas de clases) pueden también existir en las carpetas web con las extensiones cs/vb. En ASP.NET 2 estos deberían estar colocados dentro de la carpeta App_Code donde son dinámicamente compilados y están disponibles para toda la aplicación
dbml 3.5 Archivo de clases de datos LINQ a SQL
master 2.0 Archivo de página maestra
resx 1.0 Archivos de recursos para localización y globalización. Los archivos de recursos pueden ser globales (por ejemplo, mensajes) o locales, que están hechos específicamente para un solo archivo aspx o ascx.
sitemap 2.0 Archivos de configuración sitemap
skin 2.0 Archivos de temas
svc 3.0 Archivos de servicio de Windows Communication Foundation

Estructura de directorios

[editar]

En general, la estructura de directorios de ASP.NET puede ser determinada por las preferencias del desarrollador. Aparte de unos pocos nombres de directorios reservados, el sitio puede expandirse a cualquier número de directorios. La estructura es típicamente reflejada directamente en las urls.

Los nombres de directorios especiales (a partir de ASP.NET 2.0 son):[17]

App_Browsers
Contiene archivos de definición específicos para navegadores.
App_Code
Es un directorio para códigos. El servidor ASP.NET automáticamente compilará los archivos (y subdirectorios) en esta carpeta en un ensamblado que es accesible desde cualquier página del sitio. App_Code es típicamente usada para código de acceso a datos, código de modelo o código de negocios. También cualquier manejador http específico para el sitio e implementación de módulos y servicios web van este directorio. Como alternativa a utilizar App_Code el desarrollador puede optar por proporcionar un ensamblado independiente con código precompilado.
App_Data
Directorio por defecto para las base de datos, tales como archivos mdb de Microsoft Access y archivos mdf de Microsoft SQL Server. Este directorio es usualmente el único con permisos de escritura en la aplicación.
App_LocalResources
Contiene archivos de recursos localizados para páginas individuales del sitio.
App_GlobalResources
Contiene archivos resx con recursos localizados disponibles para cada página del sitio. Este es donde el desarrollador ASP.NET típicamente almacenara mensajes que serán usados en más de una página.
App_Themes
usado para temas alternativos del sitio.
App_WebReferences
Usado para archivos de descubrimiento y archivos WSDL para referencias a servicios web para ser consumidos en el sitio.
Bin
Contiene código compilado (archivos .dll) para controles, componentes, y otro código que pueda ser referenciado por la aplicación. Cualquier clase representada por código en la carpeta Bin es automáticamente referenciada en la aplicación. Son archivos o librerías que tienen como principal acción ejecutar una función cuando estas son llamadas o se invocan.

Evolución respecto al ASP clásico

[editar]

En el modelo de desarrollo web basado en páginas activas, la programación ASP actual tiene diversas limitaciones:

  • Para que todo ocurra en una página web, es habitual escribir una gran cantidad de código para resolver necesidades sencillas. ASP.NET incorpora un modelo declarativo a la programación web: los controles de servidor funcionan en una página Web simplemente declarándolos. Cuando se carga la página ASP.NET, se instancian los controles listados en la página ASP y es responsabilidad del control emitir código HTML que el navegador pueda entender.
  • ASP clásico es un tanto desorganizado. En una página ASP podemos incluir casi todo: HTML plano, código script, objetos COM y texto. No hay una distinción formal entre el contenido de una página y su comportamiento: simplemente, insertamos código en la página, y a ver qué pasa. ASP.NET impone un cierto orden sobre el modelo de programación estándar ASP. En cierto modo, esta "desorganización" puede evitarse fácilmente usando el sentido común y algunas de las nuevas tecnologías. Por ejemplo, podemos escribir en nuestras páginas ASP únicamente código VBScript. Dicho código generaría un mensaje XML, que luego sería interpretado por un archivo XSLT. De esta forma conseguimos evitar el llamado "código spaguetti", aumentando la claridad del código y la velocidad de ejecución de las páginas ASP. Sin embargo, en la medida en que el programador deba trabajar con código escrito por otros, se enfrentará a menudo con las malas prácticas que son en gran medida acentuadas por la permisividad del ASP clásico.
  • La tercera limitación en el desarrollo con ASP es que con el tradicional utilizamos lenguajes de scripting no tipados como VBScript o JScript. Podemos instalar otros motores de scripting que impongan verificación de tipos; sin embargo, no son universalmente conocidos o utilizados como los anteriores. ASP.NET claramente separa la porción basada en script de una página web de su contenido.
  • ASP.Net, puede decirse que es un nuevo nivel de abstracción en la construcción de sitios web, porque se pueden crear rápidamente aplicaciones web, basándose en los controles incluidos en el frameWork o muchos gratuitos que hay en la red, ocultando el código de mucho Ej: Puedes crear fácilmente un grid o tabla, y esta se auto-ordena, página, etc, obteniendo sus datos desde cualquier base de datos. Incluye una gran herramienta para la construcción de reportes, y esto incluyen medios automáticos para exportarlos a XLS o PDF, y de igual forma incluye CristalReport. Además permite separar completamente la interfaz de la lógica de negocio. Excelente para desarrollo de aplicaciones multicapas.
  • Es muy sencilla la creación de páginas con AJAX, sólo incluyendo unos controles, así como descargar gratuitamente el ToolKit de ASP.Net Ajax.

Extensiones

[editar]

ASP.NET AJAX

[editar]

ASP.NET AJAX, anteriormente llamado Atlas, es un conjunto de extensiones para ASP.NET desarrollado por Microsoft para implementar la funcionalidad de Ajax.

ASP.NET AJAX fue liberado en enero de 2007 después de un largo periodo de pruebas. Fue subsecuentemente incluido con la versión 3.5 del .NET Framework, que fue liberada junto con Visual Studio 2008 en noviembre de 2007.

ASP.NET MVC Framework

[editar]

Es una extensión de páginas ASP.NET utilizando la arquitectura MVC.

ASP.NET Razor

[editar]

También conocido como ASP.NET Web Pages, es una alternativa a Web Forms diseñada para ser utilizada con MVC.

ASP.NET Dynamic Data

[editar]

Es un Framework inspirado en Ruby on Rails para la plataforma de Microsoft, que viene como una extensión de ASP.NET, que se puede utilizar para construir aplicaciones web orientadas a los datos. Expone las tablas de una base de datos mediante la codificación en la URI del servicio web ASP.NET, y los datos de la tabla se representan automáticamente a HTML. El proceso de renderizado se puede controlar con el uso de plantillas de diseño personalizadas. Internamente, se descubre el esquema de base de datos mediante el uso de los metadatos de la base de datos.

ASP.NET Web API

[editar]

Es un API HTTP para exposición de servicios Web RESTful.

ASP.NET SignaIR

[editar]

Es una nueva biblioteca para desarrolladores ASP.NET que hace el desarrollo Web en tiempo real funcionalmente fácil. Permite una comunicación bidireccional entre el cliente y el servidor. Los servidores ahora pueden insertar el contenido a los clientes conectados al instante cuando estén disponible. Soporta Web Sockets. Incluye APIs para la gestión de la conexión (por ejemplo, conectar y desconectar eventos), agrupación de conexiones y autorización.

Modelos de programación en ASP.NET

[editar]

Actualmente, ASP.NET soporta tres modelos de programación: ASP.NET Web Forms, ASP.NET MVC y ASP.NET Web Pages. Aunque los tres modelos de programación se ejecutan sobre la misma base de ASP.NET, cada uno de ellos estructura la aplicación de maneras completamente distintas, promueve metodologías de desarrollo diferentes y se adapta a perfiles de desarrolladores distintos. Algunas características que son virtudes en unos modelos de programación, pueden ser consideradas debilidades en el otro. ¿Qué es más importante, desarrollar a un gran nivel de abstracción o tener control total cada uno de los aspectos de la aplicación? Simplicidad vs. Control. Flexibilidad vs. Eficiencia. Estas son las compensaciones que hay que baremar a la hora de elegir. En esta serie de artículos repasaremos las diferencias entre los tres modelos de programación, y los escenarios favorables a cada uno de ellos.

Es importante recalcar que el hecho de elegir uno de los modelos de programación al comenzar un proyecto de ASP.NET no excluye necesariamente a los otros, sino que es posible tener aplicaciones “híbridas” y en muchos casos tendrá todo el sentido desarrollar ciertas partes de la aplicación con un modelo de programación y otras partes con otro modelo distinto.

ASP.NET Web Forms fue el primero de los tres modelos de programación en existir, y proporciona un gran nivel de abstracción con un modelo de programación familiar basado en eventos y controles que favorece la productividad mediante la programación declarativa reduciendo la cantidad de código necesaria para implementar una determinada funcionalidad.

ASP.NET MVC se concibió como alternativa a Web Forms y proporciona un modelo de programación basado en el popular patrón de arquitectura MVC. Entre sus principales características destacan su completa integración con pruebas unitarias y su separación más clara entre la lógica de presentación, la lógica de negocio y la lógica de acceso a datos.

Comunidad ASP.NET MVC en español: https://groups.google.com/d/forum/mundoaspnetmvc

ASP.NET Web Pages es el más reciente de los tres modelos de programación, y fue creado como respuesta a una creciente demanda de desarrolladores web sin experiencia previa con ASP.NET, cuya iniciación en ASP.NET Web Forms o MVC les suponía una inversión inicial de tiempo demasiado grande. Web Pages proporciona un modelo de programación más simple y rápido de aprender, sin renunciar a toda la funcionalidad y flexibilidad de ASP.NET.

Uso actual del lenguaje

[editar]

En la actualidad una aplicación .NET puede ejecutarse de dos formas distintas:

Aplicaciones cliente/servidor: Estas aplicaciones están típicamente en formato de ejecutables compilados. Estos pueden integrar toda la riqueza de una interfaz de usuario, tal es el caso de las aplicaciones de desempeño y productividad, pero no se reúne la lógica de negocio como un recurso que se pueda reutilizar. Además acostumbran ser menos gestionables y escalables que las demás aplicaciones.

Aplicaciones que utilizan el navegador: Dichas aplicaciones están caracterizadas por contar con una interfaz de web rica y muy útil. La interfaz gráfica integra varias tecnologías, las cuales son el HTML, XHTML, scripting, etc; siempre y cuando el navegador que se esté utilizando soporte estas tecnologías.

Véase también

[editar]

Referencias

[editar]
  1. «¿Qué es ASP.NET?». IONOS Digitalguide. Consultado el 11 de marzo de 2022. 
  2. a b Microsoft, ed. (Enero de 2007). «Architecture Journal Profile: Scott Guthrie». The Architecture Journal (en inglés). Consultado el 20 de abril de 2008. 
  3. Michiel van Otegem (24 de julio de 2007). «Interview with Scott Guthrie, creator of ASP.NET» (en inglés). Archivado desde el original el 9 de noviembre de 2007. Consultado el 20 de abril de 2008. 
  4. Tim Anderson (30 de octubre de 2007). The Register, ed. «How ASP.NET began in Java» (en inglés). Consultado el 20 de abril de 2008. 
  5. a b Microsoft, ed. (20 de diciembre de 2000). «Show #9 - ASP.NET». The MSDN Show (en inglés). Archivado desde el original el 22 de octubre de 2005. Consultado el 20 de abril de 2008. 
  6. Microsoft, ed. (11 de julio de 2000). «Bill Gates speech transcript - Professional Developers Conference 2000». Archivado desde el original el 10 de abril de 2008. Consultado el 20 de abril de 2008. 
  7. Business Wire, ed. (11 de julio de 2000). «ActiveState Supports Microsoft .NET Framework; Perl .NET & Python .NET Cross-Language Interoperability» (en inglés). Archivado desde el original el 9 de julio de 2012. Consultado el 20 de abril de 2008. 
  8. Microsoft, ed. (15 de noviembre de 2001). «S! from the PDC». The MSDN Show. Consultado el 20 de abril de 2008.  (enlace roto disponible en Internet Archive; véase el historial, la primera versión y la última).
  9. (MacDonald y Szpuszta, 2005, p. 63)
  10. http://msdn2.microsoft.com/en-us/library/ms972975.aspx#usercontrols_topic6 Adding Properties and Methods to a User Control
  11. http://msdn2.microsoft.com/en-us/library/ms972975.aspx#usercontrols_topic9 Creating and Raising a Custom Event
  12. a b c «INFO: ASP.NET State Management Overview» (en inglés). Consultado el 23 de octubre de 2007. 
  13. «ViewState in ASP.NET». Archivado desde el original el 14 de octubre de 2007. Consultado el 23 de octubre de 2007. 
  14. «ASP.Net ViewState Overview» (en inglés). Archivado desde el original el 16 de septiembre de 2008. 
  15. ASP.NET Master Pages Overview (Microsoft Developer Network)
  16. Global.asax Syntax
  17. http://msdn2.microsoft.com/en-us/library/ex526337.aspx ASP.NET Web Site Layout from MSDN

Enlaces externos

[editar]