Un funcionalidad requerida desde el webcontrol Login es la redireccion a partir de un rol especifico, ya sea porque unos amigos lo necesitaban o por algunas preguntas de la misma tematica en los grupos de noticias de asp.net
Vamos por lo que nos dice la razón, que es en el evento LoggedIn. Porque se ejecuta en este orden: LoggingIn, Authenticate y luego LoggedIn
Un ejemplo:
Protected Sub Login2_LoggedIn(ByVal sender As Object, ByVal e As System.EventArgs) Handles Login2.LoggedIn
If User.IsInRole("MAESTROJEDI") = True Then
Response.Redirect("~/admin/indexParaMAESTROJEDI.aspx")
End If
End Sub
Pero no funciono..!!
No encontramos en ningun lado porque no teniamos al usuario disponible (en el objeto User), ni tampoco de esta manera:
Roles.IsUserInRole(Context.User.Identity.Name, "MAESTROJEDI")
Pareciera que cuando recien termina de armar la pagina se carga en la session y las cookies son enviadas a cliente....pero antes nada de nada
No nos ibamos a quedar de brazos cruzados, algo teniamos que hacer. Llegamos a dos soluciones que espero que sean de utilidad
OPCION 1: Pagina o Handler que sea te intermediario
Desde la página de login la enviamos en el mismo evento (LoggedIn) a otra pagina que alli podamos realizar esta sencilla pregunta de Roles
OPCION 2: Un poco... (artesanal) pero nos
Bueno dijimos entonces donde esta el usuario? y via MSN je en el textbox dentro del webcontrol Login y ya sabiamos que el usuairo se autentico
asi que solo nos quedaba recuperarlo:
Dim usuario As String = Login2.UserName
If Roles.IsUserInRole(usuario, "MAESTROJEDI") Then
Response.Redirect("~/admin/indexParaMAESTROJEDI.aspx")
End If
OPCION 2.1:
Tambien lo puedes recuperar directamente del textbox que rederiza el webcontrol Login para el nombre de usuario con el id "Username"
Dim txtUsername As TextBox = CType(Login2.FindControl("Username"), TextBox)
Dim usuario As String = txtUsername.Text
If Roles.IsUserInRole(usuario, "JEDIMASTER") Then
Response.Redirect("~/admin/indexParaJEDIMASTER.aspx")
End If
Enlaces
- Login (Clase)
Proporciona los elementos de la interfaz de usuario para iniciar sesión en un sitio Web.
- Login.LoggingIn (Evento)
Se produce cuando un usuario envía información de inicio de sesión, antes de que tenga lugar la autenticación.
- Login.Authenticate (Evento)
Aparece cuando se autentica un usuario.
- Login.LoggedIn (Evento)
Aparece cuando el usuario inicia sesión en el sitio Web y se ha autenticado.
Interesante "correspondencia" entre XAML y los .FRM de los viejos (que aun utilizo) proyectos de VB6 en un post de Tom Hollander titulado VB4: "XAML, I am your father" . Lo capte al post rapidamente por dos cosas VB y la sugerencia a Startwars ;)
Hace un paralelismo entre estos dos diferentes tipos de metadata. No espero realizar un debate (ni con mis compañeros de trabajo) , ademas mas de una vez manipulamos estos archivos .frm, o .vbp de VB6 para arreglar alguna mala referencia, incluso en una oportunidad arreglando el un menu en VB6
También esto de definir formularios con xml como metadata ya habia testeado cuando jugaba con Flex y sus .mxml (en sus etapas beta) y me parecia bueno.. solo que la herramienta lo generaba cuando haciamos drag & drop era una separada Dreamweaver (parecido ya que se tomo como base esto mismo). Encima necesitaba ejecutar un sevidor de aplicaciones Java, asi que despues de las beta perdi el rastro de esta tecnología espero algun dia volver a utilizarla (si vuelve Soda Stereo porque yo no je!)
| XAML | VB5 | MXML |
<wf:Form x:Class="XamlWinForms.Window1" xmlns:x="http://schemas.microsoft.com /winfx/2006/xaml" xmlns:wf="clr-namespace:System.Windows.Forms; assembly=System.Windows.Forms" xmlns:sys="clr-namespace:System; assembly=mscorlib" Text="Window1" Height="300" Width="300" > <wf:Form.Controls> <wf:Panel BackColor="#00FFFF" Dock="Fill" BorderStyle="Fixed3D"> <wf:Panel.Controls> <wf:Button Text="Click Me!" Left="50" Top="50" Width="100" Height="50" Click="Button_Click"> </wf:Button> <wf:ListBox Top="120" Left="20"> <wf:ListBox.Items> <sys:String>Foo</sys:String> <sys:String>Bar</sys:String> </wf:ListBox.Items> </wf:ListBox> </wf:Panel.Controls> </wf:Panel> </wf:Form.Controls> </wf:Form> |
VERSION 5.00
Begin VB.Form Form1
Caption = "Form1"
ClientHeight = 3090
ClientLeft = 60
ClientTop = 450
ClientWidth = 3690
ForeColor = &H0000FFFF&
LinkTopic = "Form1"
MaxButton = 0 'False
ScaleHeight = 3090
ScaleWidth = 3690
StartUpPosition = 3 'Windows Default
Begin VB.Timer Timer1
Interval = 1000
Left = 3000
Top = 2280
End
Begin VB.CommandButton Command1
Caption = "Press to Play"
BeginProperty Font
Name = "MS Sans Serif"
Size = 9.75
Charset = 0
Weight = 700
Underline = 0 'False
Italic = 0 'False
Strikethrough = 0 'False
EndProperty
Height = 495
Left = 720
MaskColor = &H008080FF&
TabIndex = 0
Top = 2400
Width = 2175
End
Begin VB.Shape Shape1
FillColor = &H000000FF&
FillStyle = 0 'Solid
Height = 615
Index = 8
Left = 2280
Shape = 5 'Rounded Square
Top = 1080
Width = 495
End
End |
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx= "http://www.macromedia.com/2003/mxml">
<mx:WebService id="wsStock"
wsdl="http://services.xmethods.net/soap/ urn:xmethods-delayed-quotes.wsdl">
<mx:operation name="getQuote">
<mx:request>
<symbol>{symbol.text}</symbol>
</mx:request>
</mx:operation>
</mx:WebService>
<mx:Label text="Enter a symbol:"/>
<mx:HBox>
<mx:TextInput id="symbol"/>
<mx:Button label="Get Quote" click='wsStock.getQuote.send()'/>
</mx:HBox>
<mx:Label id="quote" fontWeight="bold" text="{wsStock.getQuote.result}"/>
</mx:Application> |
Buscando en Geeks.ms (que comunidad...!) encontre este interesante post del elBruno
- Migrando de VB6 a WPF ... the easy way !!!
Donde nos comenta sobre VB6(2)WPF
Me imagino que hace una correspondecia de estas propiedades que tenemos mas arriba, pero bueno el que necesita tiene algo para testear ;)
Y una frase al final que me gustaria reproducir: "it's nice to know that good ideas like this don't die"
Más de una vez quisimos llamadar a un .bat y recuperar la salida para visualizarla desde una página, con ASP.NET 2.0 tenemos metodos que nos facilitan la vida.
Como me dedique a leer un poco quise dejarlo por aquí, por si alguien lo necesita.
Siempre empezamos con un ejemplo bien pero bien básico para ir creciendo, y poder realizar las tareas que realmente necesitamos. En este caso empezamos con un ping y luego seguimos con un tracert a geeks.ms y una ayuda de cmd.exe /?
Código
Private Sub Ejecutar()
Dim strArgumentos As String = "127.0.0.1"
Dim strExe As String = "ping"
'Armar el proceso a ejecutar
Dim startInfo As System.Diagnostics.ProcessStartInfo = New System.Diagnostics.ProcessStartInfo(strExe, strArgumentos)
'Para poder manupular la salida indicamos que no se ejecute el shell
startInfo.UseShellExecute = False
'Por definicion (o mejor dicho codificacion) debemos ajustarnos a los que nos dice "San MSDN"
'(...)UseShellExecute debe ser true si se desea establecer ErrorDialog en true(...)
startInfo.ErrorDialog = False
'Sin ventana...
startInfo.CreateNoWindow = True
'Deseamos manipular la salida del proceso, para ello debemos establecer que se redirija la salida
startInfo.RedirectStandardOutput = True
Try
Dim p As Diagnostics.Process = System.Diagnostics.Process.Start(startInfo)
'Leemos la salida (objeto StreamReader)
Dim sr As System.IO.StreamReader = p.StandardOutput
Dim cadenaSalida As String = sr.ReadToEnd()
sr.Close()
'La visualizamos en el textbox. Un ejemplo basico ;)...
TextBox1.Text = cadenaSalida
Catch ex As Exception
TextBox1.Text = (ex.Message)
End Try
End Sub
Ejemplo 1: Ping
Comando: "ping 127.0.0.1"
Dim strArgumentos As String = "127.0.0.1"
Dim strExe As String = "ping"
Y en la salida capturada y visualizada en el Textbox
Ejemplo 2: Tracert
Comando: "tracert www.geeks.ms"
Dim strArgumentos As String = "www.geeks.ms"
Dim strExe As String = "tracert"
Salida capturada
Ejemplo 3: Ayuda de cmd.exe /?
Comando: "cmd.exe /?"
Dim strArgumentos As String = "/?"
Dim strExe As String = "cmd.exe"
Y en la salida capturada y visualizada en el Textbox
Hasta aquí llego el ejemplo básico, espero sea la base para otras necesidades.
Como podemos capturar la salida del proceso, podremos manipularla/filtrarla a nuestro antojo.
Enlaces
- Process.Start (Método) (ProcessStartInfo)
Inicia el recurso de proceso que se especifica mediante el parámetro que contiene la información de inicio del proceso (por ejemplo, el nombre de archivo del proceso que se va a iniciar) y asocia el recurso a un nuevo componente Process.
- ProcessStartInfo.UseShellExecute (Propiedad)
Obtiene o establece un valor que indica si se va a usar el shell del sistema operativo para iniciar el proceso.
- (...)Si se establece esta propiedad en false, es posible redirigir las secuencias de entrada, salida y error (...)
- (...)El valor de UseShellExecute debe ser true si se establece el valor de la propiedad ErrorDialog en true.(...)
- ProcessStartInfo.ErrorDialog (Propiedad)
Obtiene o establece un valor que indica si se va a mostrar un cuadro de diálogo de error al usuario si el proceso no se puede iniciar.
- nuevamente: (...)UseShellExecute debe ser true si se desea establecer ErrorDialog en true(...)
- ProcessStartInfo.CreateNoWindow (Propiedad)
Obtiene o establece un valor que indica si el proceso se va a iniciar en una nueva ventana.
- ProcessStartInfo.RedirectStandardOutput (Propiedad)
Obtiene o establece un valor que indica si el resultado de una aplicación se escribe en la secuencia de Process.StandardOutput.
- (...)Cuando un Process escribe texto en la secuencia estándar, dicho texto se muestra normalmente en la consola. Si se redirige la secuencia de StandardOutput, se puede manipular o suprimir el resultado de un proceso(...)
- (...)Es preciso establecer el valor de UseShellExecute en false si se desea establecer el valor de RedirectStandardOutput en true. De lo contrario, al leer la secuencia de StandardOutput, se produce una excepción.(...)
- Process.StandardOutput (Propiedad)
Obtiene una secuencia utilizada para leer la salida de la aplicación.