rust用来写webapi可能有点大材小用,但是作为入门学习应该说是不错的选择。

cargo new webapi创建一个webapi项目,在src下面新建handler文件夹和models文件夹。

在models文件夹下面建立一个mod.rs和weatherforecast.rs文件。

weatherforecast.rs文件新建我们需要的WeatherForecast类,附上Serialize,Deserialize接口(trait)实现。

use chrono::NaiveDate;
use serde::{Serialize, Deserialize}; #[derive(Debug,Serialize,Deserialize)]
pub struct WeatherForecast{
pub date:NaiveDate,
pub temperature_c:i32,
pub temperature_f:i32,
pub summary:String
}

mod.rs文件作为管理模块,实体类需要导入,有多少实体类都可以放进去,后续就方便从这个模块中导出需要的类。

当然rust的webapi需要导入web开发需要的库,以及项目中需要的库,看名字就大概的猜到是什么作用了。

有了实体类,下面就写下get接口的实现,作为一个webapi架子,只用内存做存储

同样在handlers文件夹下面新建mod.rs和weatherforecast.rs

handlers下面的weatherforecast.rs代码如下

use crate::models::weatherforecast::WeatherForecast;
use actix_web::{get,HttpResponse,Responder};
use chrono::{Duration, Utc};
use rand::Rng; #[get("/getweatherforecast")]
pub async fn getweatherforecast()->impl Responder{
let mut rng = rand::thread_rng();
let summaries: Vec<&str> = vec!["Sunny","Cloudy","Rainy","Stormy"];
let weather_forecasts:Vec<WeatherForecast> = (1..=5).map(|index|{
let date = Utc::now().date_naive() + Duration::days(index);
let temperature_c = rng.gen_range(-20..=55);
let summary = summaries[rng.gen_range(0..summaries.len())].to_string();
let temperature_f = 32 + (temperature_c / 5 * 9);
WeatherForecast{
date,
temperature_c,
temperature_f,
summary:summary
}
}).collect();
HttpResponse::Ok().json(weather_forecasts)
}

handlers通过use  crate::models::weatherforecast::WeatherForecast引用了models的模块,所以在main.rs中需要提前引入,代码如下:

#[path = "models/mod.rs"]
mod models;
#[path = "handlers/mod.rs"]
mod handlers; use actix_web::{App,HttpServer};
use handlers::*; #[actix_web::main]
async fn main()->std::io::Result<()> {
HttpServer::new(||{
App::new()
.service(weatherforecast::getweatherforecast)
}).bind("127.0.0.1:8088")?.run().await
}

到这里代码就写完了,下面运行一下看看效果:访问地址  127.0.0.1:8088/getweatherforecast

示例代码如下:

rust/webapi at main · liuzhixin405/rust · GitHub

rust实现weatherforecast的获取天气webapi的更多相关文章

  1. 半吊子学习Swift--天气预报程序-获取天气信息

    昨天申请的彩云天气Api开发者今天上午已审核通过  饭后运动过后就马不停蹄的来测试接口,接口是采用经纬度的方式来获取天气信息,接口地址如下 https://api.caiyunapp.com/v2/ ...

  2. 关于实现手机端自动获取天气的demo

    博主大二做的一个项目,当时很傻很天真,但是还是贴出来,希望能给大家一点帮助.欢迎转载哦!我的博客园地址:http://www.cnblogs.com/natureless/ 首先分析需求,移动端实现天 ...

  3. 内网公告牌获取天气信息解决方案(C# WebForm)

    需求:内网公告牌能够正确显示未来三天的天气信息 本文关键字:C#/WebForm/Web定时任务/Ajax跨域 规划: 1.天定时读取百度接口获取天气信息并存储至Txt文档: 2.示牌开启时请求Web ...

  4. C#调用WebService获取天气信息

    概述 本文使用C#开发Winform应用程序,通过调用<WebXml/>(URL:http://www.webxml.com.cn)的WebService服务WeatherWS来获取天气预 ...

  5. JS调用腾讯接口获取天气

    想做个直接通过JS获取某个城市的天气.本来想通过直接调用中国气象网的接口: http://www.weather.com.cn/weather/101070201.shtml,但是跨域问题一直无法解决 ...

  6. java获取天气信息

    通过天气信息接口获取天气信息,首先要给项目导入程序所需要的包,具体需要如下几个包: json-lib-2.4.jar ezmorph-1.0.6.jar commons-beanutils-1.8.3 ...

  7. Kettle通过Webservice获取天气信息

      Kettle通过Webservice获取天气信息 需求: 通过kettle工具,通过webservice获取天气信息,写成xml格式文件. 思路: Kettle可通过两种选择获取webservic ...

  8. Java通过webservice接口获取天气信息

    通过SOAP请求的方式获取天气信息并解析返回的XML文件. 参考: http://www.webxml.com.cn/WebServices/WeatherWS.asmx import java.io ...

  9. ajax无刷新获取天气信息

    浏览器由于安全方面的问题,禁止ajax跨域请求其他网站的数据,但是可以再本地的服务器上获取其他服务器的信息,在通过ajax请求本地服务来实现: <?php header("conten ...

  10. webservice获取天气信息

    效果 1.eclipse中新建一个Java项目 2.通过命名获取天气的客户端信息 首先,打开天气网站http://ws.webxml.com.cn/WebServices/WeatherWS.asmx ...

随机推荐

  1. 处理尚不存在的 DOM 节点

    探索 MutationObserver API 与传统轮询等待最终被创建的节点方法相比的优劣. 有时候,您需要操作尚未存在的 DOM 的某个部分. 出现这种需求的原因有很多,但你最常看到的是在处理第三 ...

  2. 手动实现一个call bind

    一.call的实现(apply类似) //完成版 Function.prototype.setCall = function (obj){ var object = obj || window let ...

  3. vue-router面试题

    1.vue-router怎么重定向页面? 答:路由中配置redirect属性 2.vue-router怎么配置404页面? 答:path: '*' 是对的 但是应该放在最后一个 3.切换路由时,需要保 ...

  4. nginx重启和操作

    在linux操作系统中,重启nginx 1.当不知道nginx所在目录时,需要先查找到nginx的位置  查看ngnix位置(master process 后面的就是 nginx的目录): ps -e ...

  5. Kubernetes(k8s)实现IPv4/IPv6网络双栈

    背景 如今IPv4IP地址已经使用完毕,未来全球会以IPv6地址为中心,会大力发展IPv6网络环境,由于IPv6可以实现给任何一个设备分配到公网IP,所以资源是非常丰富的. 配置hosts [root ...

  6. Java:一篇学好设计模式

    什么是设计模式 简单理解,设计模式是前人多年写代码踩坑总结出来的优秀代码攻略,目的是减少大量无用代码,让项目更好维护 七大设计原则 接下来要讲的23种设计模式,但遵循下面的七大原则: 单一职责原则 2 ...

  7. 前后端分离 nginx 的配置

    前端 nginx # 添加头部信息 proxy_send_timeout 30; # 后端服务器连接超时时间 proxy_read_timeout 30; # 后端服务器数据回传时间 proxy_co ...

  8. IT技术相关学习网站推荐

    引入在线jQuery的地址   http://code.jquery.com 唠嗑吧 IT技术经验交流    http://www.laodao8.com 博学谷视频库  传智播客   http:// ...

  9. 【Vue2.x源码系列07】监听器watch原理

    上一章 Vue2计算属性原理,我们介绍了计算属性是如何实现的?计算属性缓存原理?以及洋葱模型是如何应用的? 本章目标 监听器是如何实现的? 监听器选项 - immediate.deep 内部实现 初始 ...

  10. CS144 计算机网络 Lab1:Stream Reassembler

    前言 上一篇博客中我们完成了 Lab0,使用双端队列实现了一个字节流类 ByteStream,可以向字节流中写入数据并按写入顺序读出数据.由于网络环境的变化,发送端滑动窗口内的数据包到达接收端时可能失 ...