En definitiva se trata de un buen documento que deberia ser leido por cualquiera que este interesado en desarrollar software de calidad con una arquitectura bien definida y que aproveche todos los elementos que el nuevo framework 4.0 nos ofrece.
jueves, 25 de marzo de 2010
Guia de arquitectura
martes, 16 de marzo de 2010
Enumerados con valores de tipo cadena C#
///Ahora es necesario crear un Método de extension para poder obtener el string asociado al valor del enumerado./// Se crea una clase que hereada de Attribute /// esta clase almacenara el string con el valor /// del enumerado /// public class StringValueAttribute : Attribute { #region Properties ////// Holds the stringvalue for a value in an enum. /// public string StringValue { get; protected set; } #endregion #region Constructor ////// Constructor used to init a StringValue Attribute /// /// public StringValueAttribute(string value) { this.StringValue = value; } #endregion }
///Ahora vemos como crear un enumerado/// Se obtiene la cadena asociada /// a un valor concreto del enumerado,esto solo funciona /// si se ha asignado previamente un valor al atributo StringValue /// /// ///public static string GetStringValue(this Enum value) { // Get the type Type type = value.GetType(); // Get fieldinfo for this type FieldInfo fieldInfo = type.GetField(value.ToString()); // Get the stringvalue attributes StringValueAttribute[] attribs = fieldInfo.GetCustomAttributes( typeof(StringValueAttribute), false) as StringValueAttribute[]; // Return the first if there was a match. return attribs.Length > 0 ? attribs[0].StringValue : null; }
public enum MyEnum: int {
[StringValue("Lun")]
Lunes= 1,
[StringValue("Mar")]
Martes = 2
}
Como parte final vemos como usar nuestro enumerado.
MyEnum myE = MyEnum.Lunes; string val = myE.GetStringValue();
lunes, 22 de febrero de 2010
Mantener la posicion de un Div después de un postback asíncrono
Lo que hacemos es añadir dos manejadores BeginRequestHandler y EndRequestHandler, el primero se ejecuta justo antes de realizar el postback, en él obtenemos la posición del scroll y la almacenamos, en el segundo restauramos esa posición.
sábado, 30 de enero de 2010
Novedades Asp.Net 4.0 parte II
Output cache
Con la aparición de la primera versión de asp.net se introdujo el concepto de output cache, esto permite a los desarrolladores almacenar páginas, controles y las respuestas Http en la memoria de forma que las siguientes peticiones Web, asp.net puede servirlas de forma mucho más rápida y eficiente ya que solo tiene que acudir a la memoria y coger el código genera anteriormente para la página, editándose así una nueva generación del código de salida de la página.
Asp.Net 4 añade un punto más a esta funcionalidad permitiendo al desarrollador añadir uno o varios proveedores personalizados de output-cache. Estos proveedores (providers) permiten usar cualquier mecanismo de almacenamiento para persistir el código HTML. Esta nueva funcionalidad permite al desarrollador crear diversos providers en función del tipo de almacenamiento que precise en cada situación (discos remotos o locales, almacenamiento en la nube, motores de cache distribuida), combinandolos a su gusto.
Para crear un Cache provider personalizado debemos crear una clase y heredar de System.Web.Caching.OutputCacheProvider. Una vez creado el nuevo proveedor de cache tendremos que dar un paso mas para poder utilizarlo, este paso ya os lo podréis imaginar... si, tenemos que configurarlo en el Web.config, para ello, dentro de la sección de providers se ha creado una nueva subsección llamada outputcache. El siguiente fragmento de código nos muestra la sección de un web.config en el que se configura la cache para que se almacene en memoria. Este es el tipo de almacenamiento que se usa por defecto Asp.net 4.
Ademas de esto, podemos añadir un mayor nivel de detalle especificando a nivel de control o de petición. La manera mas sencilla de configurar un nuevo proveedor para un Control se usuario es utlizando la sintaxis declaratia. Para ello se ha creado un nuevo atributo llamado providerName, a continuación vemos como como utilizarlo
<%@ OutputCache Duration="60" VaryByParam="None" providerName="DiskCache" %>
Si por el contrario lo que queremos es configurar un proveedor difirente dependiendo de la página que se vaya a solicitar tendremos un poco más de trabajo. Es necesario sobreescribir el método GetOuputCacheProviderName en el Global.asax para especificar manualmente que proveedor corresponde con cada petición de página.
public override string GetOutputCacheProviderName(HttpContext context)
{
if (context.Request.Path.EndsWith("Advanced.aspx"))
return "DiskCache";
else
return base.GetOutputCacheProviderName(context);
}
Después de ver de forma muy resumida esta nueva caracteristica que nos ofrece asp.net a cada desarrollador se le pueden ocurrir algunas situaciones en las que podremos sacar provecho de esto, por ejemplo podemos combinar los distintos tipos de proveedores para conseguir accesos mas rápidos almacenando las páginas mas visitadas en memoria y aquellas que lo son menos en disco.
lunes, 11 de enero de 2010
Visual Studio 2010, Retrasado.
miércoles, 30 de diciembre de 2009
Novedades Asp.Net 4.0
Esto es posible gracias a que la mayoría de los elementos de conflagración han sido movidos al fichero machine.congif de forma que ahora las aplicaciones heredan del mismo. Esta novedad no aporta funcionalidad alguna pero si permite mayor legibilidad del código que teniendo en cuenta la cantidad de información que tenemos que manejar no es poco.
Feliz año nuevo a todos, menos framework y mas Champagne!!
jueves, 3 de diciembre de 2009
Cache de Objectos .Net: Applications Block
using Microsoft.Practices.EnterpriseLibrary.Caching; using Microsoft.Practices.EnterpriseLibrary.Caching.Expirations;
CacheManager cacheManager;
cacheManager = CacheFactory.GetCacheManager("MyCacheManager");
//Cache Manager es el nombre que le hemos dado al CacheManger en la herramienta de configuración
Usuario user = new Usuario("jorge", "españa", "28");
cacheManager.Add(user.nombre, user, CacheItemPriority.Normal, null, new SlidingTime(TimeSapn.FromMinutes(5)));
Con este ejemplo no se intuye la verdadera necesidad de utilizar este Block, pero si imaginamos situaciones en las que necesitemos realizar la cache en la capa de acceso a datos se vuelve un instrumento de gran importancia.