您上传的文件已经成功,我可以协助您基于提供的需求进行开发设计。以下是您的密码管
理系统(PassMan)开发的初步步骤:
### 功能模块设计
#### 1. 加载按钮
- 弹出文件选择框 (`dialog.showOpenDialog`),用户选择 SQLite 数据库文件。
- 检查数据库是否存在,并提示输入加密密钥(用 SHA1 保存)。
- 使用加密密钥解密数据库内容。
- 读取数据表并加载到表格中,按添加时间降序排列。
#### 2. 新增按钮
- 添加空行到表格顶部,允许用户输入:
- **服务器名称**(`server`)
- **访问方式**(`protocol`)
- **访问地址**(`url`)
- **用户名**(`username`)
- **密码**(`password`)
- 点击保存时:
- 若密钥未设置,提示用户设置密钥。
- 将密码使用 `AES-128-CBC` 加密,并保存到数据库的 `credentials` 表中。
- 自动更新显示表格内容。
#### 3. 删除按钮
- 支持批量操作,用户勾选行后点击删除。
- 弹出确认框,确认删除选中数据。
- 从数据库删除选中数据,同时更新表格。
#### 4. 保存按钮
- 将所有表格更改后的内容批量保存到数据库。
- 使用加密密钥对新的或修改的密码字段进行加密。
#### 5. 查询按钮
- 根据输入的服务器或访问方式条件查询数据库。
- 显示查询结果到表格中。
#### 6. 重置按钮
- 清除查询条件,重新显示所有数据。
### 其他功能
#### 表格功能
- **密码显示与复制**:
- 点击图标解密密码并显示明文。
- 点击复制图标,将明文密码复制到剪贴板。
- **分页功能**:
- 表格支持固定每页显示记录数量,支持页码切换。
- 加载时从数据库分页读取。
### 技术实现
#### 使用的技术栈
1. **后端**:
- Node.js:作为服务逻辑处理语言。
- SQLite3:本地数据库,轻量级,适合桌面应用。
- Crypto:Node.js 原生加密库,用于实现 AES-128-CBC 和 SHA1。
2. **前端**:
- Electron:将应用封装为桌面程序。
- Vue.js / React:管理 UI 的响应式表格。
- Bootstrap / Tailwind CSS:实现表格布局和交互样式。
3. **依赖库**:
- `sqlite3`:Node.js 访问 SQLite 数据库。
- `crypto-js`:密码加密、解密处理。
- `electron-store`:用于管理应用配置(如默认路径)。
#### 数据库
- **数据库表设计**:
- `encrypt_keys` 表保存密钥的哈希值。
- `credentials` 表保存每条密码记录。
#### 密钥加解密逻辑
- **加密**:
- 用户输入密码 -> SHA1 哈希保存到 `encrypt_keys` 表。
- 使用输入的密码生成 AES 密钥。
- **解密**:
- 根据输入密钥解密数据库中的密码字段,显示明文。
#### 关键接口设计
1. **加载数据库**:
- `loadDatabase(filePath, encryptionKey)`
2. **新增密码**:
- `addCredential(data)`
3. **删除密码**:
- `deleteCredentials(ids)`
4. **保存密码**:
- `saveCredentials(updatedData)`
5. **查询密码**:
- `queryCredentials(server, protocol)`
#### 安全性注意事项
- 密钥仅保存在内存中,关闭应用后清除。
- 密码显示与复制功能需要加密密钥解密,密钥错误或丢失无法显示明文。
- 数据库文件访问权限严格控制,避免明文数据泄露。
---
如果需要,我可以为您提供更加具体的代码实现或详细的前端/后端文件结构设计!
【 在 DoorWay 的大作中提到: 】
: 不懂就问,你这种需求,一个单页面,搞不定吗?html+js?
--
FROM 27.38.197.*