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

此博客介绍了如何在Spring框架中通过自定义DefaultRedirectStrategy,实现对301/302响应的特定处理,以及如何使用Around通知检查权限,确保在服务层的请求之前进行权限验证。

摘要生成于 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;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值