با نحوه استفاده از کتابخانه Cronet برای انجام عملیات شبکه در برنامه Android خود آشنا شوید. Cronet پشته شبکه Chromium است که به عنوان یک کتابخانه برای استفاده در برنامه های خود در دسترس شما قرار گرفته است. برای اطلاعات بیشتر در مورد ویژگی های کتابخانه، به انجام عملیات شبکه با استفاده از Cronet مراجعه کنید.
کتابخانه را در پروژه خود راه اندازی کنید
برای افزودن یک وابستگی به کتابخانه Cronet در پروژه خود این مراحل را دنبال کنید:
همانطور که در مثال زیر نشان داده شده است، بررسی کنید که Android Studio یک مرجع به مخزن Maven Google در فایل
settings.gradle
پروژه شما داشته باشد:شیار
dependencyResolutionManagement { ... repositories { ... google() } }
کاتلین
dependencyResolutionManagement { ... repositories { ... google() } }
همانطور که در مثال زیر نشان داده شده است، یک مرجع به کتابخانه سرویسهای Google Play برای Cronet در بخش
dependencies
فایلbuild.gradle
ماژول برنامه خود اضافه کنید:شیار
dependencies { implementation 'com.google.android.gms:play-services-cronet:18.0.1' }
کاتلین
dependencies { implementation("com.google.android.gms:play-services-cronet:18.0.1") }
اشیاء CronetEngine
که پس از اضافه شدن این وابستگی ایجاد می شوند، از Cronet بارگیری شده از سرویس های Google Play استفاده می کنند. قبل از ایجاد اشیاء CronetEngine
با CronetProviderInstaller.installProvider(Context)
تماس بگیرید تا از ایجاد استثناهای غیرمنتظره در حین ایجاد CronetEngine
به دلیل خطاهایی مانند دستگاههایی که به نسخه بهروزشده خدمات Google Play نیاز دارند، جلوگیری کنید.
در مواردی که Cronet را نمی توان از سرویس های Google Play بارگیری کرد، یک پیاده سازی با عملکرد کمتر از Cronet's API وجود دارد که می توان از آن استفاده کرد. برای استفاده از این پیادهسازی بازگشتی، به org.chromium.net:cronet-fallback
وابسته باشید و new JavaCronetProvider(context).createBuilder()
را فراخوانی کنید.
درخواست شبکه ایجاد کنید
این بخش نحوه ایجاد و ارسال درخواست شبکه با استفاده از کتابخانه Cronet را نشان می دهد. پس از ارسال درخواست شبکه، برنامه شما باید پاسخ شبکه را پردازش کند .
یک نمونه از CronetEngine ایجاد و پیکربندی کنید
این کتابخانه یک کلاس CronetEngine.Builder
ارائه می دهد که می توانید از آن برای ایجاد یک نمونه از CronetEngine
استفاده کنید. مثال زیر نحوه ایجاد یک شیء CronetEngine
را نشان می دهد:
کاتلین
val myBuilder = CronetEngine.Builder(context) val cronetEngine: CronetEngine = myBuilder.build()
جاوا
CronetEngine.Builder myBuilder = new CronetEngine.Builder(context); CronetEngine cronetEngine = myBuilder.build();
شما می توانید از کلاس Builder
برای پیکربندی یک شی CronetEngine
استفاده کنید، به عنوان مثال می توانید گزینه هایی مانند کش و فشرده سازی داده ها را ارائه دهید. برای اطلاعات بیشتر، CronetEngine.Builder
را ببینید.
اجرای درخواست پاسخ به تماس را ارائه دهید
برای ارائه یک پیاده سازی callback، یک زیر کلاس از UrlRequest.Callback
ایجاد کنید و روش های انتزاعی مورد نیاز را مانند مثال زیر پیاده سازی کنید:
کاتلین
private const val TAG = "MyUrlRequestCallback" class MyUrlRequestCallback : UrlRequest.Callback() { override fun onRedirectReceived(request: UrlRequest?, info: UrlResponseInfo?, newLocationUrl: String?) { Log.i(TAG, "onRedirectReceived method called.") // You should call the request.followRedirect() method to continue // processing the request. request?.followRedirect() } override fun onResponseStarted(request: UrlRequest?, info: UrlResponseInfo?) { Log.i(TAG, "onResponseStarted method called.") // You should call the request.read() method before the request can be // further processed. The following instruction provides a ByteBuffer object // with a capacity of 102400 bytes for the read() method. The same buffer // with data is passed to the onReadCompleted() method. request?.read(ByteBuffer.allocateDirect(102400)) } override fun onReadCompleted(request: UrlRequest?, info: UrlResponseInfo?, byteBuffer: ByteBuffer?) { Log.i(TAG, "onReadCompleted method called.") // You should keep reading the request until there's no more data. byteBuffer.clear() request?.read(byteBuffer) } override fun onSucceeded(request: UrlRequest?, info: UrlResponseInfo?) { Log.i(TAG, "onSucceeded method called.") } }
جاوا
class MyUrlRequestCallback extends UrlRequest.Callback { private static final String TAG = "MyUrlRequestCallback"; @Override public void onRedirectReceived(UrlRequest request, UrlResponseInfo info, String newLocationUrl) { Log.i(TAG, "onRedirectReceived method called."); // You should call the request.followRedirect() method to continue // processing the request. request.followRedirect(); } @Override public void onResponseStarted(UrlRequest request, UrlResponseInfo info) { Log.i(TAG, "onResponseStarted method called."); // You should call the request.read() method before the request can be // further processed. The following instruction provides a ByteBuffer object // with a capacity of 102400 bytes for the read() method. The same buffer // with data is passed to the onReadCompleted() method. request.read(ByteBuffer.allocateDirect(102400)); } @Override public void onReadCompleted(UrlRequest request, UrlResponseInfo info, ByteBuffer byteBuffer) { Log.i(TAG, "onReadCompleted method called."); // You should keep reading the request until there's no more data. byteBuffer.clear(); request.read(byteBuffer); } @Override public void onSucceeded(UrlRequest request, UrlResponseInfo info) { Log.i(TAG, "onSucceeded method called."); } }
یک شی Executor برای مدیریت وظایف شبکه ایجاد کنید
می توانید از کلاس Executor
برای اجرای وظایف شبکه استفاده کنید. برای به دست آوردن یک نمونه از Executor
، از یکی از متدهای ثابت کلاس Executors
استفاده کنید که یک شی Executor
را برمی گرداند. مثال زیر نحوه ایجاد یک شی Executor
را با استفاده از متد newSingleThreadExecutor()
نشان می دهد:
کاتلین
val executor: Executor = Executors.newSingleThreadExecutor()
جاوا
Executor executor = Executors.newSingleThreadExecutor();
یک شی UrlRequest ایجاد و پیکربندی کنید
برای ایجاد درخواست شبکه، متد newUrlRequestBuilder()
CronetEngine
را فراخوانی کنید تا URL مقصد، نمونهای از کلاس برگشت تماس شما و شی اجراکننده را ارسال کند. متد newUrlRequestBuilder()
یک شی UrlRequest.Builder
را برمی گرداند که می توانید از آن برای ایجاد شی UrlRequest
استفاده کنید، همانطور که در مثال زیر نشان داده شده است:
کاتلین
val requestBuilder = cronetEngine.newUrlRequestBuilder( "https://www.example.com", MyUrlRequestCallback(), executor ) val request: UrlRequest = requestBuilder.build()
جاوا
UrlRequest.Builder requestBuilder = cronetEngine.newUrlRequestBuilder( "https://www.example.com", new MyUrlRequestCallback(), executor); UrlRequest request = requestBuilder.build();
می توانید از کلاس Builder
برای پیکربندی نمونه UrlRequest
استفاده کنید. به عنوان مثال، می توانید یک اولویت یا فعل HTTP را مشخص کنید. برای اطلاعات بیشتر، به UrlRequest.Builder
مراجعه کنید.
برای شروع کار شبکه، متد start()
درخواست را فراخوانی کنید:
کاتلین
request.start()
جاوا
request.start();
با پیروی از دستورالعمل های این قسمت می توانید با استفاده از کرونت درخواست شبکه ایجاد و ارسال کنید. با این حال، برای سادگی، اجرای مثال UrlRequest.Callback
فقط یک پیام را در گزارش چاپ می کند. بخش زیر نشان میدهد که چگونه میتوان یک پیادهسازی بازگشت به تماس را ارائه کرد که از سناریوهای مفیدتر مانند استخراج دادهها از پاسخ و تشخیص شکست در درخواست پشتیبانی میکند.
پاسخ شبکه را پردازش کنید
هنگامی که متد start()
فراخوانی کردید، چرخه حیات درخواست Cronet آغاز می شود. برنامه شما باید درخواست را در طول چرخه عمر با تعیین یک تماس پاسخ مدیریت کند. برای کسب اطلاعات بیشتر در مورد چرخه حیات، به چرخه عمر درخواست Cronet مراجعه کنید. می توانید با ایجاد یک زیر کلاس از UrlRequest.Callback
و پیاده سازی روش های زیر، یک callback تعیین کنید:
-
onRedirectReceived()
زمانی فراخوانی می شود که سرور در پاسخ به درخواست اصلی، کد تغییر مسیر HTTP را صادر می کند. برای دنبال کردن تغییر مسیر به مقصد جدید، از متد
followRedirect()
استفاده کنید. در غیر این صورت از روشcancel()
استفاده کنید. مثال زیر نحوه پیاده سازی متد را نشان می دهد:کاتلین
override fun onRedirectReceived(request: UrlRequest?, info: UrlResponseInfo?, newLocationUrl: String?) { // Determine whether you want to follow the redirect. ... if (shouldFollow) { request?.followRedirect() } else { request?.cancel() } }
جاوا
@Override public void onRedirectReceived(UrlRequest request, UrlResponseInfo info, String newLocationUrl) { // Determine whether you want to follow the redirect. … if (shouldFollow) { request.followRedirect(); } else { request.cancel(); } }
-
onResponseStarted()
هنگام دریافت مجموعه نهایی سرصفحه ها فراخوانی می شود. متد
onResponseStarted()
فقط پس از دنبال کردن همه تغییر مسیرها فراخوانی می شود. کد زیر نمونه ای از پیاده سازی متد را نشان می دهد:کاتلین
override fun onResponseStarted(request: UrlRequest?, info: UrlResponseInfo?) { val httpStatusCode = info?.httpStatusCode if (httpStatusCode == 200) { // The request was fulfilled. Start reading the response. request?.read(myBuffer) } else if (httpStatusCode == 503) { // The service is unavailable. You should still check if the request // contains some data. request?.read(myBuffer) } responseHeaders = info?.allHeaders }
جاوا
@Override public void onResponseStarted(UrlRequest request, UrlResponseInfo info) { int httpStatusCode = info.getHttpStatusCode(); if (httpStatusCode == 200) { // The request was fulfilled. Start reading the response. request.read(myBuffer); } else if (httpStatusCode == 503) { // The service is unavailable. You should still check if the request // contains some data. request.read(myBuffer); } responseHeaders = info.getAllHeaders(); }
-
onReadCompleted()
هر زمان که بخشی از بدنه پاسخ خوانده شده باشد فراخوانی می شود. مثال کد زیر نحوه پیاده سازی متد و استخراج بدنه پاسخ را نشان می دهد:
کاتلین
override fun onReadCompleted(request: UrlRequest?, info: UrlResponseInfo?, byteBuffer: ByteBuffer?) { // The response body is available, process byteBuffer. ... // Continue reading the response body by reusing the same buffer // until the response has been completed. byteBuffer?.clear() request?.read(myBuffer) }
جاوا
@Override public void onReadCompleted(UrlRequest request, UrlResponseInfo info, ByteBuffer byteBuffer) { // The response body is available, process byteBuffer. … // Continue reading the response body by reusing the same buffer // until the response has been completed. byteBuffer.clear(); request.read(myBuffer); }
-
onSucceeded()
هنگامی که درخواست شبکه با موفقیت تکمیل شد فراخوانی می شود. مثال زیر نحوه پیاده سازی متد را نشان می دهد:
کاتلین
override fun onSucceeded(request: UrlRequest?, info: UrlResponseInfo?) { // The request has completed successfully. }
جاوا
@Override public void onSucceeded(UrlRequest request, UrlResponseInfo info) { // The request has completed successfully. }
-
onFailed()
اگر درخواست به هر دلیلی پس از فراخوانی متد
start()
ناموفق باشد، فراخوانی می شود. مثال زیر نحوه پیاده سازی متد و دریافت اطلاعات مربوط به خطا را نشان می دهد:کاتلین
override fun onFailed(request: UrlRequest?, info: UrlResponseInfo?, error: CronetException?) { // The request has failed. If possible, handle the error. Log.e(TAG, "The request failed.", error) }
جاوا
@Override public void onFailed(UrlRequest request, UrlResponseInfo info, CronetException error) { // The request has failed. If possible, handle the error. Log.e(TAG, "The request failed.", error); }
-
onCanceled()
اگر درخواست با استفاده از متد
cancel()
لغو شده باشد، فراخوانی می شود. پس از فراخوانی، هیچ روش دیگری از کلاسUrlRequest.Callback
فراخوانی نمی شود. می توانید از این روش برای آزادسازی منابع اختصاص داده شده برای پردازش درخواست استفاده کنید. مثال زیر نحوه پیاده سازی متد را نشان می دهد:کاتلین
override fun onCanceled(request: UrlRequest?, info: UrlResponseInfo?) { // Free resources allocated to process this request. ... }
جاوا
@Override public void onCanceled(UrlRequest request, UrlResponseInfo info) { // Free resources allocated to process this request. … }