![在这里插入图片描述](https://i-blog.csdnimg.cn/blog_migrate/2532c95483959d69077f45751dc71ef9.png)
strings.xml
<resources>
<string name="app_name">App0504</string>
<string name="usernameInfo">用户名:</string>
<string name="passwordInfo">密 码:</string>
<string name="loginInfo">登录</string>
</resources>
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">
</LinearLayout>
<Button
android:id="@+id/btnLogin"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:layout_marginTop="220dp"
android:text="@string/loginInfo"
android:textColor="@android:color/black"
android:textSize="20sp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.5"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="24dp"
android:layout_marginTop="140dp"
android:text="@string/passwordInfo"
android:textColor="@android:color/black"
android:textSize="20sp"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<EditText
android:id="@+id/etPassword"
android:layout_width="261dp"
android:layout_height="52dp"
android:layout_marginStart="120dp"
android:layout_marginTop="124dp"
android:layout_weight="1"
android:inputType="textPassword"
android:text="123456"
android:textColor="@android:color/black"
android:textSize="20dp"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="16dp"
android:layout_marginTop="60dp"
android:text="@string/usernameInfo"
android:textColor="@android:color/black"
android:textSize="20sp"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<EditText
android:id="@+id/etUsername"
android:layout_width="260dp"
android:layout_height="53dp"
android:layout_marginStart="120dp"
android:layout_marginTop="44dp"
android:layout_weight="1"
android:inputType="text"
android:text="admin"
android:textColor="@android:color/black"
android:textSize="20sp"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent">
<requestFocus />
</EditText>
</androidx.constraintlayout.widget.ConstraintLayout>
result.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/tvUsername2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="@android:color/black"
android:textSize="20dp" />
<TextView
android:id="@+id/tvPassword2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="@android:color/black"
android:textSize="20dp" />
</LinearLayout>
创建用户类 User
public class User {
private int id;
private String strUsername;
private String strPassword;
public User() {
}
public User(String username, String password) {
this.strUsername = username;
this.strPassword = password;
}
public void setUsername(String username) {
this.strUsername = username;
}
public void setPassword(String password) {
this.strPassword = password;
}
public int getId() {
return id;
}
public String getUsername() {
return strUsername;
}
public String getPassword() {
return strPassword;
}
}
创建用户类 DBHelper
public class DBHelper {
private static final String DATABASE_NAME = "datastorage";
private static final int DATABASE_VERSION = 1;
private static final String TABLE_NAME = "users";
private static final String ID = "_id";
private static final String USERNAME = "username";
private static final String PASSWORD = "password";
private DBOpenHelper helper;
private SQLiteDatabase db;
private static class DBOpenHelper extends SQLiteOpenHelper {
private static final String CREATE_TABLE = "create table "
+ TABLE_NAME + " ( " + ID + " integer primary key autoincrement, "
+ USERNAME + " text not null, "
+ PASSWORD + " text not null);";
public DBOpenHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(CREATE_TABLE);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL("drop table if exists " + TABLE_NAME);
onCreate(db);
}
}
public DBHelper(Context context) {
helper = new DBOpenHelper(context);
db = helper.getWritableDatabase();
}
public void insert(User user) {
ContentValues values = new ContentValues();
values.put(USERNAME, user.getUsername());
values.put(PASSWORD, user.getPassword());
db.insert(TABLE_NAME, null, values);
}
public User query(int id) {
User user = new User();
Cursor cursor = db.query(TABLE_NAME, new String[] { USERNAME,
PASSWORD },
"_id = " + id, null, null, null, null);
if (cursor.getCount() > 0) {
cursor.moveToFirst() ;
user.setUsername(cursor.getString(0));
user.setPassword(cursor.getString(1));
return user;
}
cursor.close();
return null;
}
}
完善类 MainActivity 与实现程序功能
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
final EditText username = (EditText) findViewById(R.id.etUsername);
final EditText password = (EditText) findViewById(R.id.etPassword);
Button login = (Button) findViewById(R.id.btnLogin);
login.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
String strUsername = username.getText().toString();
String strPassword = password.getText().toString();
User user = new User(strUsername, strPassword);
DBHelper helper = new DBHelper(MainActivity.this);
helper.insert(user);
Intent intent = new Intent();
intent.setClass(MainActivity.this, SQLiteReadActivity.class);
startActivity(intent);
}
});
}
}
定义类 SQLiteReadActivity 与实现程序功能
public class SQLiteReadActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.result);
TextView username = (TextView) findViewById(R.id.tvUsername2);
TextView password = (TextView) findViewById(R.id.tvPassword2);
DBHelper helper = new DBHelper(SQLiteReadActivity.this);
User user = helper.query(1);
username.setText("用户名:" + user.getUsername());
password.setText("密 码:" + user.getPassword());
}
在 AndroidManifest.xml 文件中注册 2 个 Activity 并配置启动项
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".SQLiteReadActivity"></activity>
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>