Apache HTTPClient DigestAuth在Challenge中不会转发“opaque”值。
创始人
2024-09-04 04:33:33
0

在Apache HttpClient中,Digest Authentication(摘要认证)协议在处理Challenge时,不会自动转发"opaque"值。但可以通过自定义的AuthSchemeFactory来解决这个问题。

以下是一个示例代码,演示如何自定义AuthSchemeFactory来处理Digest Authentication的Challenge,并在请求中添加"opaque"值:

import org.apache.http.HttpHost;
import org.apache.http.HttpResponse;
import org.apache.http.auth.AuthScheme;
import org.apache.http.auth.AuthSchemeFactory;
import org.apache.http.auth.AuthScope;
import org.apache.http.auth.UsernamePasswordCredentials;
import org.apache.http.client.AuthCache;
import org.apache.http.client.AuthCacheValue;
import org.apache.http.client.CredentialsProvider;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.protocol.HttpClientContext;
import org.apache.http.impl.auth.DigestScheme;
import org.apache.http.impl.auth.DigestSchemeFactory;
import org.apache.http.impl.client.BasicAuthCache;
import org.apache.http.impl.client.BasicCredentialsProvider;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.protocol.HttpContext;

public class HttpClientDigestAuthExample {
    public static void main(String[] args) throws Exception {
        CloseableHttpClient httpClient = HttpClients.custom()
                .setDefaultAuthSchemeRegistry(
                        HttpClientContext.getDefaultAuthSchemeRegistry())
                .setDefaultCredentialsProvider(
                        new BasicCredentialsProvider())
                .build();

        AuthSchemeFactory digestAuthFactory = new DigestSchemeFactory() {
            @Override
            public AuthScheme create(HttpContext context) {
                return new DigestScheme() {
                    @Override
                    public void processChallenge(
                            final Header header) throws MalformedChallengeException {
                        super.processChallenge(header);
                        String opaque = getParameter("opaque");
                        if (opaque != null) {
                            setParameter("opaque", opaque);
                        }
                    }
                };
            }
        };

        AuthSchemeFactory.register("Digest", digestAuthFactory);

        HttpHost targetHost = new HttpHost("example.com", 80, "http");
        CredentialsProvider credsProvider = new BasicCredentialsProvider();
        credsProvider.setCredentials(
                new AuthScope(targetHost.getHostName(), targetHost.getPort()),
                new UsernamePasswordCredentials("username", "password"));

        AuthCache authCache = new BasicAuthCache();
        authCache.put(targetHost, new AuthCacheValue(
                new DigestScheme()));
        HttpClientContext context = HttpClientContext.create();
        context.setCredentialsProvider(credsProvider);
        context.setAuthCache(authCache);

        HttpGet httpGet = new HttpGet("/");
        HttpResponse response = httpClient.execute(targetHost, httpGet, context);
        // 处理响应
    }
}

在上述示例中,我们自定义了一个AuthSchemeFactory实现,并在其中重写了DigestScheme的processChallenge方法。在该方法中,我们首先调用父类的processChallenge方法处理Challenge,然后获取"opaque"值,并将其设置回DigestScheme中。

最后,我们将自定义的AuthSchemeFactory注册到HttpClient中,以便在进行Digest Authentication时使用。

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...