• 编写简单登陆和注册功能的demo时遇到的问题


    一、注册功能中添加数据不成功

    给数据库添加EditText中的内容后,数据库中找不到添加后的数据,并且存在字符串为空的数据

    解决方法:EditText registerAccount = (EditText)findViewById(R.id.register_account);和EditText registerPassword = (EditText)findViewById(R.id.register_password);必须写在onClick()方法中,不然获取不到EditText的值

    public class RegisterActivity extends AppCompatActivity {
    
        private MyDatabaseHelper dbHelper;
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.register);
            dbHelper = new MyDatabaseHelper(this, "UserStore.db", null, 1);
            Button okButton = (Button)findViewById(R.id.ok);
    
            okButton.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    SQLiteDatabase db = dbHelper.getWritableDatabase();
                    ContentValues values = new ContentValues();
                    EditText registerAccount = (EditText)findViewById(R.id.register_account);
                    EditText registerPassword = (EditText)findViewById(R.id.register_password);
                    String username = registerAccount.getText().toString();
                    String password = registerPassword.getText().toString();
                    if (!((username.equals("")) || (password.equals("")))) {
                        values.put("name", username);
                        values.put("password", password);
                        db.insert("User", null, values);
                        Toast.makeText(RegisterActivity.this, "注册成功", Toast.LENGTH_SHORT).show();
                        Intent intent = new Intent(RegisterActivity.this, LoginActivity.class);
                        startActivity(intent);
                    } else {
                        Toast.makeText(RegisterActivity.this, "用户名或密码不能为空", Toast.LENGTH_SHORT).show();
                    }
                }
            });
        }
    }

     二、字符串比较

    字符串之间值的比较要用.equals(),不能用“==”

    三、没有输入用户名和密码却能登陆成功,并且需要按多次Back键才能返回

    因为之前添加数据不成功导致数据库里存在空字符串数据,没有输入用户名和密码的时候,其实已经在和数据库中的空字符串数据进行了比较,所以导致登录成功,并且由于查询代码处于一个循环,所以有多少空字符串就循环了多少次,也就出现了重复的活动

  • 相关阅读:
    php如何导出csv文件(代码示例)
    【转】Linux 进程终止后自动重启
    【转】小程序web-view覆盖原生组件
    搭建 LNMP 环境
    数据库索引的底层原理
    NoSQL 介绍
    MySQL Explain详解
    centos搭建 SVN 服务器
    【转】提高mysql千万级大数据SQL查询优化30条经验(Mysql索引优化注意)
    优化mysql slave的同步速度
  • 原文地址:https://www.cnblogs.com/ruoshuisanqian/p/8781633.html
Copyright © 2020-2023  润新知