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

基于Rust语言的Rocket框架和Sqlx库开发WebAPI项目记录(五)

登录处理代码

在src目录新建login_handle.rs文件

目录结构如下:

project

|—src

        |—params   //封装参数结构体模块

                 |—req.rs    //封装请求参数结构体

                 |—resp.rs  //封装返回数据结构体

                 |—result_parse.rs  //解析返回参数结构体

                 |—mod.rs    //导出模块       

        |—common    //公共模块

                |—db.rs    //构造数据库连接池

                |—jwt.rs   //处理token

                |—mistake.rs  //处理错误

                |—util.rs  //工具函数

                |—mod.rs  //导出模块

        |—logic    //业务逻辑模块

                |—wechat.rs    //处理业务

                |—mod.rs   //导出模块

        |—login_handle.rs   //登录处理函数

login_handle.rs代码如下:

use crate::common::db;
use crate::params::req;
use crate::params::req::Userparam;
use crate::params::resp;
use crate::common::utils::get_uuid;
use crate::common::jwt::get_token;use rocket::get;
use rocket_db_pools::Connection;
use rocket_db_pools::sqlx::{self,Row};
use rocket::serde::json::{Value,Json,json};//注册
pub async fn register(mut db:  Connection<db::Prodb>,regpram:Json<req::Userparam>)->Json<resp::Regresp> {let userid=get_uuid();let sql = sqlx::query("insert into users (uname,id) values ($1,$2)").bind(&regpram.uname).bind(&userid).execute(& mut **db).await;match sql {Ok(_result) => {Json(resp::Regresp { code:1,message:"Success".to_string(),uid:userid})},Err(err) => {Json(resp::Regresp { code:0,message:err.to_string(),uid:"null".to_owned()})}}
}//获取用户idpub async fn get_id(mut db: Connection<db::Prodb>,uname:String)->String {let uid = sqlx::query("select id from users where uname=$1").bind(&uname).fetch_one(&mut **db).await.unwrap().get(0);return uid;}//验证
#[get("/verify/<uname>")]
pub async fn verify(mut db: Connection<db::Prodb>,uname:String)->Value {let count = sqlx::query("select count(*) from users where uname=$1").bind(&uname).fetch_one(&mut **db).await;match count{Ok(a)=>{  //非空行,有数据let num:i64 =a.get(0);if num>0{let id=get_id(db, uname.clone()).await;let user=Userparam{uname:uname.clone(),id:id};get_token(Json(user)).await}else{let userid=get_uuid();let regparam=Userparam{uname:uname.clone(),id:userid};let reg:Json<resp::Regresp>= register(db, Json(regparam)).await;let uid=&reg.uid;if reg.code==1{let user=Userparam{uname:uname,id:uid.to_owned()};get_token(Json(user)).await}else{json!(resp::Resp { code:0,message:"认证失败!".to_string(),})}}},Err(_b)=>{  //空行,无数据let userid=get_uuid();let regparam=Userparam{uname:uname.clone(),id:userid};let reg:Json<resp::Regresp>= register(db, Json(regparam)).await;let uid=&reg.uid;if reg.code==1{let user=Userparam{uname:uname,id:uid.to_owned()};get_token(Json(user)).await}else{json!(resp::Resp { code:0,message:"认证失败!".to_string(),})}}}}
CRUD与上传文件处理代码

在src目录新建xxx_handle.rs文件

目录结构如下:

project

|—src

        |—params   //封装参数结构体模块

                 |—req.rs    //封装请求参数结构体

                 |—resp.rs  //封装返回数据结构体

                 |—result_parse.rs  //解析返回参数结构体

                 |—mod.rs    //导出模块       

        |—common    //公共模块

                |—db.rs    //构造数据库连接池

                |—jwt.rs   //处理token

                |—mistake.rs  //处理错误

                |—util.rs  //工具函数

                |—mod.rs  //导出模块

        |—logic    //业务逻辑模块

                |—wechat.rs    //处理业务

                |—mod.rs   //导出模块

        |—login_handle.rs   //登录处理函数

        |—xxx_handle.rs   //CRUD与上传文件处理函数示例

xxx_handle.rs处理函数代码示例:

use rocket::{post,get};
use rocket_db_pools::Connection;
use rocket_db_pools::sqlx::{self,Row};
use rocket::serde::json::Json;
use sqlx::postgres::PgRow;
use rocket::form::Form;
use std::collections::HashMap;
use std::env;use crate::logic::wechat::{ocr,parse_ocr,del_img};
use crate::common::db;
use crate::params::req::{self, UploadImg};
use crate::params::resp;
use crate::common::utils::get_uuid;
use crate::common::jwt::Token;//上传文件处理
#[post("/upload",data="<img>")]
pub async fn upload_file(mut img:Form<UploadImg<'_>>)->Result<Json<HashMap<String, String>>,std::io::Error>{//处理图片上传逻辑//获取项目部署路径let exe_path=env::current_exe().unwrap();let mut path=exe_path.parent().ok_or_else(|| std::io::Error::new(std::io::ErrorKind::Other, "No parent directory found")).unwrap().to_path_buf();//拼接路径path.push("tmp");path.push(img.name);let url=path.to_str().unwrap();//将临时文件移动到路径img.file.persist_to(url).await.unwrap();//图片服务器let http_img=String::from("https://www.xxxyyy.cn/images/")+img.name;//返回识别数据let datas= ocr(&http_img).await ;if let Ok(data)=datas{let parser =parse_ocr(&data).await;return Ok(Json(parser));}else{println!("OCR文本识别失败,请重新再试");//删除临时图片del_img(String::from(url)).await.unwrap();let resp=[("code".to_string(),"0".to_string()),("msg".to_string(),"识别失败".to_string())];return Ok(Json(HashMap::from(resp)));}}//插入数据
#[post("/insert",data="<liverpram>")]
pub async fn insert_liver(mut db: Connection<db::Prodb>,liverpram:Json<req::Liverparam<'_>>,auth:Token)->Json<resp::Resp> {//获取uuidlet liverid=get_uuid();//获取从token中解析出来的用户信息let uname=auth.uname;let sql = sqlx::query("insert into livers (livervalue,checktime,uid,id) values ($1,$2,$3,$4)").bind(liverpram.livervalue).bind(liverpram.checktime).bind(uname).bind(liverid).execute(&mut **db).await;match sql {Ok(_result) => {Json(resp::Resp { code:1,message:"Success".to_string(),})},Err(err) => {Json(resp::Resp { code:0,message:err.to_string(),})}}
}//删除数据
#[get("/delete/<id>")]
pub async fn delete_liver(mut db: Connection<db::Prodb>,id:String,_auth:Token)->Json<resp::Resp> {let sql = sqlx::query("delete from livers where id=$1").bind(id).execute(&mut **db).await;match sql {Ok(_result) => {Json(resp::Resp { code:1,message:"Success".to_string(),})},Err(err) => {Json(resp::Resp { code:0,message:err.to_string(),})}}
}//返回数据
//返回liver数组--倒序
#[get("/list")]
pub async fn list_liver(mut db: Connection<db::Prodb>,auth:Token) -> Json<Vec<resp::Listliver>> {let uname=auth.uname;let rows =sqlx::query("SELECT id,uid,livervalue,checktime FROM livers where uid=$1 order by checktime desc limit 7").bind(uname);let list:Result<Vec<resp::Listliver>,sqlx::Error>=rows.map(|r:PgRow|resp::Listliver{livervalue:r.get("livervalue"),checktime:r.get("checktime"),uid:r.get("uid"),id:r.get("id")}).fetch_all(&mut **db).await;match list {Ok(data)=>{Json(data)},Err(_err)=>{Json(Vec::new())}}}//返回AFP数组--正序
#[get("/listasc")]
pub async fn list_liver_asc(mut db: Connection<db::Prodb>,auth:Token) -> Json<Vec<resp::Listliver>> {let uname=auth.uname;let rows =sqlx::query("select id,uid,livervalue,checktime from (SELECT id,uid,livervalue,checktime FROM livers where uid=$1 order by checktime desc limit 7) order by checktime asc").bind(uname);let list:Result<Vec<resp::Listliver>,sqlx::Error>=rows.map(|r:PgRow|resp::Listliver{livervalue:r.get("livervalue"),checktime:r.get("checktime"),uid:r.get("uid"),id:r.get("id")}).fetch_all(&mut **db).await;match list {Ok(data)=>{Json(data)},Err(_err)=>{Json(Vec::new())}}}//返回AFP数组--倒序
#[get("/listall")]
pub async fn list_liver_all(mut db: Connection<db::Prodb>,auth:Token) -> Json<Vec<resp::Listliver>> {let uname=auth.uname;let rows =sqlx::query("SELECT id,uid,livervalue,checktime FROM livers where uid=$1 order by checktime desc").bind(uname);let list:Result<Vec<resp::Listliver>,sqlx::Error>=rows.map(|r:PgRow|resp::Listliver{livervalue:r.get("livervalue"),checktime:r.get("checktime"),uid:r.get("uid"),id:r.get("id")}).fetch_all(&mut **db).await;match list{Ok(data)=>{Json(data)},Err(_err)=>{Json(Vec::new())}}}//返回AFP数组--正序
#[get("/listallasc")]
pub async fn list_liver_all_asc(mut db: Connection<db::Prodb>,auth:Token) -> Json<Vec<resp::Listliver>> {let uname=auth.uname;let rows =sqlx::query("SELECT id,uid,livervalue,checktime FROM livers where uid=$1 order by checktime asc").bind(uname);let list:Result<Vec<resp::Listliver>,sqlx::Error>=rows.map(|r:PgRow|resp::Listliver{livervalue:r.get("livervalue"),checktime:r.get("checktime"),uid:r.get("uid"),id:r.get("id")}).fetch_all(&mut **db).await;match list{Ok(data)=>{Json(data)},Err(_err)=>{Json(Vec::new())}}  }
http://www.xdnf.cn/news/8377.html

相关文章:

  • 【数据架构05】数据要素架构篇
  • 二、OpenCV图像处理-几何变换
  • 服务接口鉴权与内部认证:自定义注解与AOP实现的企业级实践
  • Android 14 Binderized HAL开发实战指南(AIDL版)
  • StringBuilder 和 StringBuffer 的线程安全分析
  • maven添加自己下载的jar包到本地仓库
  • Python字典的工作原理:深入理解哈希表实现
  • Redis主从+哨兵+集群分片
  • 回溯算法:解锁多种问题的解决之门
  • 利用Qt绘图随机生成带多种干扰信息的数字图片
  • Lavavel学习笔记(Eloquent ORM/Swoole 定时任务)
  • Logback 在 Spring Boot 中的详细配置
  • 【深尚想!爱普特APT32F1023H8S6单片机重构智能电机控制新标杆】
  • PostgreSQL 软件升级
  • 06 如何定义方法,掌握有参无参,有无返回值,调用数组作为参数的方法,方法的重载
  • 解构赋值与剩余参数:语法特性背后的思考
  • Go语言爬虫系列教程(三)HTML解析技术
  • 【MySQL】剖析事务和锁
  • 疏锦行Python打卡 DAY 9 热力图和子图的绘制
  • 如何备份和恢复Linux系统?
  • RHCSA Linux 系统 硬盘管理
  • linux 内核warn_on/Bug_on
  • 【深度学习-Day 16】梯度下降法 - 如何让模型自动变聪明?
  • 应对进行性核上性麻痹,健康护理铸就温暖防线
  • MATLAB NLP 工具箱 文本预处理教程
  • 四、GPU是如何成为当前电脑中不可或缺的一部分的,opengl在其中起到了什么效果
  • HTA8111 18W内置升压单声道D类音频功放
  • SAP Business One, Web Client: The Advantages of All Worlds
  • 微服务架构下的智能规则解析:Java 解释器模式的高可用实现
  • 【438. 找到字符串中所有字母异位词】