Estoy utilizando una aplicación cliente para conectarme a un servicio web solo para usuarios autenticados. Aquí es ejemplo más sencillo:
Mi código de servicio web:Mantener la sesión al llamar a un servicio web ASMX
public class TestService : System.Web.Services.WebService
{
[WebMethod(EnableSession = true)]
public string WelcomeMsg()
{
return "Hello: " + Session["UserName"] + "! Welcome to our store.";
}
[WebMethod(EnableSession = true)]
public void SetUserName(string sName)
{
Session["UserName"] = sName;
}
}
Aquí está mi código en la aplicación cliente (formulario de Windows, no base de la tela):
private void btnSetName_Click(object sender, EventArgs e)
{
TestService.TestService ws = new TestService.TestService(); //Create a web service
MainForm.m_ccSessionInfo = new System.Net.CookieContainer(); //Create a CookieContainer
ws.CookieContainer = MainForm.m_ccSessionInfo; //Set CookieContainer of the web service
ws.SetUserName(txtUserName.Text); //Set value of session
ws = null;
}
private void btnWelcome_Click(object sender, EventArgs e)
{
TestService.TestService ws = new TestService.TestService(); //Create a web service
ws.CookieContainer = MainForm.m_ccSessionInfo; //Set CookieContainer back
string sWelcome = ws.WelcomeMsg(); //Get value from session property
ws = null;
System.Diagnostics.Debug.WriteLine(sWelcome);
}
En mi ejemplo es una MainForm.m_ccSessionInfo miembro estático, quiero mantener el valor de las cookies de sesión en este!
Sin embargo, no funcionan :(. El ws.WelcomeMsg() siempre se devuelve una cadena vacía.
YESSSSSS !!!! Tengo que mantener algún código heredado para un servicio web ASMX, ¡y esto solucionó mi problema! ¡Gracias! –