相关疑难解决方法(0)

如何在Android中声明全局变量?

我正在创建一个需要登录的应用程序.我创建了主要和登录活动.

在主要活动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以避免在用户已经成功验证后出现登录表单?

singleton android state global-variables

592
推荐指数
7
解决办法
30万
查看次数

Android HTTP登录问题

嘿伙计们,我有一些关于在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上并在执行身份验证之前将其哈希?

authentication android login http

9
推荐指数
1
解决办法
3576
查看次数