我正在创建一个需要登录的应用程序.我创建了主要和登录活动.
在主要活动onCreate方法中,我添加了以下条件:
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
...
loadSettings();
if(strSessionString == null)
{
login();
}
...
}
Run Code Online (Sandbox Code Playgroud)
onActivityResult登录表单终止时执行的方法如下所示:
@Override
public void onActivityResult(int requestCode,
int resultCode,
Intent data)
{
super.onActivityResult(requestCode, resultCode, data);
switch(requestCode)
{
case(SHOW_SUBACTICITY_LOGIN):
{
if(resultCode == Activity.RESULT_OK)
{
strSessionString = data.getStringExtra(Login.SESSIONSTRING);
connectionAvailable = true;
strUsername = data.getStringExtra(Login.USERNAME);
}
}
}
Run Code Online (Sandbox Code Playgroud)
问题是登录表单有时会出现两次(login()方法被调用两次),当手机键盘滑动时,再次出现登录表单,我猜问题是变量strSessionString.
有没有人知道如何设置变量global以避免在用户已经成功验证后出现登录表单?
嘿伙计们,我有一些关于在Android中实现登录功能的问题.
1. Does android have anything like sessions or cookies?我应该如何"记住"用户被淹没?显然我不希望每次使用我的应用程序时都要求输入密码!
2. Should I hash the password before sending it to the server?我的数据库中有一个表,其中包含用户和密码列.当我想检查登录时,是否应该将密码哈希发送到服务器login.php?u=sled&p=34819d7beeabb9260a5c854bc85b3e44,或者只是将纯文本发送到服务器login.php?u=sled&p=mypassword上并在执行身份验证之前将其哈希?