2

因此,我正在尝试为 Http 请求集成 Firebase 性能,并按照此处显示的方式手动添加它们(步骤 9)。

我正在使用 Retrofit 2 和 RxJava 2,所以我想到了做一个自定义运算符,检查下面的代码:

改造 2 客户端

@GET("branch-{environment}/v2/branches")
    fun getBranch(@Path("environment") environment: String, @Query("location") location: String, @Query("fulfilment_type") fulfilmentType: String): Single<Response<GetBranchResponse>>

对改造客户端的 RxJava 调用

private val client: BranchClient = clientFactory.create(urlProvider.apiUrl)

override fun getBranch(postCode: String, fulfilmentType: FulfilmentType): Single<GetBranchResponse> {
        return client
                .getBranch(environment, postCode.toUpperCase(), fulfilmentType.toString())
                .lift(RxHttpPerformanceSingleOperator(URL?, METHOD?))
                .map { it.body() }
                .subscribeIO() //custom Kotlin extension 
                .observeMain() //custom Kotlin extension 
                ...
    } 

RxJava 2 自定义运算符通过电梯:

class RxHttpPerformanceSingleOperator<T>(private val url: String, private val method: String) : SingleOperator<Response<T>, Response<T>> {


    private lateinit var metric: HttpMetric

    @Throws(Exception::class)
    override fun apply(observer: SingleObserver<in Response<T>>): SingleObserver<in Response<T>> {
        return object : SingleObserver<Response<T>> {

            override fun onSubscribe(d: Disposable) {

                    metric = FirebasePerformance.getInstance().newHttpMetric(url,
                            method.toUpperCase())
                    metric.start()


                observer.onSubscribe(d)
            }

            override fun onSuccess(t: Response<T>) {
                observer.onSuccess(t)

                //More info: https://firebase.google.com/docs/perf-mon/get-started-android
                metric.setRequestPayloadSize(t.raw().body().contentLength())
                metric.setHttpResponseCode(t.code())
                metric.stop()
            }

            override fun onError(e: Throwable) {
                observer.onError(e)
                metric.stop()
            }


        }
    }

所以目前我不确定如何正确获取请求的 URL 和 METHOD(标记为 URL?和 METHOD?)发送给操作员

我需要他们在 onSubscribe 上启动指标..我没有回应...


目前 UGLYYYYYYYY 我的做法是:

添加到改造客户端:

@GET("branch-{environment}/v2/branches")
    fun getBranchURL(@Path("environment") environment: String, @Query("location") location: String, @Query("fulfilment_type") fulfilmentType: String): Call<JsonObject>

添加添加参数为:

val request = client.getBranchURL(environment, postCode.toUpperCase(), fulfilmentType.toString()).request()

url = request.url().toString()
method = request.method()

这使我在每个请求的客户端上都有 2 个条目......这没有任何意义。


一些有用的线索: -如何在改造 2.0 中使用 rxjava 获取请求 url?

4

2 回答 2

4

用 the添加一个 Retrofit并在那里生成你Interceptor的:HttpClient.BuilderFirebaseInstanceHttpMetrics

class FirebasePerformanceInterceptor(val performanceInstance: FirebasePerformance) : Interceptor {
    override fun intercept(chain: Interceptor.Chain): Response {
        val request = chain.request()
        //Get request values
        val url = request.url().url()
        val requestPayloadSize = request.body()?.contentLength() ?: 0L
        val httpMethod = request.method()

        //Initialize http trace
        val trace = performanceInstance.newHttpMetric(url, httpMethod)
        trace.setRequestPayloadSize(requestPayloadSize)
        trace.start()

        //Proceed
        val response = chain.proceed(chain.request())

        //Get response values
        val responseCode = response.code()
        val responsePayloadSize = response.body()?.contentLength() ?: 0L

        //Add response values to trace and close it
        trace.setHttpResponseCode(responseCode)
        trace.setResponsePayloadSize(responsePayloadSize)
        trace.stop()

        return response
    }
}

您可以直接复制并粘贴此代码,它将起作用。享受!

于 2018-05-31T14:34:51.350 回答
1

我要建议的不一定是你的方法,它只是一种不同的方式来思考你想要完​​成的事情。

我会建议两种不同的方法:

  • 创建你自己的观察者(所以创建一个扩展观察者的类)接收一个改造调用对象,并在 subscribeActual 方法中执行你的 firebase 逻辑。
  • 使用 Aspectj 定义将在 Retrofit 调用即将执行时处理的注释,您可以在 Aspect 中执行 firebase 逻辑。(我不确定 Aspectj 和 kotlin 是如何工作的)
于 2018-01-19T10:05:32.427 回答