springboot中@component注解的使用实例

 更新时间:2022年03月23日 15:42:22   作者:天蒙蒙亮  
这篇文章主要介绍了springboot中@component注解的使用实例,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

@component注解的使用

配置响应头的内容。

方式一

直接在拦截器里配置响应头内容。

/**
 * 拦截器--用户身份确认。
 */
public class RestInterceptor implements HandlerInterceptor {    
    private static final Logger log = LoggerFactory.getLogger(RestInterceptor.class);
    private static final String tokenHeader = "Authorization";
 
    /** 
         *  返回值:true表示继续流程(如调用下一个拦截器或处理器);false表示流程中断(如登录检查失败),不会继续调用其他的拦截器或处理器,此时我们需要通过response来产生响应; 
     */
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        log.info("拦截请求");
        //响应头
        response.setHeader("Access-Control-Allow-Origin", "*");
        response.setHeader("Access-Control-Allow-Headers", "x-requested-with,content-type,authorization");
        response.setHeader("Access-Control-Allow-Methods", "POST,GET,OPTIONS");
        
        if(request.getMethod().equals("OPTIONS")){
            response.setStatus(204);
            return true;
        }        
        log.info("调用接口:method=" +request.getParameter("method")+",params="+JSON.toJSONString(request.getParameterMap()));
        
//        HandlerMethod handlerMethod = (HandlerMethod)handler;
//        RequestAuth requestAuth = handlerMethod.getMethodAnnotation(RequestAuth.class);
//        if(requestAuth!=null && requestAuth.auth()==false){ //非验证API 
//            return true;//跳过验证
//        }
        //验证
//        String token = request.getHeader(tokenHeader);
//        if(token == null || token.equals("")) {
//            log.info("没有找到token");
//            throw new BusinessException(ResMsg.CODE_TOKEN_NOTFOUND, "没有找到token");
//        } else {
//            JWSObject jwsObject = JWSObject.parse(token);
//            Payload payload = jwsObject.getPayload();
//            JSONObject obj = payload.toJSONObject();
            
//            String roleNames = String.valueOf(obj.get("roleNames"));
//            Authentication auth = new Authentication();
//            if(obj.containsKey("platformId")) {
//                Long platformId = Long.valueOf(String.valueOf(obj.get("platformId")));
//                auth.setPlatformId(platformId);
//            }
//            if(obj.containsKey("userid")) {
//                Long userId = Long.valueOf(String.valueOf(obj.get("userid")));
//                auth.setUserId(userId);
//            }
//            if(obj.containsKey("orgId")) {
//                Long orgId = Long.valueOf(String.valueOf(obj.get("orgId")));
//                auth.setOrgId(orgId);
//            }
//            if(obj.containsKey("orgid")) {//为兼容老版本的接口
//                String orgid = String.valueOf(obj.get("orgid"));
//                orgid = orgid.replace(",", "");
//                Long orgId = Long.valueOf(orgid);
//                auth.setOrgId(orgId);
//            }
//            auth.setRoleNames(roleNames);
//            SecurityContext.setContext(auth);
//            JwtUtil.verify(jwsObject);
//        }
        return true;
    }
 
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
            ModelAndView modelAndView) throws Exception {
        //log.info("处理中");
    }
 
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
            throws Exception {
        if(ex != null) {
            log.error("接口处理异常:"+ex);
            throw ex;
        }
    }
}

方式二

使用@component注解,将普通JavaBean实例化到spring容器中。

public class RestInterceptor implements HandlerInterceptor {    
    private static final Logger log = LoggerFactory.getLogger(RestInterceptor.class);
    private static final String tokenHeader = "Authorization";
 
    /** 
         * 返回值:true表示继续流程(如调用下一个拦截器或处理器);false表示流程中断(如登录检查失败),不会继续调用其他的拦截器或处理器,此时我们需要通过response来产生响应; 
     */
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        log.info("拦截请求");
          
        if(request.getMethod().equals("OPTIONS")){
            response.setStatus(204);
            return true;
        }        
        log.info("调用接口:method=" +request.getParameter("method")+",params="+JSON.toJSONString(request.getParameterMap()));         
        return true;
    }
 
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
            ModelAndView modelAndView) throws Exception {
        //log.info("处理中");
    }
 
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
            throws Exception {
        if(ex != null) {
            log.error("接口处理异常:"+ex);
            throw ex;
        }
    }
}

定义 SimpleCORSFilter.java 类, 使用@component注解

@Component
public class SimpleCORSFilter implements Filter {
    public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {
        HttpServletResponse response = (HttpServletResponse) res;
        response.setHeader("Access-Control-Allow-Origin", "*");
        response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE");
        response.setHeader("Access-Control-Max-Age", "3600");
        response.setHeader("Access-Control-Allow-Headers", "x-requested-with,content-type,authorization");
        chain.doFilter(req, res);
    }
 
    public void init(FilterConfig filterConfig) {} 
    public void destroy() {}    
}

两种方式都可以完成响应。

@component注解有什么作用

用一句话概括

被@Component注解标识的类,会被纳入Spring容器中统一管理,好处是什么?一句话概括:你不用自己new了!

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • springboot接口服务,防刷、防止请求攻击,AOP实现方式

    springboot接口服务,防刷、防止请求攻击,AOP实现方式

    本文介绍了如何使用AOP防止Spring Boot接口服务被网络攻击,通过在pom.xml中加入AOP依赖,创建自定义注解类和AOP切面,以及在业务类中使用这些注解,可以有效地对接口进行保护,测试表明,这种方法有效地防止了网络攻击
    2024-11-11
  • JAVA中StringBuffer与String的区别解析

    JAVA中StringBuffer与String的区别解析

    这篇文章主要介绍了JAVA中StringBuffer与String的区别解析,需要的朋友可以参考下
    2014-02-02
  • 一篇文章带你了解MySQL数据库基础

    一篇文章带你了解MySQL数据库基础

    这篇文章主要介绍了MySql数据库基础知识点,总结整理了mysql数据库基本创建、查看、选择、删除以及数据类型相关操作技巧,需要的朋友可以参考下
    2021-08-08
  • 深入理解java泛型详解

    深入理解java泛型详解

    这篇文章主要介绍了Java中的泛型详解,什么是泛型,作用以及基础实例等,喜欢的朋友可以参考
    2017-04-04
  • Android中几种图片特效的处理的实现方法

    Android中几种图片特效的处理的实现方法

    这篇文章主要介绍了 Android中几种图片特效的处理的实现方法的相关资料,这里有放大缩小图片,获得圆角图片,获得带倒影图片的几种方法,需要的朋友可以参考下
    2017-08-08
  • jdk动态代理和cglib动态代理详解

    jdk动态代理和cglib动态代理详解

    本篇文章主要介绍了深度剖析java中JDK动态代理机制 ,动态代理避免了开发人员编写各个繁锁的静态代理类,只需简单地指定一组接口及目标类对象就能动态的获得代理对象
    2021-07-07
  • 解析HashMap中的put方法执行流程

    解析HashMap中的put方法执行流程

    在Java集合中,HashMap的重要性不言而喻,作为一种存储键值对的数据结构,它在日常开发中有着非常多的应用场景,也是面试中的高频考点,本篇文章就来分析一下HashMap集合中的put方法
    2021-12-12
  • 详解JVM的内存对象介绍[创建和访问]

    详解JVM的内存对象介绍[创建和访问]

    这篇文章主要介绍了JVM的内存对象介绍[创建和访问],文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-03-03
  • Java父线程(或是主线程)等待所有子线程退出的实例

    Java父线程(或是主线程)等待所有子线程退出的实例

    下面小编就为大家分享一篇Java父线程(或是主线程)等待所有子线程退出的实例,具有很好的参考价值,希望对大家有所帮助
    2017-11-11
  • JAVA代理,静态,动态详解

    JAVA代理,静态,动态详解

    这篇文章主要介绍了Java静态代理和动态代理总结,非常不错,具有参考借鉴价值,需要的朋友可以参考下,希望能够给你带来帮助
    2021-09-09

最新评论