使用OkHttp3发起POST或GET请求

OkHttp 3 是一个比较流行的 HTTP 客户端,作用就是用来发起 HTTP 请求的。

以下是它支持的一些功能:

  • 支持发起 PUT,DELETE,POST,GET 等请求
  • 支持文件的上传下载
  • 至此加载图片(内部会图片大小自动压缩)
  • 支持请求回调,直接返回对象、对象集合
  • 支持session的保持

下面记录一下用 OkHttp 3 ,发起最常见的 GET 请求和 POST 请求。

发起GET请求

这种形式,参数直接拼接在 url 后面,第一个参数用 ? 连接,后面的每一个参数都用 & 连接。

    /**
     * HTTP接口-GET方式,请求参数形式为params形式
     *
     * @param url
     * @param param
     * @return String
     */
    public static String sendGet(String url, String param) throws IOException {
        OkHttpClient client = new OkHttpClient().newBuilder()
                .connectTimeout(180, TimeUnit.SECONDS)
                .readTimeout(180, TimeUnit.SECONDS)
                .writeTimeout(180, TimeUnit.SECONDS)
                .build();

        String dataUrl = url + "?userName=" + param;
        Request request = new Request.Builder()
                .url(dataUrl)
                .get()
                .build();
        Response response;
        String result;
        try {
            response = client.newCall(request).execute();
            result = response.body().string();
        } catch (IOException e) {
            throw new IOException(DATA, e);
        }
        return result;
    }

发起POST请求

参数为表单形式的POST请求
    /**
     * 表单形式post请求
     *
     * @paramurl 请求地址
     * @parammap post请求参数
     * @return请求结果
     */
    public static String doPostWithForm(Map<String, String> map, String url) throws IOException {
        OkHttpClient client = new OkHttpClient().newBuilder()
                .connectTimeout(180, TimeUnit.SECONDS)
                .readTimeout(180, TimeUnit.SECONDS)
                .writeTimeout(180, TimeUnit.SECONDS)
                .build();
        //构建一个formBody builder
        FormBody.Builder builder = new FormBody.Builder();
        //循环form表单,将表单内容添加到form builder中
        for (Map.Entry<String, String> entry : map.entrySet()) {
            String key = entry.getKey();
            String value = entry.getValue();
            builder.add(key, value);
        }
        //构建formBody,将其传入Request请求中
        FormBody body = builder.build();
        Request request = new Request.Builder().url(url).post(body).build();
        Call call = client.newCall(request);
        //返回请求结果
        try (Response response = call.execute()) {
            return response.body().string();
        } catch (IOException e) {
            throw new IOException(e);
        }
    }
参数为json形式的POST请求
    /**
     * HTTP接口-POST方式,请求参数形式为body-json形式
     *
     * @param url
     * @param jsonString
     * @return String
     */
    public static String sendPostWithJson(String url, String jsonString) throws IOException {
        OkHttpClient client = new OkHttpClient().newBuilder().build();
        RequestBody body = RequestBody.create(MediaType.parse("application/json; charset=utf-8"), jsonString);
        Request request = new Request.Builder()
                .post(body)
                .url(url)
                .build();
        Call call = client.newCall(request);
        //返回请求结果
        try {
            Response response = call.execute();
            return response.body().string();
        } catch (IOException e) {
            throw new IOException(e);
        }
    }
参数直接拼接在url后面的POST请求

这种形式的参数传递,和 GET 请求类似。

    /**
     * HTTP接口-POST方式,请求参数形式为params形式
     *
     * @param url
     * @param param
     * @return String
     */
    public static String sendPost(String url, String param) throws IOException {
        OkHttpClient client = new OkHttpClient().newBuilder()
                .connectTimeout(180, TimeUnit.SECONDS)
                .readTimeout(180, TimeUnit.SECONDS)
                .writeTimeout(180, TimeUnit.SECONDS)
                .build();

        FormBody body = new FormBody.Builder().build();
        String dataUrl = url + "?userName=" + param;
        Request request = new Request.Builder()
                .url(dataUrl)
                .post(body)
                .build();
        Response response;
        String result;
        try {
            response = client.newCall(request).execute();
            result = response.body().string();
        } catch (IOException e) {
            throw new IOException(e);
        }
        return result;
    }

### PyCharm 日志文件的存储位置 PyCharm 是一款功能强大的集成开发环境(IDE),其日志文件用于记录软件运行期间的关键事件和错误信息。以下是关于 PyChar 日志文件存储位置的相关说明: #### 1. **默认路径** PyCharm日志文件通常保存在其配置目录下的 `log` 子目录中。具体路径取决于操作系统以及安装类型(社区版或专业版)。以下是不同操作系统的标准路径[^2]: - **Windows**: ``` C:\Users\<用户名>\.<产品名称><版本号>\log\ ``` 例如,对于 PyCharm Professional Edition 版本 2023.x,路径可能为: ``` C:\Users\<用户名>\.PyCharm2023\.config\log\ ``` - **macOS**: ``` ~/Library/Logs/JetBrains/<产品名称><版本号>/ ``` 同样以 PyCharm Professional Edition 版本 2023.x 为例: ``` ~/Library/Logs/JetBrains/PyCharm2023.1/ ``` - **Linux**: ``` ~/.cache/JetBrains/<产品名称><版本号>/log/ ``` 对应于 Linux 平台上的路径可能是: ``` ~/.cache/JetBrains/PyCharm2023.1/log/ ``` #### 2. **通过 IDE 查找日志文件** 除了手动定位外,还可以直接在 PyCharm 内部找到日志文件的具体位置。执行以下步骤可以快速访问日志文件夹: - 打开帮助菜单 (**Help**)。 - 选择子项 **Show Log in Explorer**(适用于 Windows)、**Show Log in Finder**(适用于 macOS)或者 **Show Log in Files**(适用于 Linux)。 这一选项会自动导航到当前用户的日志文件所在目录[^3]。 #### 3. **日志文件的内容结构** PyCharm日志文件通常是 `.log` 格式的纯文本文件,命名规则类似于 `idea.log` 或带有时间戳标记的变体形式(如 `idea.cycle.yyyy-MM-dd.log`)。这些文件按日期分片存储以便管理和检索历史记录。每条日志消息都包含时间戳、严重程度标签(INFO/WARN/ERROR 等)以及实际描述内容。 --- ### 总结 PyCharm日志文件一般存放在特定的操作系统专属目录下,并遵循 JetBrains 统一管理规范。用户既可依据固定模式自行探索相应地址,也能借助内置功能迅速抵达目标区域。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值