Android用户登录与数据存储:从权限请求到内外部存储的完整实践【完整实践步骤、外部存储、内部存储】

步骤 1: 登录页面布局

MainActivity 中实现用户登录功能,首先创建一个布局文件 activity_main.xml 包含用户名和密码的输入字段以及登录按钮。

<!-- activity_main.xml -->
<LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"android:padding="16dp"><EditTextandroid:id="@+id/editTextUsername"android:layout_width="match_parent"android:layout_height="wrap_content"android:hint="用户名" /><EditTextandroid:id="@+id/editTextPassword"android:layout_width="match_parent"android:layout_height="wrap_content"android:hint="密码"android:inputType="textPassword" /><Buttonandroid:id="@+id/buttonLogin"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="登录" /></LinearLayout>

实现效果
在这里插入图片描述

步骤 2:商品列表页面布局

在Android Studio中,右键点击项目的app目录,选择“New” > “Activity” > “Empty Activity”。
在这里插入图片描述

布局文件 activity_product_list.xml 用于显示商品列表。

<!-- activity_product_list.xml -->
<ListViewxmlns:android="http://schemas.android.com/apk/res/android"android:id="@+id/listViewProducts"android:layout_width="match_parent"android:layout_height="match_parent" />

实现效果
在这里插入图片描述

然后,在 ProductListActivity.java 中加载商品数据并显示在 ListView 中。

import android.os.Bundle;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import androidx.appcompat.app.AppCompatActivity;public class ProductListActivity extends AppCompatActivity {private ListView listViewProducts;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_product_list);listViewProducts = findViewById(R.id.listViewProducts);// 在这里获取商品数据,可以从网络或本地获取// 假设你有一个商品列表的字符串数组String[] products = {"商品1", "商品2", "商品3", "商品4"};// 使用ArrayAdapter将商品数据绑定到ListViewArrayAdapter<String> adapter = new ArrayAdapter<>(this,android.R.layout.simple_list_item_1, products);listViewProducts.setAdapter(adapter);}
}

步骤 3:实现登录功能

然后在 MainActivity.java 中处理登录逻辑,验证用户名和密码是否正确。在成功登录后,跳转到商品列表页面。

package com.leo.login_filestore;import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import androidx.appcompat.app.AppCompatActivity;
import android.widget.Toast;public class MainActivity extends AppCompatActivity {private EditText editTextUsername;private EditText editTextPassword;private Button buttonLogin;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);editTextUsername = findViewById(R.id.editTextUsername);editTextPassword = findViewById(R.id.editTextPassword);buttonLogin = findViewById(R.id.buttonLogin);buttonLogin.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {// 在这里验证用户名和密码是否正确String username = editTextUsername.getText().toString();String password = editTextPassword.getText().toString();if (isValidCredentials(username, password)) {// 登录成功,跳转到商品列表页面startActivity(new Intent(MainActivity.this, ProductListActivity.class));} else {// 登录失败,显示错误消息Toast.makeText(MainActivity.this, "登录失败,用户名或密码不正确", Toast.LENGTH_SHORT).show();}}});}private boolean isValidCredentials(String username, String password) {// 在这里实现验证逻辑,比较输入的用户名和密码是否正确// 这里可以将用户名和密码写在代码中或从其他数据源获取// 用户名和密码硬编码在代码中,用于演示String validUsername = "user";String validPassword = "password";// 比较输入的用户名和密码与有效的用户名和密码是否匹配return username.equals(validUsername) && password.equals(validPassword);}}

实现效果
user

步骤 4:请求外部存储权限

要请求外部存储权限,你需要在 AndroidManifest.xml 中添加权限声明。

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" tools:ignore="WrongManifestParent" />

在这里插入图片描述

步骤 5:编写SaveUtil类用于保存数据到外部存储上的文件

创建一个 SaveUtil.java 类来处理数据保存到外部存储的逻辑。

使用 Environment.getExternalStorageDirectory() 来获取外部存储的根目录,然后创建一个文件并将数据写入其中。这将使你的代码更加灵活,因为它动态获取了外部存储的路径,而不是硬编码路径。请确保在使用外部存储时处理好权限问题。

package com.leo.login_filestore;import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;import android.os.Environment;public class SaveUtil {public static boolean saveDataToExternalStorage(String filename, String data) {// 在这里实现数据保存到外部存储的逻辑// 注意要处理异常情况try {// 获取外部存储根目录File root = Environment.getExternalStorageDirectory();// 创建要保存的文件File file = new File(root, filename);// 创建文件输出流FileOutputStream fos = new FileOutputStream(file);// 写入数据fos.write(data.getBytes());// 关闭文件输出流fos.close();return true;} catch (IOException e) {e.printStackTrace();return false;}}
}

步骤 6: 在MainActivity中调用SaveUtil类实现保存用户名和密码

在登录成功后,调用 SaveUtil 类保存用户名和密码到外部存储。这里我们使用模拟数据,实际情况下应该更加安全地保存密码。

存储的默认目录:/storage/emulated/0/你的文件

// 登录成功后
if (isValidCredentials(username, password)) {// 保存用户名和密码到外部存储boolean saved = SaveUtil.saveDataToExternalStorage("credentials.txt", username + "," + password);if (saved) {// 跳转到商品列表页面startActivity(new Intent(MainActivity.this, ProductListActivity.class));} else {// 处理保存失败的情况}
}

步骤 7:在 MainActivity 中请求权限保存代码

还需要在 MainActivity 中请求权限。通常,这会在应用的运行时动态请求。
完整代码

package com.leo.login_filestore;import android.content.Intent;
import android.content.pm.PackageManager;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;import android.Manifest;import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;
import androidx.core.content.ContextCompat;
import android.widget.Toast;public class MainActivity extends AppCompatActivity {private static final int PERMISSION_REQUEST_CODE = 1;private EditText editTextUsername;private EditText editTextPassword;private  String username;private  String password;private Button buttonLogin;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);editTextUsername = findViewById(R.id.editTextUsername);editTextPassword = findViewById(R.id.editTextPassword);buttonLogin = findViewById(R.id.buttonLogin);// 请求外部存储权限requestStoragePermission();buttonLogin.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {// 在这里验证用户名和密码是否正确username = editTextUsername.getText().toString();password = editTextPassword.getText().toString();if (isValidCredentials(username, password)) {// 登录成功,跳转到商品列表页面startActivity(new Intent(MainActivity.this, ProductListActivity.class));saveDataToExternalStorage();} else {// 登录失败,显示错误消息Toast.makeText(MainActivity.this, "登录失败,用户名或密码不正确", Toast.LENGTH_SHORT).show();}}});}private void requestStoragePermission() {if (ContextCompat.checkSelfPermission(this, Manifest.permission.WRITE_EXTERNAL_STORAGE)!= PackageManager.PERMISSION_GRANTED) {// 请求权限ActivityCompat.requestPermissions(this,new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},PERMISSION_REQUEST_CODE);}}private void saveDataToExternalStorage() {System.out.println(username + "," + password);// 可以使用FileOutputStream等方式boolean saved = SaveUtil.saveDataToExternalStorage("credentials.txt", username + "," + password);}private boolean isValidCredentials(String username, String password) {// 在这里实现验证逻辑,比较输入的用户名和密码是否正确// 这里可以将用户名和密码写在代码中或从其他数据源获取// 用户名和密码硬编码在代码中,用于演示String validUsername = "user";String validPassword = "password";// 比较输入的用户名和密码与有效的用户名和密码是否匹配return username.equals(validUsername) && password.equals(validPassword);}}

实现效果
请添加图片描述
存储到虚拟机文件中的内容——/storage/emulated/0/credentials.txt
在这里插入图片描述

步骤 8:尝试自动登录

当前我们已经实现了保存用户名和密码到外部存储的逻辑。接下来,需要修改 MainActivity,在启动应用时尝试读取 credentials.txt 文件中的用户名和密码,并实现自动登录。

private static final String CREDENTIALS_FILE = "credentials.txt";@Override
protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);// ...// 尝试自动登录tryAutoLogin();
}private void tryAutoLogin() {String savedCredentials = readDataFromExternalStorage(CREDENTIALS_FILE);if (savedCredentials != null) {String[] parts = savedCredentials.split(",");if (parts.length == 2) {String savedUsername = parts[0];String savedPassword = parts[1];// 检查保存的用户名和密码是否与有效凭据匹配if (isValidCredentials(savedUsername, savedPassword)) {// 自动登录成功,跳转到商品列表页面startActivity(new Intent(MainActivity.this, ProductListActivity.class));}}}
}private String readDataFromExternalStorage(String filename) {try {File root = Environment.getExternalStorageDirectory();File file = new File(root, filename);if (file.exists()) {FileInputStream fis = new FileInputStream(file);InputStreamReader isr = new InputStreamReader(fis);BufferedReader bufferedReader = new BufferedReader(isr);StringBuilder sb = new StringBuilder();String line;while ((line = bufferedReader.readLine()) != null) {sb.append(line);}bufferedReader.close();return sb.toString();}} catch (IOException e) {e.printStackTrace();}return null;
}

上述代码在 onCreate 中调用了 tryAutoLogin 方法,该方法会尝试从 credentials.txt 文件中读取保存的用户名和密码,然后检查它们是否与有效凭据匹配。如果匹配成功,它将执行自动登录并跳转到商品列表页面。

请确保在 AndroidManifest.xml 中添加适当的权限声明以及在 Android 11 及更高版本上正确处理存储权限。

实现自动登录效果
请添加图片描述

步骤 9: 使用内部存储文件和SharedPreferences实现自动登录功能

我们使用SharedPreferences来保存和检索用户名和密码。tryAutoLogin 方法尝试从SharedPreferences中获取保存的凭据,并自动登录用户,如果凭据存在并有效的话。

确保在 ProductListActivity 中实现商品列表的显示,这部分代码应该保持不变。

代码如下:

import android.content.Intent;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import androidx.appcompat.app.AppCompatActivity;public class MainActivity extends AppCompatActivity {private EditText editTextUsername;private EditText editTextPassword;private Button buttonLogin;private SharedPreferences sharedPreferences;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);editTextUsername = findViewById(R.id.editTextUsername);editTextPassword = findViewById(R.id.editTextPassword);buttonLogin = findViewById(R.id.buttonLogin);sharedPreferences = getSharedPreferences("MyAppPrefs", MODE_PRIVATE);tryAutoLogin();buttonLogin.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {String username = editTextUsername.getText().toString();String password = editTextPassword.getText().toString();if (isValidCredentials(username, password)) {// 登录成功,保存用户名和密码到SharedPreferencessaveCredentials(username, password);// 跳转到商品列表页面startActivity(new Intent(MainActivity.this, ProductListActivity.class));} else {// 登录失败,显示错误消息Toast.makeText(MainActivity.this, "登录失败,用户名或密码不正确", Toast.LENGTH_SHORT).show();}}});}private void tryAutoLogin() {String savedUsername = sharedPreferences.getString("username", "");String savedPassword = sharedPreferences.getString("password", "");if (!savedUsername.isEmpty() && !savedPassword.isEmpty()) {// 自动登录成功,跳转到商品列表页面startActivity(new Intent(MainActivity.this, ProductListActivity.class));}}private void saveCredentials(String username, String password) {SharedPreferences.Editor editor = sharedPreferences.edit();editor.putString("username", username);editor.putString("password", password);editor.apply();}private boolean isValidCredentials(String username, String password) {// 在这里实现验证逻辑,比较输入的用户名和密码是否正确// 这里可以将用户名和密码写在代码中或从其他数据源获取// 示例:用户名和密码硬编码在代码中,用于演示String validUsername = "user";String validPassword = "password";// 比较输入的用户名和密码与有效的用户名和密码是否匹配return username.equals(validUsername) && password.equals(validPassword);}
}

MainActivity完整代码

package com.leo.login_filestore;
/** 使用内部存储文件和SharedPreferences实现自动登录功能 **/
import android.content.Intent;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import androidx.appcompat.app.AppCompatActivity;public class MainActivity extends AppCompatActivity {private EditText editTextUsername;private EditText editTextPassword;private Button buttonLogin;private SharedPreferences sharedPreferences;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);editTextUsername = findViewById(R.id.editTextUsername);editTextPassword = findViewById(R.id.editTextPassword);buttonLogin = findViewById(R.id.buttonLogin);sharedPreferences = getSharedPreferences("MyAppPrefs", MODE_PRIVATE);tryAutoLogin();buttonLogin.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {String username = editTextUsername.getText().toString();String password = editTextPassword.getText().toString();if (isValidCredentials(username, password)) {// 登录成功,保存用户名和密码到SharedPreferencessaveCredentials(username, password);// 跳转到商品列表页面startActivity(new Intent(MainActivity.this, ProductListActivity.class));} else {// 登录失败,显示错误消息Toast.makeText(MainActivity.this, "登录失败,用户名或密码不正确", Toast.LENGTH_SHORT).show();}}});}private void tryAutoLogin() {String savedUsername = sharedPreferences.getString("username", "");String savedPassword = sharedPreferences.getString("password", "");if (!savedUsername.isEmpty() && !savedPassword.isEmpty()) {// 自动登录成功,跳转到商品列表页面startActivity(new Intent(MainActivity.this, ProductListActivity.class));}}private void saveCredentials(String username, String password) {SharedPreferences.Editor editor = sharedPreferences.edit();editor.putString("username", username);editor.putString("password", password);editor.apply();}private boolean isValidCredentials(String username, String password) {// 在这里实现验证逻辑,比较输入的用户名和密码是否正确// 这里可以将用户名和密码写在代码中或从其他数据源获取// 示例:用户名和密码硬编码在代码中,用于演示String validUsername = "user";String validPassword = "password";// 比较输入的用户名和密码与有效的用户名和密码是否匹配return username.equals(validUsername) && password.equals(validPassword);}
}/** # 外部存储实现自动登录 **/
//
//import android.content.Intent;
//import android.content.pm.PackageManager;
//import android.os.Bundle;
//import android.os.Environment;
//import android.view.View;
//import android.widget.Button;
//import android.widget.EditText;
//
//import android.Manifest;
//
//import androidx.annotation.NonNull;
//import androidx.appcompat.app.AppCompatActivity;
//import androidx.core.app.ActivityCompat;
//import androidx.core.content.ContextCompat;
//import android.widget.Toast;
//
//import java.io.BufferedReader;
//import java.io.File;
//import java.io.FileInputStream;
//import java.io.IOException;
//import java.io.InputStreamReader;
//
//public class MainActivity extends AppCompatActivity {
//    private static final int PERMISSION_REQUEST_CODE = 1;
//    private static final String CREDENTIALS_FILE = "credentials.txt";
//
//
//    private EditText editTextUsername;
//    private EditText editTextPassword;
//
//    private  String username;
//    private  String password;
//
//    private Button buttonLogin;
//
//    @Override
//    protected void onCreate(Bundle savedInstanceState) {
//        super.onCreate(savedInstanceState);
//        setContentView(R.layout.activity_main);
//
//        editTextUsername = findViewById(R.id.editTextUsername);
//        editTextPassword = findViewById(R.id.editTextPassword);
//        buttonLogin = findViewById(R.id.buttonLogin);
//        // 请求外部存储权限
//        requestStoragePermission();
//
//        tryAutoLogin();
//
//        buttonLogin.setOnClickListener(new View.OnClickListener() {
//            @Override
//            public void onClick(View v) {
//
//                // 在这里验证用户名和密码是否正确
//                username = editTextUsername.getText().toString();
//                password = editTextPassword.getText().toString();
//
//                if (isValidCredentials(username, password)) {
//                    // 登录成功,跳转到商品列表页面
//                    startActivity(new Intent(MainActivity.this, ProductListActivity.class));
//                    saveDataToExternalStorage();
//                } else {
//                    // 登录失败,显示错误消息
//                    Toast.makeText(MainActivity.this, "登录失败,用户名或密码不正确", Toast.LENGTH_SHORT).show();
//                }
//            }
//        });
//    }
//    private void requestStoragePermission() {
//
//        if (ContextCompat.checkSelfPermission(this, Manifest.permission.WRITE_EXTERNAL_STORAGE)
//                != PackageManager.PERMISSION_GRANTED) {
//            // 请求权限
//            ActivityCompat.requestPermissions(this,
//                    new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},
//                    PERMISSION_REQUEST_CODE);
//        }
//    }
//
//    private void saveDataToExternalStorage() {
//        System.out.println(username + "," + password);
//        // 可以使用FileOutputStream等方式
//        boolean saved = SaveUtil.saveDataToExternalStorage("credentials.txt", username + "," + password);
//
//    }
//
//    private boolean isValidCredentials(String username, String password) {
//        // 在这里实现验证逻辑,比较输入的用户名和密码是否正确
//        // 这里可以将用户名和密码写在代码中或从其他数据源获取
//
//        // 用户名和密码硬编码在代码中,用于演示
//        String validUsername = "user";
//        String validPassword = "password";
//
//        // 比较输入的用户名和密码与有效的用户名和密码是否匹配
//        return username.equals(validUsername) && password.equals(validPassword);
//    }
//
//    private void tryAutoLogin() {
//        String savedCredentials = readDataFromExternalStorage(CREDENTIALS_FILE);
//        if (savedCredentials != null) {
//            String[] parts = savedCredentials.split(",");
//            if (parts.length == 2) {
//                String savedUsername = parts[0];
//                String savedPassword = parts[1];
//
//                // 检查保存的用户名和密码是否与有效凭据匹配
//                if (isValidCredentials(savedUsername, savedPassword)) {
//                    // 自动登录成功,跳转到商品列表页面
//                    startActivity(new Intent(MainActivity.this, ProductListActivity.class));
//                }
//            }
//        }
//    }
//
//    private String readDataFromExternalStorage(String filename) {
//        try {
//            File root = Environment.getExternalStorageDirectory();
//            File file = new File(root, filename);
//
//            if (file.exists()) {
//                FileInputStream fis = new FileInputStream(file);
//                InputStreamReader isr = new InputStreamReader(fis);
//                BufferedReader bufferedReader = new BufferedReader(isr);
//
//                StringBuilder sb = new StringBuilder();
//                String line;
//                while ((line = bufferedReader.readLine()) != null) {
//                    sb.append(line);
//                }
//
//                bufferedReader.close();
//                return sb.toString();
//            }
//        } catch (IOException e) {
//            e.printStackTrace();
//        }
//
//        return null;
//    }
//
//}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/128962.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Java题】模拟下载进度条

目录 一&#xff1a;题目 二&#xff1a;解析 1.匿名内部类 2.lambda 三&#xff1a;结果 一&#xff1a;题目 使用匿名内部类&#xff0c;模拟下载过程进度条&#xff0c;体会回调函数的作用。 1. 定义 DownloadListener 接口&#xff0c;包含一个包含 void progressU…

基于vue框架的uniapp小程序开发发现了新大陆

项目场景&#xff1a; 在基于vue框架的uniapp小程序开发中&#xff0c;在页面跳转时&#xff0c;当前页路径带参数&#xff0c;在跳转页中接受数据除了用官方推荐的保留当前页面&#xff0c;跳转到应用内的某个页面&#xff0c;使用onLoad(option)接受数据&#xff0c;但是我发…

webpack不同环境下使用CSS分离插件mini-css-extract-plugin

1.背景描述 使用mini-css-extract-plugin插件来打包css文件&#xff08;从css文件中提取css代码到单独的文件中&#xff0c;对css代码进行代码压缩等&#xff09;。 本次采用三个配置文件&#xff1a; 公共配置文件&#xff1a;webpack.common.jsdev开发环境配置文件&#x…

IDEA 2021.2.2设置自动热部署

1.导入包坐标 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><scope>runtime</scope><optional>true</optional></dependency> 2.pom.xml添加piugins插…

Git 学习笔记 | Git 项目创建及克隆

Git 学习笔记 | Git 项目创建及克隆 Git 学习笔记 | Git 项目创建及克隆创建工作目录与常用指令本地仓库搭建克隆远程仓库 Git 学习笔记 | Git 项目创建及克隆 创建工作目录与常用指令 工作目录&#xff08;WorkSpace)一般就是你希望Git帮助你管理的文件夹&#xff0c;可以是…

详细介绍区块链之挖矿

对不起&#xff0c;大家&#xff0c;这篇文章对作者来说实在是太有意义和含金量了&#xff0c;作者想把它设置为关注博主才能见全文&#xff0c;请大家理解&#xff01;如果觉得还是看不懂&#xff0c;抱歉耽误大家的时间&#xff0c;就请取消关注&#xff01;&#xff01;&…

分类预测 | MATLAB实现KOA-CNN开普勒算法优化卷积神经网络数据分类预测

分类预测 | MATLAB实现KOA-CNN开普勒算法优化卷积神经网络数据分类预测 目录 分类预测 | MATLAB实现KOA-CNN开普勒算法优化卷积神经网络数据分类预测分类效果基本描述程序设计参考资料 分类效果 基本描述 1.MATLAB实现KOA-CNN开普勒算法优化卷积神经网络数据分类预测&#xff0…

.NET ABP.Zero 项目疑似内存排查历程

当前项目是 .NET 5 EentityFrameworkCore&#xff0c;疑似内存泄漏&#xff0c;之所以说是疑似是因为到目前位置还没有能准确的定位到问题。当前这个框架从 .NET Core 2.1 就开始用&#xff0c;期间有升级到 3.1、5.0、6.0&#xff0c;在排查过程中还把 5.0 分支升级到了 7.0 。…

Vue3 + Ts实现NPM插件 - 定制loading

目录 你的 Loading&#x1f916; 安装&#x1f6f9; 简介苍白请 您移步文档&#xff1a;✈️ 使用方法&#x1f6e0;️ 配置 loading 类型&#x1f3b2; 定制 loading 色彩 &#x1f4a1; 注意事项 前期回顾 你的 Loading 开箱即可用的 loading&#xff0c; 说明&#xff1a;vu…

springboot项目做成公共项目

一&#xff1a;引言 最近碰到个需求&#xff0c;就是把我项目做成一个公共的提供jar包给别人使用&#xff0c;我也是捣鼓了一段时间去研究这个问题&#xff0c;这个东西其实就是A 项目提供jar包给B项目&#xff0c;B项目只要引入A项目的jar包就可以使用A项目的功能。 问题一&…

基于Springboot实现学生毕业离校系统项目【项目源码+论文说明】分享

基于Springboot实现学生毕业离校系统演示 摘要 随着科学技术的飞速发展&#xff0c;社会的方方面面、各行各业都在努力与现代的先进技术接轨&#xff0c;通过科技手段来提高自身的优势&#xff0c;新生宿舍管理系统当然也不能排除在外。新生宿舍管理系统是以实际运用为开发背景…

java Spring Boot在配置文件中关闭热部署

之前更大家一起搭建了一个热部署的开发环境 但是 大家要清楚一个情况 我们线上程序运行突然内部发生变化这是不可能的。 所以 他就只会对我们开发环境有效 是否开启 我们可以通过 application配置文件来完成 我这里是yml格式的 参考代码如下 spring:devtools:restart:enabled…