Я выполнил некоторую работу, которая добавляет значения к состоянию сеанса внутри потока. Я бы хотел, чтобы эти значения были доступны вне потока (очевидно).
Информация, добавленная к сеансу, доступна вне сеанса без каких-либо проблем, когда режим состояния сеанса - «InProc».
Однако, когда режим состояния сеанса установлен на «StateServer», поведение отличается. Обычно значения, установленные внутри потока, сохраняются иногда, а иногда нет. Мне это кажется случайным.
Вот код, который воспроизводит проблему.
public partial class _Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
}
protected void store_Click(object sender, EventArgs e)
{
// Set the session values to default.
Session["Test1"] = "No";
Session["Test2"] = "No";
// Set the Test1 session value in the thread.
ThreadObject threadObject = new ThreadObject() { Username = Page.User.Identity.Name, SessionState = Session };
worker = new Thread(new ParameterizedThreadStart(Work));
worker.Start(threadObject);
// Set the Test2 session value in this thread just to compare.
Session["Test2"] = "Yes";
}
protected void print_Click(object sender, EventArgs e)
{
// Print out the Session values.
label1.Text = string.Empty;
label1.Text += "Inside Thread: " + Session["Test1"] + ", \n";
label1.Text += "Outside: " + Session["Test2"] + "\n";
}
private static Thread worker;
public static void Work(object threadObject)
{
// Retrieve the Session object and set the Test2 value.
ThreadObject threadObject1 = (ThreadObject)threadObject;
HttpSessionState currentSession = threadObject1.SessionState;
currentSession["Test1"] = "Yes";
}
}
public class ThreadObject
{
public string Username { get; set; }
public HttpSessionState SessionState { get; set; }
}
Приведенный выше код отлично работает с SessionState mode = "InProc", но случайный с:
<sessionState mode="StateServer"
stateConnectionString="tcpip=localhost:42424"
cookieless="false"
timeout="20"/>
Любые идеи?
РЕДАКТИРОВАТЬ: Итак, согласно комментариям ниже, поток должен завершиться до завершения запроса (основного потока), иначе все, что добавлено к сеансу, будет потеряно. Это связано с тем, что в конце основного потока сеанс сериализуется и отправляется в хранилище данных (вне процесса или SQL Server).