首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何从okhttp3.ResponseBody获取url?

从okhttp3.ResponseBody获取url的方法是通过ResponseBody的source()方法获取BufferedSource对象,然后使用BufferedSource的readUtf8Line()方法读取响应体的第一行数据,该行数据即为URL。

以下是示例代码:

代码语言:txt
复制
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;
import okhttp3.ResponseBody;
import okio.BufferedSource;

import java.io.IOException;

public class Main {
    public static void main(String[] args) {
        OkHttpClient client = new OkHttpClient();

        Request request = new Request.Builder()
                .url("https://www.example.com")
                .build();

        try {
            Response response = client.newCall(request).execute();
            ResponseBody responseBody = response.body();

            if (responseBody != null) {
                BufferedSource source = responseBody.source();
                String firstLine = source.readUtf8Line();

                // 提取URL
                String url = extractUrlFromFirstLine(firstLine);
                System.out.println("URL: " + url);
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    private static String extractUrlFromFirstLine(String firstLine) {
        // 在第一行数据中提取URL
        // 这里的提取方式可能因具体响应格式而有所不同
        // 示例中假设第一行数据为 "HTTP/1.1 200 OK"
        // 实际应根据具体情况进行解析
        String[] parts = firstLine.split(" ");
        if (parts.length >= 2) {
            return parts[1];
        } else {
            return "";
        }
    }
}

请注意,这只是一个示例代码,实际应用中需要根据具体的响应格式进行解析,以提取正确的URL。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • 领券