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

营口做网站价格免费推广网站2023mmm

营口做网站价格,免费推广网站2023mmm,北京网站开发浩森宇特,官网定制公司登录处理代码 在src目录新建login_handle.rs文件 目录结构如下: project |—src |—params //封装参数结构体模块 |—req.rs //封装请求参数结构体 |—resp.rs //封装返回数据结构体 |—result_parse.rs //解析返回参数结构体 |—mod.rs //导出模块 …
登录处理代码

在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.dtcms.com/wzjs/210515.html

相关文章:

  • 广州市城乡和建设局网站网站推广公司
  • 北京网站制作 建设推广短视频seo营销系统
  • 深圳网站建设网站制作公司seo推广培训
  • 以下可以制作二维码的网站为网络推广团队
  • 电商数据中台镇江seo优化
  • 老网站用新域名东莞推广
  • 服务好的普通网站建设津seo快速排名
  • 长春网站建设营销q479185700刷屏百度退推广费是真的吗
  • php网站怎么做自适应百度网站制作
  • 2003 建设网站爱战网关键词挖掘查询工具
  • 天将建设集团有限公司网站百度推广竞价排名
  • 专注企业网站建设给公司做网站要多少钱
  • 整合wordpress济南搜索引擎优化网站
  • 网站架构变迁百度推广400电话
  • 宁波做公司网站的公司外包网络推广公司怎么选
  • 什么是营销型网站呢怎样做一个网站平台
  • 做公司网站软件网游百度搜索风云榜
  • 多个织梦dedecms网站怎么做站群百度官方官网
  • 河北做it的网站加快实施创新驱动发展战略
  • 怎么做网络推广品牌哪家强北京网站seo公司
  • 网站中flash怎么做今日头条新闻
  • php网站的客服窗口怎么做的查关键词
  • 河东苏州网站建设刷关键词排名seo软件
  • 网站设计与制作培训学校选择宁波seo优化公司
  • 模板式网站建设怎样建立个人网站
  • 深圳政府网站建设开平网站设计
  • 做JAVA基础编程题什么网站好长春百度推广排名优化
  • 有没有一起做网站的百度权重什么意思
  • 网站建设的公司业务seo公司多少钱
  • 金山石化网站建设seo最好的工具