JAX-RS 2.0如何验证查询参数

JAX-RS 2.0如何验证查询参数

大家好,又见面了,我是全栈君。

版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/72935228

JAX-RS 2.0如何验证查询参数

  • 版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。

在JAX-RS 2.0规范中,要验证查询参数并不难,可以通过过滤器ContainerRequestFilter来实现。它还提供了一些可选项,例如使用CDI或EJB的拦截器,或通过@Context注解的HttpServletRequest进行注入。

使用场景:验证由调用者传递的查询参数

步骤:

  1. 实现过滤器
  2. 从ContainerRequestContext上下文中提取查询参数
  3. 执行验证——以适合的响应状态(和错误消息)中止请求

    @Provider
    @QueryParamValidator
    public class JAXRSReqFilter implements ContainerRequestFilter {
    @Override
    public void filter(ContainerRequestContext requestContext) throws IOException {
    MultivaluedMap < String, String > queryParameters = requestContext.getUriInfo().getQueryParameters();
    String queryParam = queryParameters.keySet().stream().findFirst().get();
    System.out.println(“Query param – ” + queryParam);
    if (!queryParam.equals(“p”)) {
    requestContext.abortWith(Response
    .status(Response.Status.BAD_REQUEST)
    .entity(“Invalid Query Param ” + queryParam)
    .build());
    }
    }
    }

强制过滤器

  • 使用@NameBinding注解来修饰自定义的注解
  • 在JAX-RS的方法上使用自定义的注解

    @NameBinding
    @Retention(RetentionPolicy.RUNTIME)
    @Target({ElementType.TYPE, ElementType.METHOD})
    public @interface QueryParamValidator {
    // do something
    }

    @Path(“test”)
    public class TestResource {
    @GET
    @QueryParamValidator
    public String test(@QueryParam(“p”) String p){
    return “Param “+ p + ” on ” + new Date();
    }
    }

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/108428.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Unity Odin从入门到精通(三):静态检查器详解

    Unity Odin从入门到精通(三):静态检查器详解前言:开发者可以使用静态检查器来选择项目工程、Unity引擎、.Net框架中所有的类型,并查看其所有的静态成员。打开静态检查器:在Unity的菜单栏中选择【Tools->OdinInspector->StaticInspector】菜单项来打开静态检查器。如下图所示:查看静态检查器的源码:首先在Rider当中切换到Assemblies视图。接着在该视图的列表当中选择Sirenix.OdinInspector.Editor程序集。然后从该程序集的列表当中选择Sirenix.Odi

    2022年7月21日
    11
  • 【c#】DataTable分页处理

    【c#】DataTable分页处理【c#】DataTable分页处理

    2022年4月25日
    40
  • nginx性能优化面试题_nginx高并发优化

    nginx性能优化面试题_nginx高并发优化nginx的优化1.gzip压缩优化2.expires缓存有还3.网络IO事件模型优化4.隐藏软件名称和版本号5.防盗链优化6.禁止恶意域名解析7.禁止通过IP地址访问网站8.HTTP请求方法优化9.防DOS攻击单IP并发连接的控制,与连接速率控制10.严格设置web站点目录的权限11….

    2022年8月27日
    3
  • pytest运行_怎么清理ios文件app的缓存

    pytest运行_怎么清理ios文件app的缓存前言pytest运行完用例之后会生成一个.pytest_cache的缓存文件夹,用于记录用例的ids和上一次失败的用例。方便我们在运行用例的时候加上–lf和–ff参数,快速运行上一

    2022年8月6日
    3
  • java 工作流框架_java工作流是什么?哪些工作流框架比较好?

    java 工作流框架_java工作流是什么?哪些工作流框架比较好?由于java编程语言本身的强大性,导致学习它需要掌握极其庞大的知识群。今天就带大家了解一下什么是java的工作流,以及为大家介绍一下哪些工作流框架比较好。简单来说,java工作流就是一个基于java开发的流程框架,一般情况下,好的工作流在开发时是不需要写代码的,直接配置就可以了。它一般在OA系统应用的频率比较高。那么哪些工作流框架比较好呢?首先Activiti、JBPM、JBossSeam、XJ…

    2022年5月16日
    44
  • jdbc fetchsize_jdbc和odbc的关系

    jdbc fetchsize_jdbc和odbc的关系DBUtilscommons-dbutils是Apache组织提供的一个开源JDBC工具类库,封装了针对于数据库的增删改查操作APIQueryRunnerResulSetHandlerDbutils插入举例Connection conn = null; try { QueryRunner runner = new QueryRunner(); conn = JBBCUtils.getConnections3();

    2022年8月8日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号