domingo, 10 de octubre de 2010
Estos son los enlaces publicados en Variable not found en Facebook y Twitter desde el martes, 05 de octubre de 2010 hasta el domingo, 10 de octubre de 2010.
Espero que te resulten interesantes. :-)
Publicado en: Variable not found
Espero que te resulten interesantes. :-)
- ASP.NET MVC 3 Beta: Some FAQ’s by Jon Galloway
Fecha: 08/10/2010 - Post de Eduard Tomàs: Mis impresiones sobre la Beta de MVC3
Fecha: 07/10/2010 - Validaciones en cliente no intrusivas con ASP.NET MVC 3.
Fecha: 07/10/2010 - Ajax no intrusivo en ASP.NET MVC 3.
Fecha: 07/10/2010 - Resultados POCO en acciones ASP.NET MVC.
Fecha: 07/10/2010 - Miguel de Icaza: Mono 2.8 is out.
Fecha: 07/10/2010 - Técnicas CSS a prueba de navegadores.
Fecha: 07/10/2010 - Interesante extensión para VS2010: se acabó el cuadro de diálogo “añadir referencias”
Fecha: 07/10/2010 - Brad Wilson: Unobtrusive Ajax in ASP.NET MVC 3
Fecha: 06/10/2010 - Brad Wilson: Seven new blog posts on IoC in ASP.NET MVC 3 Beta
Fecha: 06/10/2010 - ScottGu anuncia ASP.NET MVC 3 Beta, Webmatrix Beta 2 y Nupack.
Fecha: 06/10/2010 - Scott Hanselman: NuPack Package Management for .NET - Another piece of the Web Stack Fecha: 06/10/2010
- ¡Sorpresa! ASP.NET MVC 3 Beta.
Fecha: 06/10/2010 - Post de Eduard Tomàs: SQL Server Compact 4 CTP1: Cannot load native components
Fecha: 06/10/2010 - La putridez del software por Lobosoft.
Fecha: 06/10/2010 - Interesante batalla: Content Advisor vs. TempData en ASP.NET MVC
Fecha: 06/10/2010 - Extending ASP.NET MVC’s Validation by Mike Ormond
Fecha: 05/10/2010 - Helper para usar jQuery Autocomplete desde ASP.NET MVC
Fecha: 05/10/2010 - Pruebas unitarias usando el Mocking Context Generator de Entity Framework 4.
Fecha: 05/10/2010 - Diez errores usando el caché que pueden romper tu aplicación.
Fecha: 05/10/2010 - Soporte de CSS3 en Internet Explorer 9.
Fecha: 05/10/2010 - Extraer metadatos Exif de imágenes jpg desde .NET.
Fecha: 05/10/2010 - Gran revisión de cuatro View Engines para ASP.NET MVC.
Fecha: 05/10/2010
Publicado en: Variable not found
Publicado por José M. Aguilar a las 11:15 p. m.
Nadie ha comentado la entrada, ¿quieres ser el primero?
Etiquetas: enlaces
martes, 5 de octubre de 2010
Imaginad un día y medio con un montón de gente estupenda, auténticos monstruos cada uno en su especialidad, en un ambiente de lo más cordial y distendido, un entorno inmejorable, y con una agenda lo suficientemente densa como para mostrarnos las principales tecnologías y apuestas de Microsoft, pero con holgura suficiente como para permitir conocernos, intercambiar ideas y opiniones… Eso es el TTT, una experiencia alucinante.
Desde aquí, agradecer a los organizadores el esfuerzo que seguro que les ha supuesto, y, claro, que hayan tenido el detalle de invitarme ;-). A los asistentes que he tenido el placer de conocer personalmente, mil gracias por la acogida y los buenos ratos pasados.
Y bueno, al tema, que me estoy poniendo nostálgico: aunque un poco más tarde de lo habitual, van los enlaces publicados la semana pasada (y ya puestos, hoy también) a través de Variable not found en Facebook y Twitter.
Desde aquí, agradecer a los organizadores el esfuerzo que seguro que les ha supuesto, y, claro, que hayan tenido el detalle de invitarme ;-). A los asistentes que he tenido el placer de conocer personalmente, mil gracias por la acogida y los buenos ratos pasados.
Y bueno, al tema, que me estoy poniendo nostálgico: aunque un poco más tarde de lo habitual, van los enlaces publicados la semana pasada (y ya puestos, hoy también) a través de Variable not found en Facebook y Twitter.
- Elijah Manor: "MSDN Magazine: Cutting Edge - Action Filters in ASP.NET MVC"
Fecha: 04/10/2010 - jQuery Cycle Plugin, en MS Ajax CDN.
Fecha: 04/10/2010 - Crear diálogos simples con jQuery Alert Dialogs.
Fecha: 04/10/2010 - La verdad sobre los tipos valor, por Eric Lippert.
Fecha: 04/10/2010 - Create .zip files from an ASP.NET Application, por Scott Mitchell
Fecha: 04/10/2010 - José Manuel Alarcón: "Cómo incluir cambios de línea en los Tooltip"
Fecha: 29/09/2010 - El fix para ASP.NET está ya aquí listo para descarga (vía CampusMVP)
Fecha: 29/09/2010 - Qué tamaño tiene MSDN library, vía Scott Hanselman
Fecha: 29/09/2010 - "Five Must Have Tools for MVC Developers" por Michael Ceranski
Fecha: 28/09/2010 - Por qué es buena idea introducir retardos de duración aleatoria (como en el workaround de la vulnerabilidad de asp.net)
Fecha: 28/09/2010 - Uso de controladores asíncronos para llamar a webservices, por Gunnar Peipman.
Fecha: 27/09/2010 - Si pasas una conexión al contexto, eres responsable de su cierre y liberación. By Ayende Rahien.
Fecha: 27/09/2010 - Cómo mover los scripts de validación de ASP.NET MVC al final de la página.
Fecha: 27/09/2010
Publicado en: Variable not found
lunes, 27 de septiembre de 2010
La validación de peticiones es un mecanismo integrado en ASP.NET que evita la entrada al sistema de valores considerados “peligrosos” para su integridad, como tags y otros elementos utilizables para la inyección de scripts (XSS) o introducción de valores no controlados.
Dado que está implementado a nivel de plataforma ASP.NET, los valores recibidos en parámetros de entrada son vigilados con ASP.NET MVC, WebForms e incluso WebPages (la tecnología incluida en el nuevo WebMatrix).
Así, en cada petición son analizados los valores recibidos en el query string, cookies y campos de formulario, generándose una bonita pantalla de error cuando se identifica algo sospechoso:
Según el comportamiento por defecto, el framework realiza esta comprobación en el método
Aunque en la mayoría de ocasiones este mecanismo es muy útil, hay escenarios en los que se vuelve en nuestra contra. Por ejemplo, si en el formulario de datos hay campos destinados a la introducción de texto enriquecido, no nos permitirá la recepción de estos valores, pues normalmente incluirán tags HTML.
Veamos cómo podemos desactivar la comprobación de valores de entrada en distintos casos.
Para evitar la introducción de esta directiva en todas las páginas, podíamos hacerlo de forma global en el web.config, añadiendo el atributo
También en ASP.NET MVC era posible desactivar este comportamiento muy fácilmente añadiendo a la acción del control destinataria de los datos del formulario el atributo [
Concretamente, se ha modificado el momento en el ciclo de vida del tratamiento de las peticiones donde se realiza la validación de la información de entrada. De esta forma, ahora se aplicarán también a servicios web, handlers o módulos HTTP personalizados, que antes no eran comprobados.
Así, por defecto, se realizará la validación antes de que entren en escena las directivas de página en Webforms o los atributos del controlador, por lo que se producirá la excepción de validación aunque la hayamos desactivado con ellos.
La forma de evitar esto es indicar en el web.config que queremos trabajar en modo compatible con versiones anteriores, introduciendo en el elemento
Sin embargo, fijaos que al deshabilitar la validación lo hacemos sobre la petición completa; por ejemplo, si la desactivamos para una página donde existe un único campo en el que debe introducirse HTML estaríamos abriendo la posibilidad de que un usuario malintencionado introdujera código script en otros campos del formulario a los que posiblemente no prestemos tanta atención.
Curiosamente, analizando el código de ASP.NET he descubierto que existe un atajo que nos permite saltarnos la validación en un campo concreto del formulario, aunque la comprobación de peticiones se encuentre habilitada para la página, como es por defecto.
El hecho es que si el nombre del campo del formulario comienza por dos caracteres de subrayado, por ejemplo, “
Por tanto, si introducimos en un formulario cuadros de texto o textareas en los que queremos saltarnos esta validación, basta con nombrarlos siguiendo esta regla, como en el siguiente ejemplo, para ASP.NET MVC:
Asimismo, puede utilizarse con ASP.NET Webforms. En este caso, sólo debemos asegurarnos de que el nombre (el atributo name) asignado en cliente al control comience por el doble subrayado:
Publicado en: Variable not found.
Dado que está implementado a nivel de plataforma ASP.NET, los valores recibidos en parámetros de entrada son vigilados con ASP.NET MVC, WebForms e incluso WebPages (la tecnología incluida en el nuevo WebMatrix).
Así, en cada petición son analizados los valores recibidos en el query string, cookies y campos de formulario, generándose una bonita pantalla de error cuando se identifica algo sospechoso:
Según el comportamiento por defecto, el framework realiza esta comprobación en el método
IsDangerousString()
de una clase interna de System.Web
, llamada CrossSiteScriptingValidation
. Si estudiamos su implementación, podemos observar que se comprueban los siguientes aspectos:- si se detecta algún ampersand “
&
”, se asegura que el siguiente carácter no sea una almohadilla “#”. Esto impide la entrada de entidades como "|
;" - si se detecta algún símbolo “<”, se asegura que el siguiente carácter no sea alfabético, el signo de exclamación “!”, interrogación “?” o la barra de división “/”. Esto evitará la entrada de etiquetas HTML (como <script>), el cierre de las mismas o la introducción de directivas o comentarios, aunque dejará pasar algunas expresiones que pueden ser construcciones lógicas como “a<1”.
HttpRequestValidationException
, cuya representación en pantalla hemos visto anteriormente.Aunque en la mayoría de ocasiones este mecanismo es muy útil, hay escenarios en los que se vuelve en nuestra contra. Por ejemplo, si en el formulario de datos hay campos destinados a la introducción de texto enriquecido, no nos permitirá la recepción de estos valores, pues normalmente incluirán tags HTML.
Veamos cómo podemos desactivar la comprobación de valores de entrada en distintos casos.
Desactivación en versiones anteriores a ASP.NET 4
Antes de la llegada de ASP.NET 4, en Webforms era posible desactivar la validación de peticiones simplemente añadiendo la directivaValidateRequest=false
en las páginas:Para evitar la introducción de esta directiva en todas las páginas, podíamos hacerlo de forma global en el web.config, añadiendo el atributo
validateRequest="false"
en la sección <pages>
del system.web:También en ASP.NET MVC era posible desactivar este comportamiento muy fácilmente añadiendo a la acción del control destinataria de los datos del formulario el atributo [
ValidateInput]
enviándole false
como argumento:Desactivación en ASP.NET 4
ASP.NET 4 ha introducido una serie de breaking changes que pueden hacer que aplicaciones web que antes funcionaban correctamente dejen de hacerlo. Uno de estos cambios es la forma en que se validan las peticiones.Concretamente, se ha modificado el momento en el ciclo de vida del tratamiento de las peticiones donde se realiza la validación de la información de entrada. De esta forma, ahora se aplicarán también a servicios web, handlers o módulos HTTP personalizados, que antes no eran comprobados.
Así, por defecto, se realizará la validación antes de que entren en escena las directivas de página en Webforms o los atributos del controlador, por lo que se producirá la excepción de validación aunque la hayamos desactivado con ellos.
La forma de evitar esto es indicar en el web.config que queremos trabajar en modo compatible con versiones anteriores, introduciendo en el elemento
<httpRuntime>
el atributo requestValidationMode="2.0"
:¿Y la desactivación para un único campo?
En apartados anteriores hemos visto cómo desactivar las comprobaciones de la petición sobre páginas (en el caso de Webforms) y acciones (en ASP.NET MVC). El problema de la aparición del error “se detectó un posible valor Request.Form peligroso” lo solucionaríamos muy rápidamente con las técnicas descritas.Sin embargo, fijaos que al deshabilitar la validación lo hacemos sobre la petición completa; por ejemplo, si la desactivamos para una página donde existe un único campo en el que debe introducirse HTML estaríamos abriendo la posibilidad de que un usuario malintencionado introdujera código script en otros campos del formulario a los que posiblemente no prestemos tanta atención.
Curiosamente, analizando el código de ASP.NET he descubierto que existe un atajo que nos permite saltarnos la validación en un campo concreto del formulario, aunque la comprobación de peticiones se encuentre habilitada para la página, como es por defecto.
El hecho es que si el nombre del campo del formulario comienza por dos caracteres de subrayado, por ejemplo, “
__Texto
”, no se efectúan sobre él las comprobaciones de validación, probablemente para evitar que se realice sobre los campos especiales como “__VIEWSTATE
” o “__EVENTVALIDATION
”. Por tanto, si introducimos en un formulario cuadros de texto o textareas en los que queremos saltarnos esta validación, basta con nombrarlos siguiendo esta regla, como en el siguiente ejemplo, para ASP.NET MVC:
Asimismo, puede utilizarse con ASP.NET Webforms. En este caso, sólo debemos asegurarnos de que el nombre (el atributo name) asignado en cliente al control comience por el doble subrayado:
Publicado en: Variable not found.
domingo, 26 de septiembre de 2010
Estos son los enlaces publicados en Variable not found en Facebook y Twitter desde el domingo, 19 de septiembre de 2010 hasta el domingo, 26 de septiembre de 2010.
Espero que te resulten interesantes. :-)
Publicado en: Variable not found
Espero que te resulten interesantes. :-)
- Cookies grabadas a fuego: Evercookie.
Fecha: 26/09/2010 - EF4 Code First, MVC2 y Unity para atarlo todo un poco... , por Eduard Tomás.
Fecha: 24/09/2010 - La mejor forma de aprender a programar, y OrderedDictionary vs Dictionary, por José Manuel Alarcón.
Fecha: 24/09/2010 - Proveedor de SiteMaps para ASP.NET MVC. Fecha: 23/09/2010
- Cómo eliminar las cadenas mágicas en consultas con DataServiceQuery
Fecha: 23/09/2010 - Face Detection API: detección de caras en fotos de forma sencilla (vía CampusMVP)
Fecha: 22/09/2010 - El interfaz IValidatableObject de ASP.NET MVC 3.
Fecha: 22/09/2010 - Filtros globales y condicionales en MVC 3.
Fecha: 22/09/2010 - Brutal! Explicación muy buena en vídeo sobre la vulnerabilidad de ASP.NET (vía CampusMVP) Fecha: 21/09/2010
- Elijah Manor: "HowTo: Facebook Connect & ASP.NET MVC"
Fecha: 20/09/2010 - ¡Imprescindible! Buenas prácticas para ASP.NET MVC , creado por Microsoft.
Fecha: 20/09/2010
Publicado en: Variable not found
martes, 21 de septiembre de 2010
Este es un error que me ha hecho perder un buen rato mientras trabajaba con objetos POCO en Entity Framework 4, y espero que pueda ayudar a alguien que se encuentre con el mismo problema.
El tema comienza con el lanzamiento de una excepción
Hay ocasiones en las que la excepción lanzada al crear el
Sin embargo, este
Tras un buen rato de infructuosa investigación, acudí a Google, ese que todo lo sabe, y encontré la primera recomendación si esto te ocurre: revisa minuciosamente la definición de tus entidades POCO. Éstas deben coincidir exactamente con la definición del modelo conceptual, tanto en sus propiedades escalares, de tipos complejos y las propiedades de navegación.
Y el "minucionamente" no sobra. En mi caso había definido de forma incorrecta una propiedad de navegación, y por más que repasaba no veía ningún error; obviamente, desconfié de la recomendación que había encontrado, y me puse de nuevo a buscar la solución por mi cuenta: seguí escudriñando el EDM, regenerándolo, eliminando entidades que no usaba, modificándolas... para nada, claro.
Al final, la moraleja de esta historia es la siguiente: aunque pienses que tus entidades son correctas, vuelve a revisarlas, que fijo que algo te estás dejando por detrás.
Espero que, a diferencia de uno que yo me sé ;-), esta tontería no os haga perder mucho tiempo.
Publicado en: Variable not found.
El tema comienza con el lanzamiento de una excepción
InvalidOperationException
justo en el momento de crear un ObjectSet<T>
, como en el siguiente código:class MiContexto : ObjectContext
{
...
private ObjectSet<Cliente> clientes;
public ObjectSet<Cliente> Clientes
{
get
{
return clientes ??
(clientes = CreateObjectSet<Cliente>());
}
}
}
Hay ocasiones en las que la excepción lanzada al crear el
ObjectSet
es de tipo MetadataException
, y contiene información suficiente para detectar el error, por lo que es sencillo dar con la solución.Sin embargo, este
InvalidOperationException
y el texto que la acompaña (no se encontró la información de metadatos y asignaciones para EntityType 'Namespace.Entidad') son bastante confusos. De hecho, supongo que al ver esta descripción lo normal es que ponerse como loco a destripar el EDM para ver a dónde se ha ido la información de metadatos y asignaciones, a cambiar los namespaces… y por supuesto, todo en vano.Tras un buen rato de infructuosa investigación, acudí a Google, ese que todo lo sabe, y encontré la primera recomendación si esto te ocurre: revisa minuciosamente la definición de tus entidades POCO. Éstas deben coincidir exactamente con la definición del modelo conceptual, tanto en sus propiedades escalares, de tipos complejos y las propiedades de navegación.
Y el "minucionamente" no sobra. En mi caso había definido de forma incorrecta una propiedad de navegación, y por más que repasaba no veía ningún error; obviamente, desconfié de la recomendación que había encontrado, y me puse de nuevo a buscar la solución por mi cuenta: seguí escudriñando el EDM, regenerándolo, eliminando entidades que no usaba, modificándolas... para nada, claro.
Al final, la moraleja de esta historia es la siguiente: aunque pienses que tus entidades son correctas, vuelve a revisarlas, que fijo que algo te estás dejando por detrás.
Espero que, a diferencia de uno que yo me sé ;-), esta tontería no os haga perder mucho tiempo.
Publicado en: Variable not found.
domingo, 19 de septiembre de 2010
Estos son los enlaces publicados en Variable not found en Facebook desde el domingo, 12 de septiembre de 2010 hasta el domingo, 19 de septiembre de 2010.
Espero que te resulten interesantes. Y sobre todo, ojo al primero de ellos :-)
Publicado en: Variable not found
Espero que te resulten interesantes. Y sobre todo, ojo al primero de ellos :-)
- ScottGu: Important ASP.NET Security Vulnerability
Fecha: 18/09/2010 - Security Response: Security Advisory 2416728 has been released to address a vulnerability in ASP.NET
Fecha: 18/09/2010 - ¡Muy bueno! José Manuel Alarcón: Archivos temporales de compilación de ASP.NET
Fecha: 18/09/2010 - Interesante: jQuery UI en la CDN de Microsoft. /via Phil Haack
Fecha: 17/09/2010 - The Ultimate Guide for New IE9 users Who Fear Change " (Vía campusMVP)
Fecha: 17/09/2010 - Curiosidad: ¿is es as, o as es is? Eric Lippert nos lo cuenta.
Fecha: 17/09/2010 - .NET String Formatting Cheat Sheet" por Dylan Beattie
Fecha: 16/09/2010 - Determinar el tamaño del ViewState usando distintas técnicas, por Scott Mitchell
Fecha: 16/09/2010 - Abrir enlaces externos en ventanas independientes con jQuery, por Scott Mitchell
Fecha: 16/09/2010 - Post de gpeipman: implementación de PagedResult
, para retornar datos paginados desde repositorios
Fecha: 16/09/2010 - Post de marc_Rubino: ASP. NET MVC como Servicio REST
Fecha: 16/09/2010 - Luis Ruiz Pavón: Autenticación con DNIe en aplicaciones ASP.NET
Fecha: 15/09/2010 - jQuery Barcode Generator Plugin jQuery
Fecha: 14/09/2010 - Cambios en la validación de peticiones introducidos por ASP.NET 4.
Fecha: 14/09/2010 - Fórmulas para la implementación de Ajax en ASP.NET MVC.
Fecha: 14/09/2010 - Particularidades del uso de app_offline.htm en aplicaciones ASP.NET MVC.
Fecha: 14/09/2010 - Scott Guthrie: I just blogged about "Automating Deployment with Microsoft Web Deploy" and cover how to setup & use it:
Fecha: 13/09/2010 - Todas las herramientas de Sysinternals en una única descarga: "Sysinternals suite".
Fecha: 13/09/2010 - Gonzalo Pérez C. muestra un ejemplo práctico de uso de Google Maps, jQuery y ASP.NET.
Fecha: 13/09/2010 - Unai Zorrila continúa su serie de trucos para mejorar el rendimiento en #EF4.
Fecha: 13/09/2010 - Hoy es el día del programador, ¡Felicidades! X-D
Fecha: 13/09/2010
Publicado en: Variable not found