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

news2024/11/26 2:38:30

步骤 1: 登录页面布局

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

<!-- activity_main.xml -->
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:padding="16dp">

    <EditText
        android:id="@+id/editTextUsername"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="用户名" />

    <EditText
        android:id="@+id/editTextPassword"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="密码"
        android:inputType="textPassword" />

    <Button
        android: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 -->
<ListView
    xmlns: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;

    @Override
    protected 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将商品数据绑定到ListView
        ArrayAdapter<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;

    @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);

        buttonLogin.setOnClickListener(new View.OnClickListener() {
            @Override
            public 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;

    @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();

        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);
    }

}

实现效果
请添加图片描述
存储到虚拟机文件中的内容——/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;

    @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);

        sharedPreferences = getSharedPreferences("MyAppPrefs", MODE_PRIVATE);

        tryAutoLogin();

        buttonLogin.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                String username = editTextUsername.getText().toString();
                String password = editTextPassword.getText().toString();

                if (isValidCredentials(username, password)) {
                    // 登录成功,保存用户名和密码到SharedPreferences
                    saveCredentials(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;

    @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);

        sharedPreferences = getSharedPreferences("MyAppPrefs", MODE_PRIVATE);

        tryAutoLogin();

        buttonLogin.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                String username = editTextUsername.getText().toString();
                String password = editTextPassword.getText().toString();

                if (isValidCredentials(username, password)) {
                    // 登录成功,保存用户名和密码到SharedPreferences
                    saveCredentials(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.coloradmin.cn/o/1070827.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Tomcat服务器下载、安装、配置环境变量教程(超详细)

请先配置安装好Java的环境&#xff0c;若没有安装&#xff0c;请参照如下博客上的步骤进行安装&#xff01; 安装Java环境教程Windows配置Java环境变量(下载、安装、配置环境)_第三女神程忆难的博客-CSDN博客 Tomcat部署Web项目&#xff08;一&#xff09;内嵌 Tomcat部署网站…

Java基于SpringBoot的社区维修平台

文章目录 简介环境需要住户前台功能模块管理员功能模块住户后台功能模块维修员后台功能模块源码咨询 简介 系统管理也都将通过计算机进行整体智能化操作,对于社区维修平台所牵扯的管理及数据保存都是非常多的,例如住户管理、社区公告管理、维修工管理、维修订单管理、接单信息…

STM32H723加上ThreadX,时钟不准确

硬件用的晶振是8MHz 的&#xff0c;默认这里是25&#xff0c;需要改为8&#xff0c;然后主频用400MHz 其他的&#xff1a; tx_thread_sleep(1000); //延时就是1秒了

【java问题排查方法】

文章目录 一、内存泄漏排查方案 一、内存泄漏排查方案 jmap是Java JDK提供的一个命令行工具&#xff0c;用于生成Java虚拟机的堆转储快照dump文件&#xff0c;它可以帮助开发者查看Java堆的内存使用情况&#xff0c;诊断内存泄漏和其他内存问题。 要使用jmap&#xff0c;需要…

tcpdump(五)命令行参数讲解(四)

一 案例讲解 tcpdump官方参考文档 最全的tcpdump手册 强调&#xff1a; -nn 选项一般是must 必选 ① 现场分析并保留现场信息 tcpdump -l | tee dat 使用tee来把tcpdump的输出同时放到文件dat和标准输出中场景&#xff1a; 自己现场分析同时把现场信息保留下来 ② …

tcpdump(四)命令行参数讲解(三)

一 BPF高级过滤条件 高级filter官方地址 常见需求案例汇总 过滤的目的&#xff1a;获取最精细、准确的数据思考&#xff1a; 抓取更精确的包?1) tcp/ip 报文结构要精通,这样才能知道如何获取自己想要的信息 -> 偏移量2) tcpdump 的synax语法要精通,要正确写对3) 多练习…

应用超高频RFID技术的银行款箱柜资产管理系统

背景概述 随着银行后台管理的集中化思路&#xff0c;对款箱的管理需要实现“安全、高效”的“管、控、营”一体化&#xff0c;传统的人工款箱管理模式和数据采集方式已无法满足银行管理的快速、准确要求&#xff0c;严重影响了银行整体运行效率。 传统的款箱管理存在以下问题…

【管理运筹学】第 9 章 | 网络计划(1,网络图的组成及绘制)

文章目录 引言一、网络图的组成及绘制1.1 网络图的组成1. 基本要素2. 线路与关键线路3. 网络图的类型 1.2 网络图的绘制1. 画图原则2. 绘图一般步骤 写在最后 引言 大纲里关于网络计划这一章的描述&#xff0c;就两个&#xff0c;一个是基本概念&#xff1a;网络计划、时间参数…

Zabbix监控系统与部署Zabbix6.0监控(系列操作完整版)

目录 Zabbix 6.0 1 zabbix 是什么 1.1 zabbix 监控原理 1.2 Zabbix 6.0 新特性 1.3 Zabbix 6.0 功能组件 2 Zabbix 6.0 部署 2.1 部署 zabbix 服务端 2.1.1 部署 Nginx PHP 环境并测试 2.1.2 部署数据库&#xff0c;要求 MySQL 5.7 或 Mariadb 10.5 及以上版本 2.1.3…

项目_数据可视化| 折线图.散点图.随机漫步

安装matplotlib 在正式开始编写程序之前&#xff0c;需要先安装pip、matplotlib模块&#xff0c;苹果系统的安装问题在之前的文章中有相关介绍内容&#xff0c;如果pycharm运行模块报错&#xff0c;可以再次检查是否版本兼容问题。 绘制折线图 调用subplot&#xff08;&#x…

Java代码hello word

一、安装java环境 开始学习java之前&#xff0c;我们的第一步就是安装java环境&#xff0c;即常说的JDK和JRE&#xff0c;此处就不在详细介绍配置环境过程&#xff0c;可以到网上搜索java开发环境配置。 二、编写第一个程序 工具&#xff1a; 常用的java编写工具有IDE、Notep…

数据结构与算法(五):树

参考引用 Hello 算法 Github&#xff1a;hello-algo 1. 二叉树 二叉树&#xff08;binary tree&#xff09;是一种非线性数据结构&#xff0c;代表着祖先与后代之间的派生关系&#xff0c;体现着“一分为二”的分治逻辑 与链表类似&#xff0c;二叉树的基本单元是节点&#xff…

【Qt】顶层窗口和普通窗口区别以及用法

区别 在Qt项目开发中&#xff0c;经常会用到窗体控件用于显示及数据操作和其他交互等。 但&#xff0c;窗体分为顶层窗口&#xff08;Top-level Window&#xff09;和普通窗口&#xff08;Regular Window&#xff09;。 他们之间是有区别的&#xff0c;包括在项目实际中的用法…

【Vue面试题十一】、Vue组件之间的通信方式都有哪些?

文章底部有个人公众号&#xff1a;热爱技术的小郑。主要分享开发知识、学习资料、毕业设计指导等。有兴趣的可以关注一下。为何分享&#xff1f; 踩过的坑没必要让别人在再踩&#xff0c;自己复盘也能加深记忆。利己利人、所谓双赢。 面试官&#xff1a;Vue组件之间的通信方式都…

学习网络编程No.7【应用层之序列化和反序列化】

引言&#xff1a; 北京时间&#xff1a;2023/9/14/19:13&#xff0c;下午刚刚更完文章&#xff0c;是一篇很久很久以前的文章&#xff0c;由于各种原因&#xff0c;留到了今天更新&#xff0c;非常惭愧呀&#xff01;目前在上学校开的一门网络课程&#xff0c;学校的课听不了一…

leetCode 1143.最长公共子序列 动态规划

1143. 最长公共子序列 - 力扣&#xff08;LeetCode&#xff09; 给定两个字符串 text1 和 text2&#xff0c;返回这两个字符串的最长 公共子序列 的长度。如果不存在 公共子序列 &#xff0c;返回 0 。 一个字符串的 子序列 是指这样一个新的字符串&#xff1a;它是由原字符串…

Linux登录自动执行脚本

一、所有用户每次登录时自动执行。 1、在/etc/profile文件末尾添加。 将启动命令添加到/etc/profile文件末尾。 2、在/etc/profile.d/目录下添加sh脚本。 在/etc/profile.d/目录下新建sh脚本&#xff0c;设置每次登录自动执行脚本。有用户登录时&#xff0c;/etc/profile会遍…

一文带你读懂残差网络ResNet

&#x1f680; 作者 &#xff1a;“码上有钱” &#x1f680; 文章简介 &#xff1a;AI-残差算法 &#x1f680; 欢迎小伙伴们 点赞&#x1f44d;、收藏⭐、留言&#x1f4ac;简介 残差网络&#xff08;Residual Neural Network, ResNet&#xff09;是深度神经网络的一种。它通…

2.1 关系数据结构及形式化定义

思维导图&#xff1a; 2.1.1 关系 笔记&#xff1a; 关系数据库模型是一个简单但强大的方式来表示数据及其之间的关系。下面是这节的关键内容&#xff1a; - **关系模型核心概念** * 关系数据模型的核心是“关系”&#xff0c;它在逻辑上表现为一个二维表。 * 此表中&a…

Cesium问题——在使用贴图的方式加载图片时并未加载出来

文章目录 问题分析问题 Cesium在使用贴图的方式加载图片失败 分析 如果在Cesium中加载图片时,控制台显示成功(200状态码),但是预览显示却失败了,可能有以下几个原因: 图片格式不受支持:Cesium中通常支持常见的图片格式,如JPEG、PNG等。确保你使用的图片格式在Cesium中…