Solon MVC 的 @Mapping 用法说明
在 Solon Mvc 里,@Mapping 注解一般是配合 @Controller 和 @Remoting,作请求路径映射用的。且,只支持加在 public 函数 或 类上。
1、注解属性
| 属性 | 说明 | 备注 |
|---|---|---|
| value | 路径 | 与 path 互为别名 |
| path | 路径 | 与 value 互为别名 |
| method | 请求方式限定(def=all) | 可用 @Post、@Get 等注解替代此属性 |
| consumes | 指定处理请求的提交内容类型 | 可用 @Consumes 注解替代此属性 |
| produces | 指定返回的内容类型 | 可用 @Produces 注解替代此属性 |
| multipart | 申明支持多分片请求(def=false) | 如果为false,则自动识别 |
当 method=all,即不限定请求方式
2、支持的路径映射表达式
| 符号 | 说明 | 示例 |
|---|---|---|
** | 任意字符、不限段数 | ** 或 /user/** |
* | 任意字符 | /user/* |
? | 可有可无 | /user/? |
/ | 路径片段开始符和间隔符 | / 或 /user |
{name} | 路径变量申明 | /user/{name} |
路径组合(控制器映射与动作映射)及应用示例:
import org.noear.solon.annotation.Controller;
import org.noear.solon.annotation.Mapping;@Mapping("/user") //或 "user",开头自动会补"/"
@Controller
public void DemoController{@Mapping("") //=/userpublic void home(){ }@Mapping("/") //=/user/,与上面是有区别的,注意下。public void home2(){ }@Mapping("/?") //=/user/ 或者 /user,与上面是有区别的,注意下。public void home3(){ }@Mapping("list") //=/user/list ,间隔自动会补"/"public void getList(){ }@Mapping("/{id}") //=/user/{id}public void getOne(long id){ }@Mapping("/ajax/**") //=/user/ajax/**public void ajax(){ }
}
提醒:一个 @Mapping 函数不支持多个路径的映射
3、参数注入
非请求参数的可注入对象:
| 类型 | 说明 |
|---|---|
| Context | 请求上下文(org.noear.solon.core.handle.Context) |
| Locale | 请求的地域信息,国际化时需要 |
| ModelAndView | 模型与视图对象(org.noear.solon.core.handle.ModelAndView) |
支持请求参数自动转换注入:
- 当变量名有对应的请求参数时(即有名字可对上的请求参数)
- 会直接尝试对请求参数值进行类型转换
- 当变量名没有对应的请求参数时
- 当变量为实体时:会尝试所有请求参数做为属性注入
- 否则注入 null
支持多种形式的请求参数直接注入:
- queryString
- form-data
- x-www-form-urlencoded
- path
- json body
其中 queryString, form-data, x-www-form-urlencoded, path 参数,支持 ctx.param() 接口统一获取。
import org.noear.solon.core.handle.Context;
import org.noear.solon.core.handle.ModelAndView;
import org.noear.solon.core.handle.UploadedFile;
import java.util.Locale;@Mapping("/user")
@Controller
public void DemoController{//非请求参数的可注入对象@Mapping("case1")public void case1(Context ctx, Locale locale , ModelAndView mv){ }//请求参数(可以是散装的;支持 queryString, form;json,或支持的其它序列化格式)@Mapping("case2")public void case2(String userName, String nickName, long[] ids, List<String> names){ }//请求参数(可以是整装的结构体;支持 queryString, form;json,或支持的其它序列化格式Mapping@Mapping("case3")public void case3(UserModel user){ }//也可以是混搭的@Mapping("case4")public void case4(Context ctx, UserModel user, String userName){ }//文件上传 //注意与 <input type='file' name="file1" /> 名字对上@Mapping("case5")public void case5(UploadedFile file1, UploadedFile file2){ } //同名多文件上传@Mapping("case6")public void case6(UploadedFile[] file){ }
}
提醒: ?user[name]=1&ip[0]=a&ip[1]=b&order.id=1 风格的参数注入,需要引入插件:solon-serialization-properties
4、带注解的参数注入
注解:
| 注解 | 说明 |
|---|---|
| @Param | 注入请求参数(包括:query-string、form)。起到指定名字、默认值等作用 |
| @Header | 注入请求 header |
| @Cookie | 注入请求 cookie |
| @Path | 注入请求 path 变量(因为框架会自动处理,所以这个只是标识下方便文档生成用) |
| @Body | 注入请求体(一般会自动处理。仅在主体的 String, InputSteam, Map 时才需要) |
注解相关属性:
| 属性 | 说明 | 适用注解 |
|---|---|---|
| value | 参数名字 | @Param, @Header, @Cookie, @Path |
| name | 参数名字(与 value 互为别名) | @Param, @Header, @Cookie, @Path |
| required | 必须的 | @Param, @Header, @Cookie, @Body |
| defaultValue | 默认值 | @Param, @Header, @Cookie, @Body |
import org.noear.solon.annotation.Controller;
import org.noear.solon.annotation.Mapping;
import org.noear.solon.annotation.Header;
import org.noear.solon.annotation.Body;
import org.noear.solon.annotation.Path;@Mapping("/user")
@Controller
public void DemoController{@Mapping("case1")public void case1(@Body String bodyStr){ }@Mapping("case2")public void case2(@Body Map<String,String> paramMap, @Header("Token") String token){ }@Mapping("case3")public void case3(@Body InputStream stream, @Cookie("Token") token){ }//这个用例加不加 @Body 效果一样@Mapping("case4")public void case4(@Body UserModel user){ } @Mapping("case5/{id}")public void case5(String id){ }//如果名字不同,才有必要用 @Path //否则是自动处理(如上)@Mapping("case5_2/{id}")public void case5_2(@Path("id") String name){ } @Mapping("case6")public void case6(String name){ }//如果名字不同,才有必要用 @Param //否则是自动处理(如上)@Mapping("case6_2")public void case6_2(@Param("id") String name){ } //如果要默认值,才有必要用 @Param@Mapping("case6_3")public void case6_3(@Param(defaultValue="world") String name){ }@Mapping("case7")public void case7(@Header String token){ }@Mapping("case7_2")public void case7_2(@Header String[] user){ } //v2.4.0 后支持
}
5、请求方式限定
可以1个或多个加个 @Mppaing 注解上,用于限定请求方式(不限,则支持全部请求方式)
| 请求方式限定注解 | 说明 |
|---|---|
| @Get | 限定为 Http Get 请求方式 |
| @Post | 限定为 Http Post 请求方式 |
| @Put | 限定为 Http Put 请求方式 |
| @Delete | 限定为 Http Delete 请求方式 |
| @Patch | 限定为 Http Patch 请求方式 |
| @Head | 限定为 Http Head 请求方式 |
| @Options | 限定为 Http Options 请求方式 |
| @Trace | 限定为 Http Trace 请求方式 |
| @Http | 限定为 Http 所有请求方式 |
| @Message | 限定为 Message 请求方式 |
| @To | 标注转发目标 |
| @WebSokcet | 限定为 WebSokcet 请求方式 |
| @Sokcet | 限定为 Sokcet 请求方式 |
| @All | 允许所有请求方式(默认) |
| 其它限定注解 | 说明 |
|---|---|
| @Produces | 申明输出内容类型 |
| @Consumes | 申明输入内容类型(当输出内容类型未包函 @Consumes,则响应为 415 状态码) |
| @Multipart | 显式申明支持 Multipart 输入 |
例:
import org.noear.solon.boot.web.MimeType;@Mapping("/user")
@Controller
public void DemoController{@Get@Mapping("case1")public void case1(Context ctx, Locale locale , ModelAndView mv){ }//也可以直接使用 Mapping 的属性进行限定。。。但是没使用注解的好看@Mapping(path = "case1_2", method = MethodType.GET)public void case1_2(Context ctx, Locale locale , ModelAndView mv){ }@Put@Message@Mapping("case2")public void case2(String userName, String nickName){ }//如果没有输出申明,侧 string 输出默认为 "text/plain"@Produces(MimeType.APPLICATION_JSON_VALUE)@Mapping("case3")public String case3(){return "{code:1}";}也可以直接使用 Mapping 的属性进行限定。。。但是没使用注解的好看@Mapping(path= "case3_2", produces=MimeType.APPLICATION_JSON_VALUE))public String case3_2(){return "{code:1}";}//如果没有输出申明,侧 object 输出默认为 "application/json"@Mapping("case3_3")public User case3_3(){return new User();}}
6、输出类型
@Mapping("/user")
@Controller
public void DemoController{//输出视图与模型,经后端渲染后输出最终格式@Maping("case1")public ModelAndView case1(){ModelAndView mv = new ModelAndView();mv.put("name", "world");mv.view("hello.ftl");return mv;}//输出结构体,默认会采用josn格式渲染后输出@Maping("case2")public UserModel case2(){return new UserModel();}//输出下载文件@Maping("case3")public Object case3(){return new File(...); //或者 return new DownloadedFile(...);}
}
7、父类继承支持
@Mapping("user")
public void UserController extends CrudControllerBase<User>{}public class CrudControllerBase<T>{@Post@Mapping("add")public void add(T t){...}@Delete@Mapping("remove")public void remove(T t){...}
}
相关文章:
Solon MVC 的 @Mapping 用法说明
在 Solon Mvc 里,Mapping 注解一般是配合 Controller 和 Remoting,作请求路径映射用的。且,只支持加在 public 函数 或 类上。 1、注解属性 属性说明备注value路径与 path 互为别名path路径与 value 互为别名method请求方式限定(defall)可用…...
uni-app表单⑪
文章目录 十七、用户登录-登录界面搭建一、结构样式代码编写 十八、用户登录-表单验证一、userRulesMixin 文件使用二、验证规则编写 十七、用户登录-登录界面搭建 一、结构样式代码编写 uni-forms 插件下载 下载地址:https://ext.dcloud.net.cn/plugin?id2773 s…...
PyQt5 加载UI界面与资源文件
步骤一: 使用 Qt Designer 创建 XXX.ui文件 步骤二: 使用 Qt Designer 创建 资源文件 步骤三: Python文件中创建相关类, 使用 uic.loadUi(mainwidget.ui, self ) 加载UI文件 import sys from PyQt5 import QtCore, QtWidgets, uic from PyQt5.QtCore import Qt f…...
【MySQL】数据库知识突破:数据类型全解析与详解
前言:本节内容讲述MySQL的数据类型, 我们在学习之前的建表的时候已经用过各种各样的数据类型。 比如int、varchar、char类型等等。其中它们是对表的结构的操作, 并没有对数据的内容进行操作,所以它叫做DDL。另外,还有…...
使用Golang实现开发中常用的【实例设计模式】
使用Golang实现开发中常用的【实例设计模式】 设计模式是解决常见问题的模板,可以帮助我们提升思维能力,编写更高效、可维护性更强的代码。 单例模式: 描述:确保一个类只有一个实例,并提供一个全局访问点。 优点&…...
【Java学习】电脑基础操作和编程环境配置
CMD 在Windows中用命令行的方式操作计算机。 打开CMD Win R输入CMD按下回车键 Win E 进入我的电脑 常用的CMD命令 盘符名称冒号 说明:盘符切换 举例:E:回车,表示切换到E盘 dir 说明:查看当前路径下的内容 cd目录 说明&a…...
AVL树解析
目录 一. AVL的概念 二 AVL树的插入 2.1先按二叉搜索树的规则插入 2.2 AVL的重点:平衡因子更新 3.1 更新后parent的平衡因子等于0。 3.2 更新后parent的平衡因子等于1 或 -1,需要继续往上更新。 3.3 更新后parent的平衡因子等于2 或 -2,需…...
栈和队列(Java)
一.栈(Stack) 1.定义 栈是限定仅在表尾进行插入或删除操作的线性表 一般的表尾称为栈顶 表头称为栈底 栈具有“后进先出”的特点 2.对栈的模拟 栈主要具有以下功能: push(Object item):将元素item压入栈顶。 pop()&am…...
C#设计原则
文章目录 项目地址一、开放封闭原则1.1 不好的版本1.2 将BankProcess的实现改为接口1.3 修改BankStuff类和IBankClient类二、依赖倒置原则2.1 高层不应该依赖于低层模块2.1.1 不好的例子2.1.2 修改:将各个国家的歌曲抽象2.2 抽象不应该依于细节2.2.1 不同的人开不同的车(接口…...
easyfs 简易文件系统
easyfs easyfs 简易文件系统文件系统虚拟文件系统 VFS简易文件系统 easyfs磁盘布局超级块 easyfs 文件系统结构磁盘上的索引结构索引节点Inode 和 DiskInode 之间的关系举例说明读取文件的过程( /hello ) 参考文档 easyfs 简易文件系统 文件系统 常规文…...
【架构论文-1】面向服务架构(SOA)
【摘要】 本文以我参加公司的“生产线数字孪生”项目为例,论述了“面向服务架构设计及其应用”。该项目的目标是构建某车企的数字孪生平台,在虚拟场景中能够仿真还原真实产线的动作和节拍,实现虚实联动,从而提前规避问题ÿ…...
刚刚!更新宁德时代社招Verify测评语言理解数字推理SHL题库、网盘资料、高分答案
宁德时代社招入职的Verify测评主要分为两大块:语言理解和数字推理。语言理解部分包括阅读理解、逻辑填空和语句排序,要求在17分钟内完成30题。数字推理部分包括数字序列、数学问题解决和图表分析,同样要求在17分钟内完成18题。这些测评题目旨…...
C++笔记---智能指针
1. 什么是智能指针 1.1 RALL设计思想 RAII(Resource Acquisition Is Initialization,资源获取即初始化)是一种资源管理类的设计思想,广泛应用于C等支持对象导向编程的语言中。它的核心思想是将资源的管理与对象的生命周期紧密绑定…...
CentOS 7系统中更改YUM源为阿里云的镜像源
引言 更换阿里的镜像源可以带来诸多好处,包括提高下载速度、提升稳定性、同步更新、简化配置、节省带宽资源以及增强系统安全性等。因此,对于使用CentOS系统的用户来说,更换阿里的镜像源是一个值得考虑的选择。 1.备份yum源 mv /etc/yum.r…...
Python酷库之旅-第三方库Pandas(206)
目录 一、用法精讲 961、pandas.IntervalIndex.mid属性 961-1、语法 961-2、参数 961-3、功能 961-4、返回值 961-5、说明 961-6、用法 961-6-1、数据准备 961-6-2、代码示例 961-6-3、结果输出 962、pandas.IntervalIndex.length属性 962-1、语法 962-2、参数 …...
3.4CQU数学实验???
meshgrid 是一个用于生成网格点坐标的函数。它常用于在二维或三维空间中创建坐标网格,用于可视化和数据处理。 在二维情况下,meshgrid 函数接受两个一维数组作为输入,并返回两个二维数组,这两个数组中的元素分别表示了所有可能的…...
Linux(CentOS)开放端口/关闭端口
一、普通用户使用 sudo 操作,开放/关闭端口,80 1、检查端口是否开放 sudo firewall-cmd --zonepublic --query-port80/tcp 2、开放端口 sudo firewall-cmd --zonepublic --add-port80/tcp --permanent 3、重新加载(开放或关闭端口后都需…...
GreenDao适配AGP8.7+
升级配置 工具版本Android StudioLadybug 2024.2.1 Path2AGP8.7.2KPG1.8.21GGP3.3.1明细 classpath "com.android.tools.build:gradle:$agp_version"classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kgp_version"classpath "org.greenrobot:g…...
【前端】Typescript从入门到进阶
以下是 TypeScript 的常用知识点总结,涵盖了从基础到入门的内容,并配有代码示例: 1. TypeScript 基础 1.1 安装和配置 安装 TypeScript 并初始化配置文件: npm install -g typescript tsc --init 1.2 基本类型 TypeScript 提供…...
在 RHEL 8 | CentOS Linux release 8.5.2111上安装 Zabbix 6
1. 备份YUM源文件 cd /etc/yum.repos.d/ mkdir bak mv C* ./bak/ wget -O /etc/yum.repos.d/CentOS-Linux-BaseOS.repo https://mirrors.aliyun.com/repo/Centos-vault-8.5.2111.repo yum clean all yum makecache2. 将 SELinux 设置为宽容模式,如下所示。 sudo s…...
【WiFi帧结构】
文章目录 帧结构MAC头部管理帧 帧结构 Wi-Fi的帧分为三部分组成:MAC头部frame bodyFCS,其中MAC是固定格式的,frame body是可变长度。 MAC头部有frame control,duration,address1,address2,addre…...
边缘计算医疗风险自查APP开发方案
核心目标:在便携设备(智能手表/家用检测仪)部署轻量化疾病预测模型,实现低延迟、隐私安全的实时健康风险评估。 一、技术架构设计 #mermaid-svg-iuNaeeLK2YoFKfao {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg…...
QMC5883L的驱动
简介 本篇文章的代码已经上传到了github上面,开源代码 作为一个电子罗盘模块,我们可以通过I2C从中获取偏航角yaw,相对于六轴陀螺仪的yaw,qmc5883l几乎不会零飘并且成本较低。 参考资料 QMC5883L磁场传感器驱动 QMC5883L磁力计…...
UR 协作机器人「三剑客」:精密轻量担当(UR7e)、全能协作主力(UR12e)、重型任务专家(UR15)
UR协作机器人正以其卓越性能在现代制造业自动化中扮演重要角色。UR7e、UR12e和UR15通过创新技术和精准设计满足了不同行业的多样化需求。其中,UR15以其速度、精度及人工智能准备能力成为自动化领域的重要突破。UR7e和UR12e则在负载规格和市场定位上不断优化…...
Typeerror: cannot read properties of undefined (reading ‘XXX‘)
最近需要在离线机器上运行软件,所以得把软件用docker打包起来,大部分功能都没问题,出了一个奇怪的事情。同样的代码,在本机上用vscode可以运行起来,但是打包之后在docker里出现了问题。使用的是dialog组件,…...
云原生玩法三问:构建自定义开发环境
云原生玩法三问:构建自定义开发环境 引言 临时运维一个古董项目,无文档,无环境,无交接人,俗称三无。 运行设备的环境老,本地环境版本高,ssh不过去。正好最近对 腾讯出品的云原生 cnb 感兴趣&…...
#Uniapp篇:chrome调试unapp适配
chrome调试设备----使用Android模拟机开发调试移动端页面 Chrome://inspect/#devices MuMu模拟器Edge浏览器:Android原生APP嵌入的H5页面元素定位 chrome://inspect/#devices uniapp单位适配 根路径下 postcss.config.js 需要装这些插件 “postcss”: “^8.5.…...
短视频矩阵系统文案创作功能开发实践,定制化开发
在短视频行业迅猛发展的当下,企业和个人创作者为了扩大影响力、提升传播效果,纷纷采用短视频矩阵运营策略,同时管理多个平台、多个账号的内容发布。然而,频繁的文案创作需求让运营者疲于应对,如何高效产出高质量文案成…...
推荐 github 项目:GeminiImageApp(图片生成方向,可以做一定的素材)
推荐 github 项目:GeminiImageApp(图片生成方向,可以做一定的素材) 这个项目能干嘛? 使用 gemini 2.0 的 api 和 google 其他的 api 来做衍生处理 简化和优化了文生图和图生图的行为(我的最主要) 并且有一些目标检测和切割(我用不到) 视频和 imagefx 因为没 a…...
七、数据库的完整性
七、数据库的完整性 主要内容 7.1 数据库的完整性概述 7.2 实体完整性 7.3 参照完整性 7.4 用户定义的完整性 7.5 触发器 7.6 SQL Server中数据库完整性的实现 7.7 小结 7.1 数据库的完整性概述 数据库完整性的含义 正确性 指数据的合法性 有效性 指数据是否属于所定…...
