Xamarin.forms 登录成功时Xamarin表单导航
我开发了一个WebApi项目,它使用MS Identity并将数据提供给Html/Jquery客户端。我第一次尝试Xamarin forms,然后学习教程。我已经到了可以成功发布登录条件并接收承载令牌的阶段,并使用Xam Plugins.Settings存储它。我可以在将来的请求中使用此令牌并接收数据。 我正在努力实现导航,因此当用户单击登录按钮并获得令牌时,应用程序将“重定向”到查看GSMUnitsPage()。当前,用户单击按钮并正常登录,但它位于同一登录屏幕上。。。。我通过在GSMUnitsPage上创建一个按钮来证明一切正常 登录视图模型:Xamarin.forms 登录成功时Xamarin表单导航,xamarin.forms,Xamarin.forms,我开发了一个WebApi项目,它使用MS Identity并将数据提供给Html/Jquery客户端。我第一次尝试Xamarin forms,然后学习教程。我已经到了可以成功发布登录条件并接收承载令牌的阶段,并使用Xam Plugins.Settings存储它。我可以在将来的请求中使用此令牌并接收数据。 我正在努力实现导航,因此当用户单击登录按钮并获得令牌时,应用程序将“重定向”到查看GSMUnitsPage()。当前,用户单击按钮并正常登录,但它位于同一登录屏幕上。。。。我通过在GSMUnit
class LoginViewModel
{
public string Email { get; set; }
public string Password { get; set; }
public ICommand LoginCommand
{
get
{
return new Command(async () =>
{
ApiServices apiServices = new ApiServices();
var accesstoken = await apiServices.LoginUserAsync(Email, Password);
Settings.AccessToken = accesstoken;
});
}
}
public LoginViewModel()
{
Email = Settings.Username;
Password = Settings.Password;
}
}
登录Api:
public async Task<string> LoginUserAsync(string email, string password)
{
var client = new HttpClient();
var keyValues = new List<KeyValuePair<string, string>>
{
new KeyValuePair<string, string>("username", email),
new KeyValuePair<string, string>("password", password),
new KeyValuePair<string, string>("grant_type", "password")
};
var request = new HttpRequestMessage(
HttpMethod.Post, "linktotoken");
request.Content = new FormUrlEncodedContent(keyValues);
var reponse = await client.SendAsync(request);
var jwt = await reponse.Content.ReadAsStringAsync();
JObject jwtDyanmic = JsonConvert.DeserializeObject<dynamic>(jwt);
var accessToken = jwtDyanmic.Value<string>("access_token");
var accessTokenExpiration = jwtDyanmic.Value<DateTime>(".expires");
Settings.AccessTokenExpiration = accessTokenExpiration;
Debug.WriteLine(jwt);
return accessToken;
}
在LoginCommand上设置Settings.AccessToken后,尝试调用App.SetMainPage()方法。 (您可能希望将SetMainPage公开) -今天早些时候,我已经回答了你出于某种原因删除的几乎相同的问题。
<ContentPage.BindingContext>
<vm:LoginViewModel/>
</ContentPage.BindingContext>
<StackLayout VerticalOptions="Center">
<Entry Text="{Binding Email}" />
<Entry Text="{Binding Password}" />
<Button Command="{Binding LoginCommand}" Text="Login/Signin" />
</StackLayout>
public App ()
{
InitializeComponent();
SetMainPage();
}
private void SetMainPage()
{
if (!string.IsNullOrEmpty(Settings.AccessToken))
{
if (DateTime.UtcNow.AddHours(1) > Settings.AccessTokenExpiration)
{
var vm = new LoginViewModel();
vm.LoginCommand.Execute(null);
}
MainPage = new NavigationPage(new GSMUnitsPage());
}
else if(!string.IsNullOrEmpty(Settings.Username) && !string.IsNullOrEmpty(Settings.Password))
{
MainPage = new NavigationPage(new LoginPage());
}
else
{
MainPage = new NavigationPage(new RegisterPage());
}
}
public ICommand LoginCommand
{
get
{
return new Command(async () =>
{
ApiServices apiServices = new ApiServices();
var accesstoken = await apiServices.LoginUserAsync(Email, Password);
Settings.AccessToken = accesstoken;
App.SetMainPage();
});
}
}