Logging using slf4j

There are three backend wrappers available, which log request & response information using a slf4j Logger. To see the logs, you’ll need to use an slf4j-compatible logger implementation, e.g. logback, or use a binding, e.g. log4j-slf4j.

To use the backend wrappers, add the following dependency to your project:

"com.softwaremill.sttp.client" %% "slf4j-backend" % "2.2.4"

The following backend wrappers are available:

import sttp.client._
import sttp.client.logging.slf4j._
val delegateBackend: SttpBackend[Identity, Nothing, NothingT] = ???

Slf4jLoggingBackend[Identity, Nothing, NothingT](delegateBackend)
Slf4jTimingBackend[Identity, Nothing, NothingT](delegateBackend)
Slf4jCurlBackend[Identity, Nothing, NothingT](delegateBackend)

The logging backend logs DEBUG-level logs when a request is started, completes successfully, and ERROR-level logs when it results in an exception.

The timing backend logs INFO-level logs when a request completes successfully or with an exception, together with the number of seconds and milliseconds that the request took.

The curl backend logs DEBUG-level logs when a request completes successfully or with an exception, together with the curl command that can be issued to reproduce the request.

Example usage:

import sttp.client._
import sttp.client.logging.slf4j.Slf4jTimingBackend

implicit val backend = Slf4jTimingBackend[Identity, Nothing, NothingT](HttpURLConnectionBackend())
basicRequest.get(uri"https://httpbin.org/get").send()

To create a customised logging backend, see the section on custom backends.