parent
5d2fcf0b35
commit
ac0941b13f
@ -1,149 +1,149 @@
|
|||||||
package com.example.mathsystemtogether;
|
package com.example.mathsystemtogether;
|
||||||
|
|
||||||
import javafx.fxml.FXML;
|
import javafx.fxml.FXML;
|
||||||
import javafx.fxml.FXMLLoader;
|
import javafx.fxml.FXMLLoader;
|
||||||
import javafx.scene.Scene;
|
import javafx.scene.Scene;
|
||||||
import javafx.scene.control.*;
|
import javafx.scene.control.*;
|
||||||
import javafx.stage.Stage;
|
import javafx.stage.Stage;
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
import java.nio.file.Paths;
|
import java.nio.file.Paths;
|
||||||
import java.nio.file.StandardOpenOption;
|
import java.nio.file.StandardOpenOption;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class ChangePasswordController {
|
public class ChangePasswordController {
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
private TextField usernameField;
|
private TextField usernameField;
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
private PasswordField oldPasswordField;
|
private PasswordField oldPasswordField;
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
private PasswordField newPasswordField;
|
private PasswordField newPasswordField;
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
private PasswordField confirmNewPasswordField;
|
private PasswordField confirmNewPasswordField;
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
private Button changePasswordButton;
|
private Button changePasswordButton;
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
private Button cancelButton;
|
private Button cancelButton;
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
private Label statusLabel;
|
private Label statusLabel;
|
||||||
|
|
||||||
private String currentUser;
|
private String currentUser;
|
||||||
private ExamController examController;
|
private ExamController examController;
|
||||||
private static final String USER_DATA_FILE = "user_data.txt";
|
private static final String USER_DATA_FILE = "user_data.txt";
|
||||||
|
|
||||||
public void setCurrentUser(String username) {
|
public void setCurrentUser(String username) {
|
||||||
this.currentUser = username;
|
this.currentUser = username;
|
||||||
usernameField.setText(username);
|
usernameField.setText(username);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setExamController(ExamController examController) {
|
public void setExamController(ExamController examController) {
|
||||||
this.examController = examController;
|
this.examController = examController;
|
||||||
}
|
}
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
private void handleChangePassword() {
|
private void handleChangePassword() {
|
||||||
String oldPassword = oldPasswordField.getText();
|
String oldPassword = oldPasswordField.getText();
|
||||||
String newPassword = newPasswordField.getText();
|
String newPassword = newPasswordField.getText();
|
||||||
String confirmNewPassword = confirmNewPasswordField.getText();
|
String confirmNewPassword = confirmNewPasswordField.getText();
|
||||||
|
|
||||||
if (oldPassword.isEmpty() || newPassword.isEmpty() || confirmNewPassword.isEmpty()) {
|
if (oldPassword.isEmpty() || newPassword.isEmpty() || confirmNewPassword.isEmpty()) {
|
||||||
showStatus("请填写所有字段", true);
|
showStatus("请填写所有字段", true);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!examController.checkUserPassword(currentUser, oldPassword)) {
|
if (!examController.checkUserPassword(currentUser, oldPassword)) {
|
||||||
showStatus("原密码错误", true);
|
showStatus("原密码错误", true);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (newPassword.length() < 6) {
|
if (newPassword.length() < 6) {
|
||||||
showStatus("新密码至少需要6个字符", true);
|
showStatus("新密码至少需要6个字符", true);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!newPassword.equals(confirmNewPassword)) {
|
if (!newPassword.equals(confirmNewPassword)) {
|
||||||
showStatus("两次输入的新密码不一致", true);
|
showStatus("两次输入的新密码不一致", true);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (oldPassword.equals(newPassword)) {
|
if (oldPassword.equals(newPassword)) {
|
||||||
showStatus("新密码不能与原密码相同", true);
|
showStatus("新密码不能与原密码相同", true);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (updatePassword(currentUser, newPassword)) {
|
if (updatePassword(currentUser, newPassword)) {
|
||||||
showStatus("密码修改成功!", false);
|
showStatus("密码修改成功!", false);
|
||||||
|
|
||||||
// 延迟关闭窗口
|
// 延迟关闭窗口
|
||||||
new java.util.Timer().schedule(
|
new java.util.Timer().schedule(
|
||||||
new java.util.TimerTask() {
|
new java.util.TimerTask() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
javafx.application.Platform.runLater(() -> {
|
javafx.application.Platform.runLater(() -> {
|
||||||
handleClose();
|
handleClose();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
1500
|
1500
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
showStatus("密码修改失败,请重试", true);
|
showStatus("密码修改失败,请重试", true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
private void handleCancel() {
|
private void handleCancel() {
|
||||||
handleClose();
|
handleClose();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void handleClose() {
|
private void handleClose() {
|
||||||
Stage stage = (Stage) cancelButton.getScene().getWindow();
|
Stage stage = (Stage) cancelButton.getScene().getWindow();
|
||||||
stage.close();
|
stage.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean updatePassword(String username, String newPassword) {
|
private boolean updatePassword(String username, String newPassword) {
|
||||||
try {
|
try {
|
||||||
// 读取所有用户数据
|
// 读取所有用户数据
|
||||||
List<String> lines = Files.readAllLines(Paths.get(USER_DATA_FILE));
|
List<String> lines = Files.readAllLines(Paths.get(USER_DATA_FILE));
|
||||||
boolean userFound = false;
|
boolean userFound = false;
|
||||||
|
|
||||||
for (int i = 0; i < lines.size(); i++) {
|
for (int i = 0; i < lines.size(); i++) {
|
||||||
String[] parts = lines.get(i).split("\\|");
|
String[] parts = lines.get(i).split("\\|");
|
||||||
if (parts.length >= 2 && parts[0].equals(username)) {
|
if (parts.length >= 2 && parts[0].equals(username)) {
|
||||||
// 更新密码
|
// 更新密码
|
||||||
parts[1] = newPassword;
|
parts[1] = newPassword;
|
||||||
lines.set(i, String.join("|", parts));
|
lines.set(i, String.join("|", parts));
|
||||||
userFound = true;
|
userFound = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (userFound) {
|
if (userFound) {
|
||||||
// 写回文件
|
// 写回文件
|
||||||
Files.write(Paths.get(USER_DATA_FILE), lines);
|
Files.write(Paths.get(USER_DATA_FILE), lines);
|
||||||
// 更新内存中的用户数据
|
// 更新内存中的用户数据
|
||||||
examController.updateUserPassword(username, newPassword);
|
examController.updateUserPassword(username, newPassword);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void showStatus(String message, boolean isError) {
|
private void showStatus(String message, boolean isError) {
|
||||||
statusLabel.setText(message);
|
statusLabel.setText(message);
|
||||||
if (isError) {
|
if (isError) {
|
||||||
statusLabel.setStyle("-fx-text-fill: #DC143C; -fx-font-weight: bold; -fx-font-size: 14;");
|
statusLabel.setStyle("-fx-text-fill: #DC143C; -fx-font-weight: bold; -fx-font-size: 14;");
|
||||||
} else {
|
} else {
|
||||||
statusLabel.setStyle("-fx-text-fill: #228B22; -fx-font-weight: bold; -fx-font-size: 14;");
|
statusLabel.setStyle("-fx-text-fill: #228B22; -fx-font-weight: bold; -fx-font-size: 14;");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,2 +1,2 @@
|
|||||||
wgll|123456|ymhlovesLQX@163.com|小学|1760162416490
|
wgll|Ymh123456|ymhlovesLQX@163.com|小学|1760162416490
|
||||||
666|123456789|252436951@qq.com|小学|1760166999971
|
666|123456789|252436951@qq.com|小学|1760166999971
|
||||||
|
|||||||
Loading…
Reference in new issue