【04-20】httpclient处理302重定向问题

本文探讨了如何自定义HTTP客户端的重定向策略,并深入解析了Spring框架中利用AOP进行服务层权限验证的方法。通过示例代码展示了如何实现更灵活的重定向逻辑及围绕业务方法进行前置与后置的权限校验。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


DefaultRedirectStrategy



client.setRedirectHandler(new DefaultRedirectHandler() {                  
                    @Override  
                    public boolean isRedirectRequested(HttpResponse response, HttpContext context) {  
                        boolean isRedirect = super.isRedirectRequested(response, context);  
                        if (!isRedirect) {  
                            int responseCode = response.getStatusLine().getStatusCode();  
                            if (responseCode == 301 || responseCode == 302) {  
                                return true;  
                            }  
                        }  
                        return isRedirect;  
                    }  
                });  




    /**
     * @since 4.2
     */
    protected boolean isRedirectable(final String method) {
        for (final String m: REDIRECT_METHODS) {
            if (m.equalsIgnoreCase(method)) {
                return true;
            }
        }
        return false;
    }



   /**
     * Redirectable methods.
     */
    private static final String[] REDIRECT_METHODS = new String[] {
        HttpGet.METHOD_NAME,
        HttpHead.METHOD_NAME
    };

http://blog.youkuaiyun.com/chszs/article/details/16996489
/** 
     * spring中Around通知   
     * @param joinPoint 
     * @return 
     * @throws Throwable  
     */  
    @Around("com.leanyu.lcsystem.pointcut.PointcutsDefinition.inServiceLayer()")     
    public Object checkPermissionAround( ProceedingJoinPoint joinPoint )    
    {  
        try  
        {   
             Object[] args           = joinPoint.getArgs();  
             AbstractRequest request =  (AbstractRequest)args[0];  
             int userId          = request.getUserId();  
             String password     = request.getPassword();  
             Signature signature = joinPoint.getSignature();  
             String service      = signature.getDeclaringTypeName();  
             String method       = signature.getName();  
                           
             if ( checkPermission.hasServicePermission(userId, service , method , password) )  
             {  
                 Object result = joinPoint.proceed( args );    
                 return result;  
             }  
               
         }catch(Throwable e)  
         {  
             logger.error(e.toString(), e);  
         }  
         return null;  
    }  

转载于:https://www.cnblogs.com/achievec/p/6741614.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值