Bilgisayarınızda ağ işlemleri gerçekleştirmek için Cronet Library'yi nasıl kullanacağınızı öğrenin Android uygulaması. Cronet, kitaplık olarak kullanıma sunulan Chromium ağ yığınıdır oluşturmanız için bir fırsattır. Kitaplık özellikleri hakkında daha fazla bilgi için Aşağıdakileri kullanarak ağ işlemleri gerçekleştirme: Cronet'de bulabilirsiniz.
Projenizde kitaplığı ayarlama
Projenizde Cronet Kitaplığı'na bağımlılık eklemek için şu adımları izleyin:
Android Studio'nun Google'ın Maven deposuna referans içerdiğini doğrulayın projenizin
settings.gradle
dosyasında gösterildiği gibi, örnek:Eski
dependencyResolutionManagement { ... repositories { ... google() } }
Kotlin
dependencyResolutionManagement { ... repositories { ... google() } }
Cronet için Google Play Hizmetleri İstemci Kitaplığı'na referans ekle uygulama modülünüzün
build.gradle
dosyasınındependencies
bölümünde aşağıdaki örnekte gösterilmektedir:Eski
dependencies { implementation 'com.google.android.gms:play-services-cronet:18.0.1' }
Kotlin
dependencies { implementation("com.google.android.gms:play-services-cronet:18.0.1") }
Bu kez CronetEngine
nesne oluşturuldu
Bağımlılık eklendiğinde, Google Play Hizmetleri'nden yüklenen Cronet kullanılır. Telefonla arama
CronetProviderInstaller.installProvider(Context)
beklenmedik istisnaları önlemek için CronetEngine
nesne oluşturmadan önce
CronetEngine
oluşturma sırasında cihazlar gibi hatalar nedeniyle atılmasını engelleme
Google Play hizmetlerinin güncellenmiş bir sürümünü gerektiriyor.
Cronet'in Google Play Hizmetleri'nden yüklenemediği durumlarda
daha düşük performanslı bir uygulamadır. Kullanılacak
bu yedek uygulama, org.chromium.net:cronet-fallback
bağlı
ve new JavaCronetProvider(context).createBuilder()
numaralı telefonu arayın.
Ağ isteği oluşturma
Bu bölümde, Cronet kullanarak nasıl ağ isteği oluşturup göndereceğiniz gösterilmektedir Kitaplık'a dokunun. Ağ isteğini gönderdikten sonra, uygulamanız ağı işlemelidir yanıt ekleyin.
CronetEngine örneği oluşturma ve yapılandırma
Kitaplıkta sunulanlar
CronetEngine.Builder
sınıf
veya örnek oluşturmak için kullanabileceğiniz
CronetEngine
. Aşağıdaki örnek
CronetEngine
nesnesinin nasıl oluşturulduğunu gösterir:
Kotlin
val myBuilder = CronetEngine.Builder(context) val cronetEngine: CronetEngine = myBuilder.build()
Java
CronetEngine.Builder myBuilder = new CronetEngine.Builder(context); CronetEngine cronetEngine = myBuilder.build();
Builder
sınıfını kullanarak bir
CronetEngine
nesnesini sorgulayabilirsiniz.
önbellek ve veri sıkıştırma gibi seçenekler sunar. Daha fazla bilgi için bkz.
CronetEngine.Builder
.
Geri çağırma isteğinin bir uygulamasını sağlayın
Geri çağırmanın uygulanmasını sağlamak için,
UrlRequest.Callback
ve
aşağıdaki örnekte gösterildiği gibi gerekli soyut yöntemleri uygulayın:
Kotlin
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.") } }
Java
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."); } }
Ağ görevlerini yönetmek için Yürütücü nesnesi oluşturma
Ağı yürütmek için Executor
sınıfını kullanabilirsiniz
görevlerden biridir.
Executor
örneği almak için
Executors
sınıfının, şunu döndüren statik yöntemleri:
Executor
nesnesini ifade eder. Aşağıdaki örnekte Executor
oluşturma işleminin nasıl yapılacağı gösterilmektedir
newSingleThreadExecutor()
kullanarak nesne
yöntem:
Kotlin
val executor: Executor = Executors.newSingleThreadExecutor()
Java
Executor executor = Executors.newSingleThreadExecutor();
UrlRequest nesnesi oluşturma ve yapılandırma
Ağ isteğini oluşturmak için
newUrlRequestBuilder()
CronetEngine
hedef URL'yi, geri çağırma sınıfınızın bir örneğini ve yürütücü nesnesini içerir.
newUrlRequestBuilder()
yöntemi,
UrlRequest.Builder
nesne
UrlRequest
oluşturmak için kullanabileceğiniz
nesnesini tanımlayın:
Kotlin
val requestBuilder = cronetEngine.newUrlRequestBuilder( "https://www.example.com", MyUrlRequestCallback(), executor ) val request: UrlRequest = requestBuilder.build()
Java
UrlRequest.Builder requestBuilder = cronetEngine.newUrlRequestBuilder( "https://www.example.com", new MyUrlRequestCallback(), executor); UrlRequest request = requestBuilder.build();
Builder
sınıfını kullanarak şunları yapabilirsiniz:
UrlRequest
örneğini yapılandırın. Örneğin,
Örneğin, bir öncelik veya HTTP fiili belirtebilirsiniz. Daha fazla bilgi için bkz.
UrlRequest.Builder
.
Ağ görevini başlatmak için
İsteğin start()
yöntemi:
Kotlin
request.start()
Java
request.start();
Bu bölümdeki talimatları uygulayarak bir ağ oluşturup gönderebilirsiniz
isteği gönderin. Ancak kolaylık olması açısından,
uygulanması
Yalnızca UrlRequest.Callback
baskılar
günlüğe bir mesaj ekler. Aşağıdaki bölümde, geri arama özelliğinin nasıl sağlanacağı gösterilmektedir
veya başka bir kaynaktan veri ayıklama gibi daha kullanışlı senaryoları destekleyen bir
ve istekte bir hata algılanır.
Ağ yanıtını işleme
start()
yöntemini kullandığınızda, Cronet isteğinin yaşam döngüsü başlatılır. Uygulamanız
isteğini geri çağırmak için kullanır.
yaşam döngüsü için Cronet isteği
yaşam döngüsü boyunca geçerlidir. Hedeflerinize göre bir
bir alt sınıf oluşturarak
UrlRequest.Callback
ve
aşağıdaki yöntemleri uygulayarak:
onRedirectReceived()
Sunucu gerekir. Yeni hedefe giden yönlendirmeyi izlemek için
followRedirect()
yöntemidir. Aksi takdirdecancel()
yöntemidir. Aşağıdaki örnekte, yöntemin nasıl uygulanacağı gösterilmektedir:Kotlin
override fun onRedirectReceived(request: UrlRequest?, info: UrlResponseInfo?, newLocationUrl: String?) { // Determine whether you want to follow the redirect. ... if (shouldFollow) { request?.followRedirect() } else { request?.cancel() } }
Java
@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()
Nihai başlık grubu alındığında çağrılır.
onResponseStarted()
yöntemi yalnızca tüm yönlendirmeler izleildikten sonra çağrılır. Aşağıdaki kod aşağıdaki yöntemin örnek bir uygulamasını gösterir:Kotlin
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 }
Java
@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()
Yanıt gövdesinin bir bölümü her okunduğunda çağrılır. Aşağıdaki kod örnek, yöntemin nasıl uygulanacağını ve yanıt gövdesinin nasıl çıkarılacağını gösterir:
Kotlin
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) }
Java
@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()
Ağ isteği başarıyla tamamlandığında çağrılır. Aşağıdakiler örnek, yöntemin nasıl uygulanacağını gösterir:
Kotlin
override fun onSucceeded(request: UrlRequest?, info: UrlResponseInfo?) { // The request has completed successfully. }
Java
@Override public void onSucceeded(UrlRequest request, UrlResponseInfo info) { // The request has completed successfully. }
onFailed()
Şu tarihten sonra herhangi bir nedenle istek başarısız olursa çağrılır:
start()
yöntemi çağrıldı. İlgili içeriği oluşturmak için kullanılan aşağıdaki örnekte, yöntemin nasıl uygulanacağı gösterilmektedir. Ayrıca, hata:Kotlin
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) }
Java
@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()
İstek
cancel()
yöntemini kullanabilirsiniz. Bir kez çağrıldıktan sonra diğer yöntemlerinUrlRequest.Callback
sınıf çağrılır. Bu yöntemi kullanarak bir isteğinde bulunabilirsiniz. Aşağıdaki örnekte, yöntemin nasıl uygulanacağı gösterilmektedir:Kotlin
override fun onCanceled(request: UrlRequest?, info: UrlResponseInfo?) { // Free resources allocated to process this request. ... }
Java
@Override public void onCanceled(UrlRequest request, UrlResponseInfo info) { // Free resources allocated to process this request. … }