安卓通过SQLite实现登录注册功能(小白式教程)

安卓通过SQLlite实现登录注册功能

前面基本操作看图片

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

第一个xml文件是:round_bg.xml,后面界面布局要用到

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
    <solid android:color="@color/colorPrimary"/>
    <corners android:radius="100dp"/>
</shape>

在这里插入图片描述

第二个xml文件是:round_border.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
    <stroke android:color="@color/colorPrimary"
        android:width="1dp"/>
    <corners android:radius="100dp"/>
</shape>

修改下系统颜色

在这里插入图片描述
改为:

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <color name="colorPrimary">#0099ff</color>
    <color name="colorPrimaryDark">#0099ff</color>
    <color name="colorAccent">#03DAC5</color>
</resources>

现在开始添加图标:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

其他的图标如下图,命名方法看个人习惯

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
可以参考我的命名方法,不要改太多就行。
在这里插入图片描述

开始登录界面的布局:打开activity_login.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"
    tools:context=".LoginActivity">

    <androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_constraintGuide_percent="0.5" />

    <androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        app:layout_constraintGuide_percent="0.35" />

    <androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        app:layout_constraintGuide_percent="0.45" />

    <androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline4"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        app:layout_constraintGuide_percent="0.55" />

    <androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline5"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        app:layout_constraintGuide_percent="0.65" />

    <androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline6"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        app:layout_constraintGuide_percent="0.75" />

    <TextView
        android:id="@+id/tv_loginview"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/logint"
        android:textSize="45sp"
        android:textColor="@color/colorPrimary"
        app:layout_constraintBottom_toTopOf="@+id/guideline2"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.129"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.494" />

    <EditText
        android:id="@+id/et_User"
        android:layout_width="350dp"
        android:layout_height="wrap_content"
        android:autofillHints="user"
        android:background="@drawable/round_border"
        android:drawableStart="@drawable/ic_user"
        android:drawablePadding="16dp"
        android:ems="10"
        android:hint="@string/etUser_hint"
        android:inputType="textEmailAddress"
        android:padding="16dp"
        app:layout_constraintBottom_toTopOf="@+id/guideline3"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        tools:ignore="LabelFor"
        app:layout_constraintTop_toTopOf="@+id/guideline2" />

    <EditText
        android:id="@+id/et_Psw"
        android:layout_width="350dp"
        android:layout_height="wrap_content"
        android:autofillHints=""
        android:background="@drawable/round_border"
        android:drawableStart="@drawable/ic_lock"
        android:drawablePadding="16dp"
        android:ems="10"
        android:hint="@string/pswHint"
        android:inputType="textPassword"
        android:padding="16dp"
        app:layout_constraintBottom_toTopOf="@+id/guideline4"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.508"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="@+id/guideline3"
        app:layout_constraintVertical_bias="0.47" />

    <CheckBox
        android:id="@+id/cb_rmbPsw"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:checked="true"
        android:drawingCacheQuality="auto"
        android:shadowColor="@color/colorPrimaryDark"
        android:text="@string/rempsw"
        android:textColor="
Android应用中,SQLite是一个轻量级的关系型数据库管理系统,常用于本地数据存储。当涉及到用户登录和注册功能时,可以采用以下步骤: 1. **创建数据库表**: - 创建两个表,如`Users`表用于存储用户信息(字段可能包括`userId`, `username`, `password`等),`Sessions`表用于保存会话信息(如`sessionId`, `userId`及登录状态)。 ```sql CREATE TABLE Users ( userId INTEGER PRIMARY KEY, username TEXT NOT NULL UNIQUE, password TEXT NOT NULL ); CREATE TABLE Sessions ( sessionId INTEGER PRIMARY KEY AUTOINCREMENT, userId INTEGER, token TEXT, FOREIGN KEY (userId) REFERENCES Users(userId) ); ``` 2. **用户注册**: - 新增用户时,将用户名、密码插入`Users`表。 ```java try { ContentValues values = new ContentValues(); values.put("username", username); values.put("password", hashedPassword); // 对密码进行哈希处理 context.getContentResolver().insert(Users.CONTENT_URI, values); } catch (Exception e) { // 处理错误 } ``` 3. **用户登录**: - 根据输入的用户名和密码查询`Users`表,如果找到匹配的数据,则尝试登录并保存会话到`Sessions`表。 ```java Cursor cursor = context.getContentResolver().query(Users.CONTENT_URI, null, "username=?", new String[]{username}, null); if (cursor.moveToFirst()) { String storedPassword = cursor.getString(cursor.getColumnIndex("password")); if (checkPassword(password, storedPassword)) { // 比较实际密码和数据库中的密码 int userId = cursor.getInt(cursor.getColumnIndex("userId")); saveSession(userId, generateToken()); // 生成并保存会话令牌 } cursor.close(); } // 登录方法辅助函数 private boolean checkPassword(String inputPassword, String storedPassword) { // 密码验证逻辑... } private void saveSession(int userId, String token) { ContentValues sessionValues = new ContentValues(); sessionValues.put("userId", userId); sessionValues.put("token", token); context.getContentResolver().insert(Sessions.CONTENT_URI, sessionValues); } ``` 4. **会话管理**: - 用户每次访问应用时,检查当前是否有有效的会话(通过`Sessions`表),如果有则直接登录;否则提示登录。 ```java Cursor sessionCursor = context.getContentResolver().query(Sessions.CONTENT_URI, null, "token=?", new String[]{sessionToken}, null); if (sessionCursor != null && sessionCursor.getCount() > 0) { sessionCursor.moveToFirst(); int userId = sessionCursor.getInt(sessionCursor.getColumnIndex("userId")); // 使用userId进行后续操作 sessionCursor.close(); } else { // 提示登录 } ``` 5. **安全性注意事项**: - 对敏感数据(如密码)进行加密存储和传输,并确保仅在客户端进行适当的权限管理。
评论 85
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

KIZAI

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值
>