Как сохранить соединение (созданное в синглтон-классе) на следующей странице
Я пытаюсь разработать приложение для чата Windows в wp8.1. На моей первой странице я создал соединение с сервером в синглтон-классе. Я создал другое окно для отправки сообщений. Используя синглтон, как я могу также поддерживать соединение с сервером на следующей странице? Моя кнопка отправки находится на следующей странице. Как я могу поддерживать соединение на второй странице, также используя синглтон? заранее спасибо
это мой первый код страницы для подключения к серверу с помощью синглтона
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Navigation;
using Microsoft.Phone.Controls;
using Microsoft.Phone.Shell;
using WP8Xmpp.Resources;
using System.Net.XMPP;
using System.Threading;
namespace WP8Xmpp
{
public partial class MainPage : PhoneApplicationPage
{
public MainPage()
{
InitializeComponent();
}
private static volatile Singleton instance;
private static object syncRoot = new Object();
public static XMPPConnection ObjXmppCon;
public static XMPPClient ObjXmppClient;
public static Boolean IsXmppSuccess { get; set; }
public String UserName { get; set; }
public String PassWord { get; set; }
public readonly String Server = "taurus";
public readonly String ServerIPAddress = "127.0.0.1:9090";
public sealed class Singleton
{
private Singleton() { }
public static Singleton Instance
{
get
{
if (instance == null)
{
lock (syncRoot)
{
if (ObjXmppCon == null)
instance = new Singleton();
}
}
return instance;
}
}
}
public void IsXmppValid()
{
ObjXmppClient = new XMPPClient();
ObjXmppClient.JID = UserName + "@" + Server;
ObjXmppClient.Password = PassWord;
ObjXmppClient.Server = ServerIPAddress;
ObjXmppClient.AutoReconnect = true;
ObjXmppClient.RetrieveRoster = true;
ObjXmppClient.PresenceStatus = new PresenceStatus() { PresenceType = PresenceType.available, IsOnline = true };
ObjXmppClient.AutoAcceptPresenceSubscribe = true;
ObjXmppClient.AttemptReconnectOnBadPing = true;
ObjXmppCon = new XMPPConnection(ObjXmppClient);
ObjXmppCon.Connect();
ObjXmppClient.Connect();
//initializing the xmpp connection
ObjXmppCon.OnAsyncConnectFinished += ObjXmppCon_OnAsyncConnectFinished;
ObjXmppClient.OnStateChanged += new EventHandler(XMPPClient_OnStateChanged);
Thread.Sleep(2000);
}
public void ObjXmppCon_OnAsyncConnectFinished(xmedianet.socketserver.SocketClient client, bool bSuccess, string strErrors)
{
IsXmppSuccess = client.Connected;
}
public void XMPPClient_OnStateChanged(object sender, EventArgs e)
{
switch (ObjXmppClient.XMPPState)
{
case XMPPState.Ready:
if (IsXmppSuccess)// the name isxmpp does not contain in the current context
{
this.Dispatcher.BeginInvoke(() =>
{
NavigationService.Navigate((new Uri("/Output.xaml? key=success", UriKind.Relative)));//error
});
}
else
{
this.Dispatcher.BeginInvoke(() =>
{
MessageBox.Show("Check server name/IpAddress");
return;
});
}
break;
case XMPPState.AuthenticationFailed: this.Dispatcher.BeginInvoke(() =>
{
MessageBox.Show("Enter valid username and password");
return;
}); break;
}
}
private void btnLogin_Click(object sender, RoutedEventArgs e)
{
if (txtUserName.Text.Trim() == string.Empty)
{
MessageBox.Show("Enter Username");
return;
}
if (txtPassword.Password.Trim() == string.Empty)
{
MessageBox.Show("Enter Password");
return;
}
UserName = txtUserName.Text.Trim();
PassWord = txtPassword.Password.Trim();
IsXmppValid();
}
}
}
1 ответ
На мой взгляд, лучший способ сделать это - использовать инъекцию зависимости (было бы неплохо Ninject). Таким образом, вы можете создать свое ServerConnection за интерфейсом и просто внедрить его в те модели просмотра, которые ваши страницы используют для контекста данных. Нечто подобное ниже будет работать.
Синглтонная привязка
Bind<IServerConnection>().To<ServerConnection>().InSingletonScope();
После привязки интерфейса к реализации с использованием InSingletonScope у вас будет работать только один этот экземпляр. Таким образом, вы можете внедрить его в свои модели представлений, используя конструктор, и использовать его там, где это необходимо.
Это должно значительно облегчить разработку приложения для чата. Надеюсь, это поможет.