热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

团队冲刺第一阶段(七)

一、前言昨天完善了登录注册的服务端。今天利用Sqlite数据库实现了记住用户登录状态的功能,当用户登录以后在数据库中插入用户数据,当用户点击退出登录之后,将数据删除,在启动APP的

一、前言

  昨天完善了登录注册的服务端。

  今天利用Sqlite数据库实现了记住用户登录状态的功能,当用户登录以后在数据库中插入用户数据,当用户点击退出登录之后,将数据删除,在启动APP的时候对本地数据库进行查询,如果有数据,则直接进入主页面,否则进入登录页面。遇到的困难是在记住用户已登录之后,用户id参数的传导问题,通过了解query语法解决。

  明天继续对细节以及一些页面进行美化改进。

二、成果

 三、代码

DataBaseHelper.java


package com.androidlearing.tdtreehole.database;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.util.Log;
import androidx.annotation.Nullable;
/**
* @ProjectName: TDTreeHole
* @Package: com.androidlearing.tdtreehole.databasehelper
* @ClassName: DataBaseHelper
* @Description: java类作用描述
* @Author: 武神酱丶
* @CreateDate: 2020/4/23 16:44
* @UpdateUser: 更新者
* @UpdateDate: 2020/4/23 16:44
* @UpdateRemark: 更新说明
* @Version: 1.0
*/
public class DataBaseHelper extends SQLiteOpenHelper {
private static final String DATA_BASE_NAME = "user";
private static final int VERSION = 1;
private static final String TAG = "DataBaseHelper";
public DataBaseHelper(@Nullable Context context) {
super(context, DATA_BASE_NAME, null, VERSION);
}
//创建数据库的回调
@Override
public void onCreate(SQLiteDatabase db) {
Log.d(TAG,"创建数据库...");
String sql = "create table "+DATA_BASE_NAME+"(id integer primary key,username varchar(255),password varchar(255))";
db.execSQL(sql);
}
//需要修改表结构时使用该方法
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
//升级数据库的回调
}
}
View Code

Dao.java


package com.androidlearing.tdtreehole.database;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.util.Log;
/**
* @ProjectName: TDTreeHole
* @Package: com.androidlearing.tdtreehole.database
* @ClassName: Dao
* @Description: java类作用描述
* @Author: 武神酱丶
* @CreateDate: 2020/4/23 16:49
* @UpdateUser: 更新者
* @UpdateDate: 2020/4/23 16:49
* @UpdateRemark: 更新说明
* @Version: 1.0
*/
public class Dao {
private static final String TAG ="Dao" ;
private final DataBaseHelper mHelper;
private static final String DATA_BASE_NAME = "user";
//创建数据库
public Dao(Context context){
mHelper = new DataBaseHelper(context);
}
//插入数据
public void insert(int id,String username,String password){
SQLiteDatabase db = mHelper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("id",id);
values.put("username",username);
values.put("password",password);
db.insert(DATA_BASE_NAME,null,values);
db.close();
}
//查询数据
public int select(){
SQLiteDatabase db = mHelper.getWritableDatabase();
int userid = 0;
Cursor cursor = db.query(DATA_BASE_NAME,null,null,null,null,null,null);
while (cursor.moveToNext()){
userid = cursor.getInt(cursor.getColumnIndex("id"));
}
cursor.close();
db.close();
return userid;
}
//删除数据
public void delete(){
SQLiteDatabase db = mHelper.getWritableDatabase();
db.delete(DATA_BASE_NAME,null,null);
db.close();
}
}
View Code

LunchActivity.java


package com.androidlearing.tdtreehole.activity;
import android.content.Intent;
import android.os.Bundle;
import androidx.appcompat.app.AppCompatActivity;
import com.androidlearing.tdtreehole.database.Dao;
import com.androidlearing.tdtreehole.database.DataBaseHelper;
import static java.lang.Thread.sleep;
public class LunchActivity extends AppCompatActivity {
private DataBaseHelper mDatabaseHelper;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate( savedInstanceState );
//app启动页的加载
new Thread( new Runnable( ) {
@Override
public void run() {
//耗时任务,比如加载网络数据
runOnUiThread(new Runnable() {
@Override
public void run() {
// 这里可以睡几秒钟,如果要放广告的话
try {
sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
});
}
} ).start();
//初始化用户的登录状态
initState();
}
private void initState() {
Dao dao = new Dao(this);
//查询数据,如果数据库中有数据,跳转至MainActivity
if (dao.select()!=0){
Intent intent = new Intent(LunchActivity.this, MainActivity.class);
intent.putExtra("idKey",dao.select());
startActivity(intent);
LunchActivity.this.finish();
}
//如果没有查询到数据,跳转至LoginActivity
else {
Intent intent = new Intent(LunchActivity.this, LoginActivity.class);
startActivity(intent);
LunchActivity.this.finish();
}
}
}
View Code

四、今日团队链接

https://www.cnblogs.com/three3/p/12763763.html



推荐阅读
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • Android源码深入理解JNI技术的概述和应用
    本文介绍了Android源码中的JNI技术,包括概述和应用。JNI是Java Native Interface的缩写,是一种技术,可以实现Java程序调用Native语言写的函数,以及Native程序调用Java层的函数。在Android平台上,JNI充当了连接Java世界和Native世界的桥梁。本文通过分析Android源码中的相关文件和位置,深入探讨了JNI技术在Android开发中的重要性和应用场景。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文介绍了Java高并发程序设计中线程安全的概念与synchronized关键字的使用。通过一个计数器的例子,演示了多线程同时对变量进行累加操作时可能出现的问题。最终值会小于预期的原因是因为两个线程同时对变量进行写入时,其中一个线程的结果会覆盖另一个线程的结果。为了解决这个问题,可以使用synchronized关键字来保证线程安全。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
author-avatar
洪凤兴惠婷
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有