All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.shoulder.http.util.HttpLogHelper Maven / Gradle / Ivy

Go to download

Shoulder 提供的 Http 通信模块,几十行核心代码,在 Spring RestTemplate 基础上实现了AOP日志、异常处理、统一响应解析能力。

There is a newer version: 1.0.0-M2.2
Show newest version
package org.shoulder.http.util;

import org.shoulder.core.log.beautify.ColorString;
import org.shoulder.core.log.beautify.ColorStringBuilder;

import java.util.Map;

/**
 * 请求日志美化
 *
 * @author lym
 */
public class HttpLogHelper {


    /**
     * 组装颜色字符串
     *
     * @param cost 毫秒
     * @return 颜色字符串
     */
    public static ColorString cost(long cost) {
        return new ColorString(cost + "ms").color(costColor(cost));
    }

    /**
     * 请求花费时间的颜色
     *
     * @param cost 毫秒
     * @return 颜色
     */
    public static int costColor(long cost) {
        return cost < 200 ? ColorString.GREEN :
            cost < 1000 ? ColorString.YELLOW :
                ColorString.RED;
    }

    /**
     * 响应状态颜色
     *
     * @param httpStatus 状态
     * @return 颜色
     */
    public static int httpStatusColor(String httpStatus) {
        // 成功
        return httpStatus.startsWith("2") ? ColorString.GREEN :
            // 服务器出错
            httpStatus.startsWith("5") ? ColorString.BLUE :
                // 客户端出错
                httpStatus.startsWith("4") ? ColorString.RED : ColorString.YELLOW;
    }

    /**
     * 添加请求头信息
     *
     * @param builder 彩色字符串
     * @param headers 请求头
     */
    public static void appendHeader(ColorStringBuilder builder, Map headers) {
        headers.forEach((headerName, headerValue) -> builder
            .newLine().tab()
            .lGreen(headerName)
            .tab()
            .blue(": ")
            .cyan(headerValue));
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy