SG-UAP常用注解介绍
Annotation(注解)是JDK5.0及以后版本引入的。它可以用于创建文档,跟踪代码中的依赖性,甚至执行基本编译时检查。注解是以‘@注解名’在代码中存在的,根据注解参数的个数,我们可以将注解分为:标记注解、单值注解、完整注解三类。它们都不会直接影响到程序的语义,只是作为注解(标识)存在,我们可以通过反射机制编程实现对这些元数据的访问。另外,你可以在编译时选择代码里的注解是否只存在于源代码级,或者它也能在class文件中出现
注解定义很简单:
@Target(ElementType.PARAMETER)
public @interface Test {}
使用时以@Test方式标记在方法体,类或参数上。Target(ElementType.PARA
METER)可以定义注解的标记类型。
常用 SPRING注解
1.@Controller
@Controller注解将一个类标明为用来接收HTTP请求控制器
2.@RequesMapping
@RequestMapping注解将特定的URL和具体的控制器类或控制类类中的方法绑定
3.@PathVariable
添加@PathVariable注解,可以直接在方法中使用请求URI中的值。
4.@Repository
用于将数据访问层(DAO层) 的类标识为Spring Bean。具体只需将该注解标注
在 DAO类上即可。同时,为了让Spring能够扫描类路径中的类并识别出
@Repository注解,需要在XML配置文件中启用Bean的自动扫描功能,这可
以通过<context:component-scan/><context:component-scanbase-
package=”bookstore.dao”/> 如此,我们就不再需要在XML中显式使用
<bean/> 进行 Bean 的配置。Spring在容器初始化时将自动扫描base-package
指定的包及其子包下的所有class文件,所有标注了@Repository的类都将被册
为 SpringBean。
控制层使用的注解介绍
作用:参数注解。
com.sgcc.uap.rest.annotation.ColumnRequestParam
请求体是{columns:["id","name"]}的形式,指明方法的参数是从请求体中获取的字符串数组。
用于在获取元数据信息时,从请求体获取显示的列,并将列名封装为字符串数组。
例如:请求参数为params={“columns”:[“id”,“name”,“sex”]},返回数据为:String[]{“id”,“name”,“sex”}
使用示例:@RequestMapping("/meta")
public @ColumnResponseBodyList<ViewAttributeData>getMetaData(
@ColumnRequestParam("params")String[] columns) {
…………
}
作用:方法体注解,对返回值进行拦截。
拦截List类型的返回值,将返回值解析为JSON格式字符串,如:
{“columns”:[{“name”:”id”,”caption”:”编号”,”length”:32},{},{},…]}
com.sgcc.uap.rest.annotation.ColumnResponseBody
响应体是{columns:[{},{},{}……]}的形式,指明将方法返回值转化为JSON格式列信息,
将返回的对象转换为json串。
返回对象为ViewAttributeData,
返回数据格式为:
{"columns":[{"name":"id","caption":"ID",nullable:false,dataType:"string"},...]}
3. @IdRequestBody:
作用:参数注解。
拦截请求体为{params:{primaryKey: ”EMP_ID” , ids:[”001”, “002”,……] }}格式的数据,将此数据转换为字符串数组。如
[“0001”,”0002”]。
com.sgcc.uap.rest.annotation.IdRequestBody
指明方法的参数是从请求体中获取的字符串数组 ,并将主键信息封装为IDRequestObject对象。通过getPrimarykey()和getIds()取出主键名称和主键值
例如:用于删除操作从请求体中获取主键
public @VoidResponseBody
Object delete(@IdRequestBodyIDRequestObjectid) {
。。。。。。
}
4. @ItemRequestParam:
作用:参数注解。
com.sgcc.uap.rest.annotation.ItemRequestParam
拦截请求数据{“itemType”:”school”},将数据的itemType解析,返回字符串。例如返回:school。
该注解用于在树场景中取出节点的itemType。使用示例:
public @TreeResponseBody
List<TreeNode>getNodes(@PathVariableString id,
@ItemRequestParam("params")StringitemType){
。。。。。。
}
5. @ItemsRequestBody:
作用:参数注解。
com.sgcc.uap.rest.annotation.ItemsRequestBody
拦截请求体的数据格式:
{“items”:[{“id”:”01”,”name”:”n1”},{},{},…]}和{“parentID”:”0003329281”,“items”:[{“id”:”01”,”name”:”n1”},{},{},…]}
将数据转化为List<Map>格式,list中map封装一个item数据
使用示例:用于保存场景,将请求体中的记录封装为到list中。
public @ItemResponseBody
List<SchoolVO>saveSchool(@ItemsRequestBodyList<Map>list) {
。。。。
}
6. @ItemsResponseBody:
作用:方法体注解。
拦截返回数据。将返回的list集合转化为json字符串。
{“items”:[{“id”:”01”,”name”:”n1”},{},{},…] ,itemCount:100}
com.sgcc.uap.rest.annotation.ItemResponseBody
拦截返回数据。将返回的list集合转化为json字符串。指明返回值将以
{items:[{}{}{}{}]}的形式返回。使用示例:
public @ItemResponseBody
QueryResultObjectquery(@QueryRequestParam("params")
RequestConditionparams){
。。。。。
}
7. @QueryRequestParam:
作用:参数注解。
com.sgcc.uap.rest.annotation.QueryRequestParam
GET请求中从url中通过指定KEY值将参数取出,用于查询条件。
QueryRequestParam("params"),将url中的{"params":{"filter":"name ='eqe'&sex='female'","orderStr":"age","columns":"id,name,age,sex"}}转换为RequestCondition对象。使用实例:
public @ItemResponseBody
QueryResultObjectquery(@QueryRequestParam("params")RequestCondition
params){
。。。。。
}
8. @QueryRequestParam:
作用:参数注解。
com.sgcc.uap.rest.annotation.QueryRequestParam
GET请求中从url中通过指定KEY值将参数取出,用于查询条件。
QueryRequestParam("params"),将url中的{"params":{"filter":"name ='eqe'&sex='female'","orderStr":"age","columns":"id,name,age,sex"}}转换为RequestCondition对象。使用实例:
public @ItemResponseBody
QueryResultObjectquery(@QueryRequestParam("params")RequestCondition
params){
。。。。。
}
9. @RawResponseBody:
作用:方法体注解。
拦截返回值,对于字符串类型的返回值可以原样输出。
对于List或对象类型的返回值转换为响应的json字符串输出。方便用户封装自定义的格式。
com.sgcc.uap.rest.annotation.RawResponseBody
指明方法的返回值应当以原生返回值的形式,绑定到响应体中 ,使用该注解的方法应当返回object。
使用示例:将方法中返回的字符串原样输出,用于自己拼装返回的格式,不用平台的json转换。
public @RawResponseBodyObject test(){
return"welcome!";
}
示例中的方法将字符串”welcome!”原样返回。
11. @VoidResponseBody:
作用:将空返回值包装为通用的返回格式。
com.sgcc.uap.rest.annotation.VoidResponseBody
用于没有特定返回值得方法注解,将对象转换为统一的json串。如:
{
"successful":true, ————方法是否调用成功
"resultHint":"", ————异常信息
"resultValue": “” ————数据信息是空的
}
例如:删除操作
public @VoidResponseBody
Object delete(@IdRequestBodyIDRequestObjectid) {
。。。。
}
Hibernate实体映射注解支持
平台已经引入了hibernate的注解功能,具体用法与hibernate注解映射相同,
详细用法可参考Hibernate注解映射相关文档。
@Entity
@Table(name= "O_ORG")
publicclass ORG implementsjava.io.Serializable{
@Id
@GenericGenerator(name="ORG_ID",strategy="uuid")
@GeneratedValue(generator="ORG_ID")
@Column(name="ORG_ID")
public String getId() {
return this.id;
}
public void setId(Stringid) {
this.id = id;
}
}
SG-UAP常用注解介绍的更多相关文章
- Spring常用注解介绍【经典总结】
Spring的一个核心功能是IOC,就是将Bean初始化加载到容器中,Bean是如何加载到容器的,可以使用Spring注解方式或者Spring XML配置方式. Spring注解方式减少了配置文件内容 ...
- SpringBoot | 第六章:常用注解介绍及简单使用
前言 之前几个章节,大部分都是算介绍springboot的一些外围配置,比如日志配置等.这章节开始,开始总结一些关于springboot的综合开发的知识点.由于SpringBoot本身是基于Sprin ...
- [刘阳Java]_Spring常用注解介绍_第6讲
Spring的注解是在Spring2.5的版本中引入的,目的简化XML配置.在企业开发过程中使用注解的频率非常高,但是学习注解的前提是大家一定要对Spring基于XML配置要熟悉,这是我个人建议,因为 ...
- springMvc之常用注解介绍
@requestbody和@requestparam的用法 获取请求参数的方法 get请求: 直接获取request 如: public String getHtml(HttpServletR ...
- 【JSON 注解】JSON循环引用1-----Jackson常用注解介绍 eq:@JsonIgnore
循环引用:实体A与实体B有关系,A中有B作为字段,B中有A作为一个字段.查询A对象后,将A对象转化为JSON格式数据时,会因为序列化过程中导致A中有B字段,B字段中又有A,这样就引起了循环引用的问题! ...
- Swagger2常用注解和使用方法
一 引入maven依赖 <!--整合Swagger2--> <dependency> <groupId>com.spring4all</groupId&g ...
- SpringBoot 中常用注解@PathVaribale/@RequestParam/@GetMapping介绍
SpringBoot 中常用注解@PathVaribale/@RequestParam/@GetMapping介绍 本篇博文将介绍几种如何处理url中的参数的注解@PathVaribale/@Requ ...
- 单元测试_JUnit常用单元测试注解介绍及代码演示
JUnit常用单元测试注解介绍及代码演示 by:授客 QQ:1033553122 1. 测试环境 1 2. 基础概念 1 3. 常用Annotation 1 4. 运行环境配置 3 maven配置 ...
- SpringBoot 中常用注解@Controller/@RestController/@RequestMapping介绍
原文 SpringBoot 中常用注解 @Controller/@RestController/@RequestMapping介绍 @Controller 处理http请求 @Controller / ...
随机推荐
- 微信小程序调用微信支付接口
本文链接:https://blog.csdn.net/u012667477/article/details/80940578前言:应项目要求,需要使用微信小程序做支付,写完后告知手续费太高方案不予通过 ...
- Hash算法及java HashMap底层实现原理理解(含jdk 1.7以及jdk 1.8)
现在很多公司面试都喜欢问java的HashMap原理,特在此整理相关原理及实现,主要还是因为很多开发集合框架都不甚理解,更不要说各种其他数据结构了,所以造成面子造飞机,进去拧螺丝. 1.哈希表结构的优 ...
- vs2015 项目调试出现未能加载文件或程序集“Antlr3.Runtime”或它的某一个依赖项。找到的程序集清单定义与程序集引用不匹配。 (异常来自 HRESULT:0x80131040)
今天在调试项目不知道怎么了,突然就报未能加载文件或程序集“Antlr3.Runtime”或它的某一个依赖项.找到的程序集清单定义与程序集引用不匹配. (异常来自 HRESULT:0x80131040) ...
- [转]C/C++实现回调机制的几种方式(回调、槽、代理)
转自:https://www.jianshu.com/p/4f907bba6d5f (1)Callback方式(回调) Callback的本质是设置一个函数指针进去,然后在需要需要触发某个事件时调用该 ...
- 简单易用的录屏软件(保存为gif文件)
LICEcap https://licecap.en.softonic.com/ Create animated GIFs from your desktop LICEcap is an origin ...
- start & stop kafka cluster shell script
kafka_start_cluster.sh #!/bin/bash brokers="kafka-server-1 kafka-server-2 kafka-server-3" ...
- [转]解决 gem install 安装失败
链接地址:https://blog.csdn.net/weixin_42414461/article/details/85337465
- golang遍历文件夹
golang遍历文件夹: func main() { //方式一 filepath.Walk("temp/", func (path string, info os.FileInf ...
- Redis实现实时热点查询
Redis内存淘汰 定义: 指的是用户存储的一些键被可以被Redis主动地从实例中删除,从而产生读miss的情况 机制存在原因: Redis最常见的两种应用场景为缓存和持久存储 首先要明确的一个问题是 ...
- SET key value [EX seconds] [PX milliseconds] [NX|XX]
SET key value [EX seconds] [PX milliseconds] [NX|XX] 可用版本: >= 1.0.0 时间复杂度: O(1) 将字符串值 value 关联到 k ...