Sylvanas0101 2017-11-25 13:16 采纳率: 40%
浏览 1351

用SQLite实现登录功能,点登录就会崩溃,求解答啊

用SQLite实现登录功能,点登录就会崩溃,求解答啊

这个是LoginActivity

 package com.sylvanas.qq;

import android.content.Intent;
import android.content.SharedPreferences;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.preference.PreferenceManager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.CheckBox;
import android.widget.EditText;
import android.widget.TextView;
import android.widget.Toast;

public class LoginActivity extends AppCompatActivity {
    private SharedPreferences pref;
    private SharedPreferences.Editor editor;
    private EditText accountEdit;
    private EditText passwordEdit;
    private Button login;
    private CheckBox remenberPass;
    private TextView register;
    private MyDatabaseHelper dbHelper;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_login);


        //登录
        pref = PreferenceManager.getDefaultSharedPreferences(this);
        accountEdit = (EditText) findViewById(R.id.account);
        passwordEdit = (EditText) findViewById(R.id.password);
        remenberPass = (CheckBox) findViewById(R.id.remember_pass);
        login = (Button) findViewById(R.id.button);
        boolean isRemember = pref.getBoolean("remember_password",false);
        if (isRemember){
            String account = pref.getString("account","");
            String password = pref.getString("password","");
            accountEdit.setText(account);
            passwordEdit.setText(password);
            remenberPass.setChecked(true);
        }
        login.setOnClickListener(new View.OnClickListener(){
            @Override
            public void onClick(View v) {
                String account = accountEdit.getText().toString();
                String password = passwordEdit.getText().toString();
                String password_in_SQL = "";
                //验证账号密码
                SQLiteDatabase db = dbHelper.getWritableDatabase();
                Cursor cursor = db.query("Login",null,"name = ?",new String[]{account},null,null,null);
                if(cursor.moveToNext()){
                    do{
                        password_in_SQL = cursor.getString(cursor.getColumnIndex("password"));
                        Log.d("LoginActivity","password:"+password_in_SQL);
                    }while (cursor.moveToNext());
                }
                cursor.close();
                if(password.equals(password_in_SQL)) {
                    editor = pref.edit();
                    if (remenberPass.isChecked()) {
                        editor.putBoolean("remember_password",true);
                        editor.putString("account",account);
                        editor.putString("password",password);
                    }else {
                        editor.clear();
                    }
                    editor.apply();
                    Intent intent = new Intent(LoginActivity.this,MainActivity.class);
                    startActivity(intent);
                    finish();
                }
                else if (account.equals("")){
                    Toast.makeText(LoginActivity.this,"请输入用户名",
                            Toast.LENGTH_SHORT).show();
                }
                else if (password.equals("")){
                    Toast.makeText(LoginActivity.this,"请输入密码",
                            Toast.LENGTH_SHORT).show();
                }
                else {
                    Toast.makeText(LoginActivity.this,"用户名或密码错误",
                            Toast.LENGTH_SHORT).show();
                }
            }
        });

        //注册
        register = (TextView) findViewById(R.id.register);
        register.setOnClickListener(new View.OnClickListener(){
            @Override
            public void onClick(View v){
                Intent intent = new Intent(LoginActivity.this,RegisterActivity.class);
                startActivity(intent);
                finish();
            }
        });
    }
}

刚开始建数据库和插入了一组账号密码

 package com.sylvanas.qq;

import android.content.ContentValues;
import android.content.Intent;
import android.database.sqlite.SQLiteDatabase;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.os.Handler;

public class FirstActivity extends AppCompatActivity {
    private MyDatabaseHelper dbHelper;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_first);
        dbHelper = new MyDatabaseHelper(this,"User.db",null,1);
        dbHelper.getWritableDatabase();

        SQLiteDatabase db = dbHelper.getWritableDatabase();
        ContentValues values = new ContentValues();
        values.put("account","MZ");
        values.put("password","MZ");
        db.insert("Login",null,values);
        db.close();

        new Handler().postDelayed(new Runnable() {
            @Override
            public void run() {
                Intent intent = new Intent(FirstActivity.this,LoginActivity.class);
                startActivity(intent);
                FirstActivity.this.finish();
            }
        }, 2000);
    }
}

实在是不会了,求大神解答

  • 写回答

1条回答

  • qq_41219081 2017-11-29 11:33
    关注

    我刚刚也在做这个 你是不是 在第一个页面 少输入了 dbHelper = new MyDatabaseHelper(this,"User.db",null,1);

    评论

报告相同问题?

悬赏问题

  • ¥15 用matlab 设计一个不动点迭代法求解非线性方程组的代码
  • ¥15 牛顿斯科特系数表表示
  • ¥15 arduino 步进电机
  • ¥20 程序进入HardFault_Handler
  • ¥15 oracle集群安装出bug
  • ¥15 关于#python#的问题:自动化测试
  • ¥20 问题请教!vue项目关于Nginx配置nonce安全策略的问题
  • ¥15 教务系统账号被盗号如何追溯设备
  • ¥20 delta降尺度方法,未来数据怎么降尺度
  • ¥15 c# 使用NPOI快速将datatable数据导入excel中指定sheet,要求快速高效