当前位置: 首页 > wzjs >正文

廊坊做网站公司排名什么是seo?

廊坊做网站公司排名,什么是seo?,移动做网站吗,兰州网站运营诊断安全文件传输系统项目报告(第 9 周) 1. 代码链接 Gitee 仓库地址:https://gitee.com/li-zhen1215/homework/tree/master/Secure-file 代码结构说明: project-root/├── src/ # 源代码目录│ ├── main.c # 主程序入口│ ├…

安全文件传输系统项目报告(第 9 周)

1. 代码链接

Gitee 仓库地址:https://gitee.com/li-zhen1215/homework/tree/master/Secure-file

代码结构说明:

project-root/├── src/ # 源代码目录│ ├── main.c # 主程序入口│ ├── db/ # 数据库操作│ ├── gui/ # 图形界面│ └── utils/ # 工具函数模块├── include/ # 头文件├── lib/ # 动态库静态库├── docs/ # 文档目录├── Makefile # 自动编译└── README.md # 项目说明

1、完成用户登录注册界面

  • 注册功能
    用户首次进行注册时,会显示注册成功信息
    在这里插入图片描述

在这里插入图片描述
当用户名存在时,系统会提示注册失败,当前用户已存在。
在这里插入图片描述

  • 登录功能
    输入注册成功的用户名密码,和数据库中的数据匹配后会显示登录成功。
    在这里插入图片描述
    数据库文件在项目的Debug文件中
    在这里插入图片描述
    由于使用的是SQlite,不需要安装和配置服务器。SQLite 是一个嵌入式数据库,它直接将数据库存储在一个单独的磁盘文件中,不需要运行独立的服务器进程。

database.h

#ifndef DATABASE_H
#define DATABASE_H#include <QString>
#include <QSqlDatabase>class Database {
public:static Database& instance();bool registerUser(const QString &username, const QString &password);bool verifyUser(const QString &username, const QString &password);private:Database();QSqlDatabase db;
};#endif // DATABASE_H

database.cpp

#include "database.h"
#include <QSqlQuery>
#include <QSqlError>
#include <QVariant>
#include <QDebug>Database::Database() {db = QSqlDatabase::addDatabase("QSQLITE");db.setDatabaseName("user.db");if (!db.open()) {qDebug() << "无法打开数据库:" << db.lastError();}QSqlQuery query;query.exec("CREATE TABLE IF NOT EXISTS users (""id INTEGER PRIMARY KEY AUTOINCREMENT, ""username TEXT UNIQUE, ""password TEXT)");
}Database& Database::instance() {static Database instance;return instance;
}bool Database::registerUser(const QString &username, const QString &password) {QSqlQuery query;query.prepare("INSERT INTO users (username, password) VALUES (?, ?)");query.addBindValue(username);query.addBindValue(password);return query.exec();
}bool Database::verifyUser(const QString &username, const QString &password) {QSqlQuery query;query.prepare("SELECT * FROM users WHERE username = ? AND password = ?");query.addBindValue(username);query.addBindValue(password);query.exec();return query.next();
}

mainwindow.h

#ifndef MAINWINDOW_H
#define MAINWINDOW_H#include <QWidget>
#include <QLineEdit>
#include <QPushButton>class MainWindow : public QWidget {Q_OBJECTpublic:MainWindow(QWidget *parent = nullptr);private slots:void login();void registerUser();private:QLineEdit *userLineEdit;QLineEdit *passLineEdit;
};#endif // MAINWINDOW_H

mainwindow.cpp

#include "mainwindow.h"
#include "database.h"
#include "mainpage.h"
#include <QVBoxLayout>
#include <QMessageBox>MainWindow::MainWindow(QWidget *parent) : QWidget(parent) {userLineEdit = new QLineEdit(this);passLineEdit = new QLineEdit(this);passLineEdit->setEchoMode(QLineEdit::Password);QPushButton *loginBtn = new QPushButton("登录", this);QPushButton *registerBtn = new QPushButton("注册", this);QVBoxLayout *layout = new QVBoxLayout(this);layout->addWidget(userLineEdit);layout->addWidget(passLineEdit);layout->addWidget(loginBtn);layout->addWidget(registerBtn);connect(loginBtn, &QPushButton::clicked, this, &MainWindow::login);connect(registerBtn, &QPushButton::clicked, this, &MainWindow::registerUser);Database::instance();  // 初始化数据库
}void MainWindow::login() {QString username = userLineEdit->text();QString password = passLineEdit->text();if (Database::instance().verifyUser(username, password)) {QMessageBox::information(this, "登录成功", "欢迎," + username);this->hide();MainPage *page = new MainPage();page->show();} else {QMessageBox::warning(this, "登录失败", "用户名或密码错误!");}
}void MainWindow::registerUser() {QString username = userLineEdit->text();QString password = passLineEdit->text();if (Database::instance().registerUser(username, password)) {QMessageBox::information(this, "注册成功", "可以登录了!");} else {QMessageBox::warning(this, "注册失败", "用户名已存在!");}
}

2、用户登录界面

用户登陆成功后,可在主界面进行文件管理,上传或下载文件。
在这里插入图片描述
mainpage.h

#ifndef MAINPAGE_H
#define MAINPAGE_H#include <QWidget>class MainPage : public QWidget {Q_OBJECTpublic:MainPage(QWidget *parent = nullptr);private slots:void uploadFile();void downloadFile();
};#endif // MAINPAGE_H

mainpage.cpp

#include "mainwindow.h"
#include "database.h"
#include "mainpage.h"
#include <QVBoxLayout>
#include <QMessageBox>MainWindow::MainWindow(QWidget *parent) : QWidget(parent) {userLineEdit = new QLineEdit(this);passLineEdit = new QLineEdit(this);passLineEdit->setEchoMode(QLineEdit::Password);QPushButton *loginBtn = new QPushButton("登录", this);QPushButton *registerBtn = new QPushButton("注册", this);QVBoxLayout *layout = new QVBoxLayout(this);layout->addWidget(userLineEdit);layout->addWidget(passLineEdit);layout->addWidget(loginBtn);layout->addWidget(registerBtn);connect(loginBtn, &QPushButton::clicked, this, &MainWindow::login);connect(registerBtn, &QPushButton::clicked, this, &MainWindow::registerUser);Database::instance();  // 初始化数据库
}void MainWindow::login() {QString username = userLineEdit->text();QString password = passLineEdit->text();if (Database::instance().verifyUser(username, password)) {QMessageBox::information(this, "登录成功", "欢迎," + username);this->hide();MainPage *page = new MainPage();page->show();} else {QMessageBox::warning(this, "登录失败", "用户名或密码错误!");}
}void MainWindow::registerUser() {QString username = userLineEdit->text();QString password = passLineEdit->text();if (Database::instance().registerUser(username, password)) {QMessageBox::information(this, "注册成功", "可以登录了!");} else {QMessageBox::warning(this, "注册失败", "用户名已存在!");}
}

3、遇到的问题

问题1:识别不到内嵌UI文件

  • 现象:在QT程序中,无法识别内嵌的UI文件,无法启动UI
  • 原因:QT配置资源文件和路径名不匹配
  • 解决:确保UI文件的路径和名称在代码中正确引用。如果使用了资源文件(.qrc),检查资源文件的路径和前缀是否正确。例如,如果资源文件中定义了prefix=“/icons”,则在代码中引用资源时需要使用":/icons/yourfile.png"

问题2:SQlite在Ubuntu中无法使用

  • 现象:sqlite在qt中无法使用
  • 原因:没有加载SQlite插件
  • 解决
    通过下面命令安装插件
sudo apt-get install libqt5sql5-sqlite

在Qt项目文件(.pro文件)中,确保添加了SQL模块:

QT += sql

将qsqlite插件文件复制到应用程序的运行目录或sqldrivers目录下。

cp /path/to/qt/plugins/sqldrivers/libqsqlite.so /path/to/your/application/sqldrivers/

清理并重新构建项目

qmake
make clean
make

5. 提交报告文档要求

Markdown 文档

  • 本报告使用 Markdown 编写,文件名为 姓名学号_项目名称_第 XX 周.md
  • 包含代码块、图片链接、列表等标准语法。

转换为 PDF

  • 工具:使用 VS Code 插件 Markdown PDF 或在线工具 Pandoc。
  • 步骤
    # 命令行转换示例
    pandoc project-report.md -o project-report.pdf --pdf-engine=xelatex
    
http://www.dtcms.com/wzjs/296069.html

相关文章:

  • 全椒有做网站的吗成品短视频app源码的优点
  • 签约做网站模板短视频seo推广
  • 专业的咨询行业网站制作怎样免费制作网页
  • 珠海门户网站建设费用济南网站优化公司
  • 网站在百度搜不到建站推广网站
  • 玉环在哪里做网站西安seo技术培训班
  • 做淘宝代购翻译网站免费文案素材网站
  • 国外网站国内做二维码免费制作网页的网站
  • 国外做彩票网站违法吗公司网站与推广
  • 做网站就是做点击率shodan搜索引擎
  • 合肥做网站便宜关注公众号推广2元一个
  • 西宁最好网站建设公司哪家好百度浏览器手机版
  • 旅游网站建设方案书关键词排名查询
  • 网站建设banner图片关键词排名快照优化
  • 做3个网站需要多大的服务器北京seoqq群
  • 米 建设网站免费公司网站建站
  • 螺旋钢管网站建设网络营销个人感悟小结
  • 电脑制作网站总么做品牌营销策划包括哪些内容
  • 2019做网站需要营业执照吗宁波关键词优化排名工具
  • 汕头做网站网络营销总结
  • 一个备案号多个网站营销推广活动策划
  • 市住房和城乡建设局网站百度人气榜
  • 百度推广400客服电话长春seo结算
  • ztjs登录seo优化技术排名
  • 公众号开发哪家专业淘宝网站的推广与优化
  • 外贸选品搜索引擎优化管理实验报告
  • 网站内链规划q群排名优化软件
  • 网站开发作品营销软文500字范文
  • 企业网站 flash推广软文案例
  • 网站建设管理和维护baud百度一下