【QT 网络云盘客户端】——登录界面功能的实现

目录

1.注册账号

2.服务器ip地址和端口号设置

3. 登录功能

4.读取配置文件

5.显示主界面


1.注册账号

1.点击注册页面,将数据 输入 到 用户名,昵称,密码,确认密码,手机,邮箱 的输入框中,

点击确定,触发槽函数 on_reg_but_clicked。

2.on_reg_but_clicked 会校验 各个输入框中数据格式 的合法性,比如说手机号只能由数字组成。

使用正则表达式进行检验

3.如果数据没问题,则客户端发送一个http请求给服务器:

POST http://119.23.41.13:80/register HTTP/1.1
Content-Type: application/json{"email": "sjp3250506022@qq.com",  //邮箱"firstPwd": "e10adc3949ba59abbe56e057f20f883e",//密码,用md5值进行加密"nickName": "lisi", //昵称"phone": "13727989171", //电话号码"userName": "lisi"  //用户名
}

服务器响应:


"code":	"002" //账号注册成功
"code":	"003" //用户已经存在
"code":	"004" //账号注册失败

 实现:

//注册框的流程
void Dialog::on_reg_but_clicked()
{/*1.获取输入框中的数据2.校验数据格式是否正确3.封装http请求,发送http请求4.接收http响应,处理http响应*/QString usr=ui->usr_edit->text();QString nickname=ui->nickname_edit->text();QString password=ui->pasword_edit2->text();QString confirmpassword=ui->confirm_edit->text();QString mail=ui->mailbox_edit->text();QString phone=ui->phone_edit->text();QRegExp reg(USER_REG);//校验账号的规则if(!reg.exactMatch(usr)){//校验失败QMessageBox::warning(this,"警告","输入的账号格式有误");return;}reg.setPattern(PASSWD_REG);if(!reg.exactMatch(password)){QMessageBox::warning(this,"警告","输入的密码格式有误");return;}reg.setPattern(EMAIL_REG);if(!reg.exactMatch(mail)){QMessageBox::warning(this,"警告","输入的邮箱格式有误");return;}reg.setPattern(PHONE_REG);if(!reg.exactMatch(phone)){QMessageBox::warning(this,"警告","输入的手机号码格式有误");return;}if(confirmpassword!=password){QMessageBox::warning(this,"警告","确认密码不匹配");return;}//QNetworkAccessManager* manger=new QNetworkAccessManager();//封装http请求QNetworkRequest request;//从配置文件中获取到ip地址和port端口号QString ip=Common::getInstant()->getConfValue("web_server","ip");QString port=Common::getInstant()->getConfValue("web_server","port");QString url=QString("http://%1:%2/register").arg(ip).arg(port);request.setUrl(QUrl(url));//设置文件类型request.setHeader(QNetworkRequest::ContentTypeHeader,QVariant("application/json"));//将data数据以QJson的格式发送给服务器QJsonObject object;object.insert("email", mail);//邮箱object.insert("userName", usr);//账号object.insert("phone", phone);object.insert("nickName", nickname);object.insert("firstPwd", m_common->getStrMd5(password));QJsonDocument doc(object);QByteArray data=doc.toJson();//发送数据QNetworkReply* rely=manger->post(request,data);connect(rely,&QNetworkReply::readyRead,this,[=]{//响应到达,读取所有的数据QByteArray s=rely->readAll();qDebug() << "服务器返回数据:" << QString(s);//将s数据转换为Json对象QJsonParseError err;QJsonDocument document=QJsonDocument::fromJson(s,&err);if(err.error!=QJsonParseError::NoError){qDebug()<<"QJson格式错误";return;}//将QJson字符串转换为QJson对象QJsonObject object1;object1=document.object();//获取状态码QString value1=object1["code"].toString();if(value1=="002"){QMessageBox::information(this,"提示","账号注册成功");}if(value1=="003"){QMessageBox::warning(this,"警告","该账号已经存在");}if(value1=="004"){QMessageBox::critical(this,"注册失败","注册失败");}rely->deleteLater();});
}

2.服务器ip地址和端口号设置

 

1.点击 确定 按钮,获取服务器 ip 和端口号的 信息

2.验证服务器 和 端口号的格式,如果验证成功,将 服务器的 ip地址和 端口号写入到 cfg.json 配置文件中。

 

 //点击服务器设置页的按钮,将ip地址和端口写入到配置文件中
void Dialog::on_ok_button_clicked()
{QString ip=ui->ip_edit->text();QString port=ui->port_eidt->text();QRegExp reg(IP_REG);//校验账号的规则if(!reg.exactMatch(ip)){//校验失败QMessageBox::warning(this,"警告","输入的IP地址有误");return;}reg.setPattern(PORT_REG);//校验账号的规则if(!reg.exactMatch(port)){//校验失败QMessageBox::warning(this,"警告","输入的端口号有误");return;}m_common->writeWebInfo(ip,port);QMessageBox::warning(this,"提示","配置成功");ui->stackedWidget->setCurrentWidget(ui->login_page);return;
}// 将服务器的ip和port写入到配置文件
void Common::writeWebInfo(QString ip, QString port, QString path)
{QMap<QString,QVariant> web_server;web_server.insert("ip",ip);web_server.insert("port",port);QString usr_base64=getConfValue("login","user");QString pwd_base64=getConfValue("login","pwd");QString remember=getConfValue("login","remember");QMap<QString,QVariant> login;login.insert("user",usr_base64);login.insert("pwd",pwd_base64);login.insert("remember",remember);QMap<QString, QVariant> json;json.insert("web_server", web_server);json.insert("login", login);QJsonDocument jsonDocument = QJsonDocument::fromVariant(json);if ( jsonDocument.isNull() == true){qDebug() << "QJsonDocument::fromVariant错误";return;}QFile file(CONF_FILE);if(!file.open(QFile::WriteOnly)!=0){qDebug()<<"打开文件失败";return;}file.write(jsonDocument.toJson());file.close();qDebug()<<"配置成功";
}

 

3. 登录功能

 1.点击登录,获取用户名和密码

2.验证 用户名 和密码 格式的 合法性,如果 合法,则发送一个http请求给服务器:

POST http://119.23.41.13:80/login HTTP/1.1
Content-Type: application/json{"pwd": "e10adc3949ba59abbe56e057f20f883e", //密码,用md5进行加密"user": "zhangsan"                         //用户名
}

http响应:

//登录成功的响应
HTTP/1.1 200 OK{"code":	"000","token":	"86569b8a537abf45acbb811f0244a69e"
}//登录失败的响应
HTTP/1.1 200 OK{"code":	"001",
}

登录成功后:

1.客户端需要保存token,因为客户端接下来访问服务器 都需要 加上token来验证身份

2.创建一个 logininfoinstance 实例对象,将 用户名token,服务器ip端口号保存到logininfoinstance方便后续进行读取

3..需要 将用户的 用户名 和密码 写入到 cfg.json文件 中。为了防止泄密,需要对用户名和密码进行二次加密,先进行desc加密,然后再进行base64加密 

4.创建主界面,显示主界面 

代码实现: 

//登录按钮
void Dialog::on_login_toolButton_clicked()
{qDebug()<<"登录";//获取账号密码QString account=ui->account_edit->text();QString password=ui->password_edit->text();//QRegExp reg(USER_REG);//校验账号的规则if(!reg.exactMatch(account)){//校验失败QMessageBox::warning(this,"警告","输入的账号格式有误");return;}reg.setPattern(PASSWD_REG);if(!reg.exactMatch(password)){QMessageBox::warning(this,"警告","输入的密码格式有误");return;}//封装http请求QNetworkRequest request;//从配置文件中获取到ip地址和port端口号QString ip=Common::getInstant()->getConfValue("web_server","ip");QString port=Common::getInstant()->getConfValue("web_server","port");QString url=QString("http://%1:%2/login").arg(ip).arg(port);//设置登录的urlrequest.setUrl(QUrl(url));//设置文件类型request.setHeader(QNetworkRequest::ContentTypeHeader,QVariant("application/json"));//将data数据以QJson的格式发送给服务器QJsonObject object;object.insert("user", account);object.insert("pwd",  m_common->getStrMd5(password));QJsonDocument doc(object);QByteArray data=doc.toJson();//发送数据QNetworkReply* rely=manger->post(request,data);connect(rely,&QNetworkReply::readyRead,this,[=]{//响应到达,读取所有的数据QByteArray s=rely->readAll();qDebug() << "服务器返回数据:" << QString(s);//将s数据转换为Json对象QJsonParseError err;QJsonDocument document=QJsonDocument::fromJson(s,&err);if(err.error!=QJsonParseError::NoError){qDebug()<<"QJson格式错误";return;}//将QJson字符串转换为QJson对象QJsonObject object1;object1=document.object();//获取状态码QString value1=object1["code"].toString();if(value1=="000"){//登录成功//0.获取token,将用户信息写入到logininstant中。//1.判断有没有记住密码,如果有记住密码,获取记住密码的状态//2.将账号和密码信息记录到配置文件中//3.显示登录成功页面(主页面)//获取tokenQString token=object1["token"].toString();qDebug()<<"token:"<<token;//获取token,将用户信息写入到logininstant中。saveLoginInfoData(account,token,ip,port);// QMessageBox::information(this,"登录成功","账号登录成功");//判断有没有记住密码bool checkBox=ui->rember_checkBox->isChecked();if(checkBox==false){//没有记住密码直接清除密码框ui->password_edit->clear();}//将账号密码保存到配置文件中m_common->writeLoginInfo(account,password,checkBox);//获取showMainWindow(account);}if(value1=="001"){QMessageBox::warning(this,"警告","登录");}});
}​
//common.h文件:
//将用户信息 写入到配置文件
void writeLoginInfo(QString user, QString pwd, bool isRemeber, QString path=CONF_FILE);// 服务器信息写入到配置文件
void writeWebInfo(QString ip, QString port, QString path=CONF_FILE);​相关接口(接口实现自行跳转项目链接去查看) 

4.读取配置文件

  1. 当登录界面创建的时候,程序会先去读取conf.json文件内容.将账号密码服务器ip端口号写入到登录界面中。
  2. 由于账号密码在写入配置文件是加密的,读取账号和密码需要 先后进行 base64解密 desc解密,才显示到登录界面。
  3. desc加解密,需要在项目中添加des.c文件和des.h文件
//读取配置文件信息,将账号密码,服务器端口号写到界面中void Dialog::readConf(){QString user_base64=m_common->getConfValue("login","user");QString pwd_base64=m_common->getConfValue("login","pwd");QString remember=m_common->getConfValue("login","remember");//对账号进行base64解密和desc解密QByteArray usr_des=QByteArray::fromBase64(user_base64.toLocal8Bit());unsigned char usr[1024]={0};int usr_len;//进行desc解密if(DesDec((unsigned char*)usr_des.data(),usr_des.length(),usr,&usr_len)!=0){qDebug()<<"desc解密失败";}//账号解密成功,将账号显示到登录窗口QString s=QString::fromLocal8Bit((const char*)usr,usr_len);ui->account_edit->setText(s);if(remember=="yes"){ui->rember_checkBox->setCheckState(Qt::Checked);//记住密码,将密码显示到密码框上QByteArray pwd_des=QByteArray::fromBase64(pwd_base64.toLocal8Bit());unsigned char pwd[1024]={0};int pwd_len=0;//进行desc解密if(DesDec((unsigned char*)pwd_des.data(),pwd_des.length(),pwd,&pwd_len)!=0){qDebug()<<"密码解密失败";}//账号解密成功,将账号显示到登录窗口QString s1=QString::fromLocal8Bit((const char*)pwd,pwd_len);ui->password_edit->setText(s1);}//将ip地址和端口号显示到服务器设置页面QString ip=m_common->getConfValue("web_server","ip");QString port=m_common->getConfValue("web_server","port");ui->ip_edit->setText(ip);ui->port_eidt->setText(port);}

5.显示主界面

登录成功,显示主页面:

 


//创建主界面,并显示主界面
void Dialog::showMainWindow(QString account)
{//获取主页面mainwindow=MainWindow::getinstant();mainwindow->setUser(account);//将用户名显示到主页面上mainwindow->show();//显示主页面this->hide();//隐藏主页面connect(mainwindow,&MainWindow::switchUser,this,[=](){mainwindow->hide();this->show();});
}

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

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

相关文章

【C语言学习——————动态内存管理】

文章目录 一、什么是动态内存管理二、动态内存函数的介绍 1.malloc函数的介绍2.calloc函数的介绍3.realloc函数的介绍三、free函数的介绍 一.什么是动态内存管理 我们知道数据都是在内存中进行储存的&#xff0c;但是如果我们需要调用内存&#xff0c;我们可以通过定义一个变量…

网络安全系统中的守护者:如何借助威胁情报 (TI) 提高安全性

在这篇哈巴尔网站上的推文中&#xff0c;我们将解释 TI 缩写背后的含义、为什么需要它、Positive Technologies 收集哪些网络威胁数据以及如何帮助企业预防网络威胁。我们将以四种情况为例&#xff0c;说明公司如何使用 PT Threat Intelligence Feeds 来发现恶意活动并预防攻击…

vue3+ts+elementui-plus二次封装树形表格

复制粘贴即可&#xff1a; 一、定义table组件 <template><div classmain><div><el-table ref"multipleTableRef" :height"height" :default-expand-all"isExpend" :data"treeTableData"style"width: 100%…

从官网认识 JDK,JRE,JVM 三者的关系

点击下方关注我&#xff0c;然后右上角点击...“设为星标”&#xff0c;就能第一时间收到更新推送啦~~~ JVM 是一些大厂面试必问点&#xff0c;要想解决 OOM、性能调优方面的问题&#xff0c;掌握 JVM 知识必不可少&#xff0c;从今天开始&#xff0c;将为大家介绍 JVM 的常用知…

【Docker】Docker应用部署之Docekr容器安装Nginx

目录 一、搜索镜像 二、拉取镜像 三、创建容器 四、测试使用 一、搜索镜像 docker search nginx 二、拉取镜像 docker pull nginx # 不加冒号版本号 默认拉取最新版 三、创建容器 首先我们需要在宿主机创建数据卷目录 mkdir nginx # 创建目录 cd nginx # 进入目录 mkd…

Verilog语法学习——LV9_使用子模块实现三输入数的大小比较

LV9_使用子模块实现三输入数的大小比较 题目来源于牛客网 [牛客网在线编程_Verilog篇_Verilog快速入门 (nowcoder.com)](https://www.nowcoder.com/exam/oj?page1&tabVerilog篇&topicId301) 题目 描述 在数字芯片设计中&#xff0c;通常把完成特定功能且相对独立的…

LeetCode刷题总结 - 面试经典 150 题 -持续更新

LeetCode刷题总结 - 面试经典 150 题 - 持续更新 其他系列数组 / 字符串88. 合并两个有序数组27. 移除元素26. 删除有序数组中的重复项80. 删除有序数组中的重复项 II169. 多数元素189. 轮转数组121. 买卖股票的最佳时机122. 买卖股票的最佳时机 II55. 跳跃游戏274. H 指数380.…

word里的页码问题

一份文档写完&#xff0c;如果需要页码&#xff0c;第一页是封面&#xff0c;封面不需要页码怎么办&#xff1f; 解决&#xff1a;打开页眉页脚&#xff0c;然后把首页不同勾选上&#xff0c;这一页就没有页码了。 目录页&#xff0c;往往要使用罗马数字&#xff0c;其他正文又…

网络传输层协议:UDP和TCP

背景知识 再谈端口号 端口号(Port)标识了一个主机上进行通信的不同的应用程序&#xff1b; 在TCP/IP协议中, 用 "源IP", "源端口号", "目的IP", "目的端口号", "协议号" 这样一个五元组来标识一个通信(可以通过 netstat -…

【用Vscode实现简单的python爬虫】从安装到配置环境变量到简单爬虫以及python中pip和request,bs4安装

第一步&#xff1a;安装python包 可以默认&#xff0c;也可以选择自己想要安装的路径 第二步&#xff1a;配置python环境变量&#xff0c;找到我的电脑->属性->高级 然后将刚刚安装的路径配置到path路径下&#xff1a; 然后cmd 运行 输入python命令&#xff0c;如果出现…

FFmpeg aresample_swr_opts的解析

ffmpeg option的解析 aresample_swr_opts是AVFilterGraph中的option。 static const AVOption filtergraph_options[] {{ "thread_type", "Allowed thread types", OFFSET(thread_type), AV_OPT_TYPE_FLAGS,{ .i64 AVFILTER_THREAD_SLICE }, 0, INT_MA…

Python数据可视化工具——Pyecharts

目录 1 简介绘图前先导包 2 折线图3 饼图4 柱状图/条形图5 散点图6 箱线图7 热力图8 漏斗图9 3D柱状图10 其他&#xff1a;配置项 1 简介 Pyecharts是一款将python与echarts结合的强大的数据可视化工具 Pyecharts是一个用于生成echarts图表的类库。echarts是百度开源的一个数据…

【JVM】JVM五大内存区域介绍

目录 一、程序计数器&#xff08;线程私有&#xff09; 二、java虚拟机栈&#xff08;线程私有&#xff09; 2.1、虚拟机栈 2.2、栈相关测试 2.2.1、栈溢出 三、本地方法栈&#xff08;线程私有&#xff09; 四、java堆&#xff08;线程共享&#xff09; 五、方法区&…

数据结构与算法基础-学习-27-图之最短路径之Dijkstra(迪杰斯特拉)算法

一、最短路径应用案例 例如从北京到上海旅游&#xff0c;有多条路可以到目的地&#xff0c;哪条路线最短&#xff0c;哪条路线最省钱&#xff0c;就是典型的最短路径问题。 二、最短路径问题分类 最短路径问题可以分为两类&#xff0c;第一类为&#xff1a;两点间最短路径。第…

【ArcGIS Pro二次开发】(54):三调名称转用地用海名称

三调地类和用地用海地类之间有点相似但并不一致。 在做规划时&#xff0c;拿到的三调&#xff0c;都需要将三调地类转换为用地用海地类&#xff0c;然后才能做后续的工作。 一般情况下&#xff0c;三调转用地用海存在【一对一&#xff0c;多对一和一对多】3种情况。 前2种情况…

敏捷项目经理和传统项目经理有哪些区别?

敏捷项目经理和传统项目管理有哪些区别&#xff0c;经常有咱们群里的伙伴们问&#xff0c;敏捷项目经理注重迅速响应需求变化、灵活应变&#xff0c;而传统项目经理更为注重计划的制定与执行。作为项目经理&#xff0c;敏捷也是必要的技能&#xff0c;今天就为大家分享一下敏捷…

Mac上安装sshfs

目录 写在前面安装使用参考完 写在前面 1、本文内容 Mac上安装sshfs 2、平台 mac 3、转载请注明出处&#xff1a; https://blog.csdn.net/qq_41102371/article/details/130156287 安装 参考&#xff1a;https://ports.macports.org/port/sshfs/ 通过port安装 点击啊insta…

【电网异物检测硕士论文摘抄记录】电力巡检图像中基于深度学习的异物检测方法研究

根据国家电力行业发展报告统计&#xff0c;截止到 2018 年&#xff0c;全国电网 35 千伏及以上的输电线路回路长度达到 189 万千米&#xff0c;220 千伏及以上输电线路回路长度达73 万千米。截止到 2015年&#xff0c;根据国家电网公司的统计 330 千伏及以上输电线路故障跳闸总…

经营简报及考核360表格

文章目录 经营简报效果图代码tableObjectSpanMethod.js 考核360委员会效果图 经营简报效果图不需要合并单元格且有汇总表头的 懒得封装了&#xff0c;所以整体没有封装 经营简报 效果图 代码 <template><el-tableref"tableRef":data"tableData.lengt…

【数据结构(C++版)】哈希表(散列表)

目录 1. 散列表的概念 2. 散列函数的构造方法 2.1 直接定址法 2.2 除留余数法 2.3 数字分析法 2.4 平方取中法 3. 处理冲突的方法 3.1 开放定址法 3.1.1 线性探测法 3.1.2 平方探测法 3.1.3 双散列法 3.1.4 伪随机序列法 3.2 拉链法&#xff08;链接法&#xff0…