Android - E-posta Gönderme
Email bir ağ aracılığıyla bir sistem kullanıcısından bir veya daha fazla alıcıya elektronik yollarla dağıtılan mesajlardır.
E-posta Etkinliğini başlatmadan önce, E-posta işlevselliğini niyetle bilmelisiniz, Amaç, bir bileşenden başka bir bileşene uygulama içinde veya uygulama dışında veri taşıyor.
Uygulamanızdan bir e-posta göndermek için, en baştan bir e-posta istemcisi uygulamanız gerekmez, ancak Android, Gmail, Outlook, K-9 Mail vb. Tarafından sağlanan varsayılan E-posta uygulaması gibi mevcut bir uygulamayı kullanabilirsiniz. Bunun için amaç olarak, doğru eylem ve verilerle örtük bir Amaç kullanarak bir e-posta istemcisini başlatan bir Etkinlik yazmamız gerekir. Bu örnekte, mevcut e-posta istemcilerini başlatan bir Intent nesnesi kullanarak uygulamamızdan bir e-posta göndereceğiz.
Aşağıdaki bölüm, bir e-posta göndermek için gerekli olan Niyet nesnemizin farklı bölümlerini açıklamaktadır.
Amaç Nesnesi - E-posta gönderme eylemi
Kullanacaksın ACTION_SENDAndroid cihazınızda yüklü bir e-posta istemcisini başlatmak için eylem. Aşağıda, ACTION_SEND işlemiyle bir amaç oluşturmak için basit sözdizimi verilmiştir.
Intent emailIntent = new Intent(Intent.ACTION_SEND);
Amaç Nesnesi - E-posta göndermek için Veri / Tür
Bir e-posta göndermek için belirtmeniz gerekir mailto: setData () yöntemini kullanan URI olarak ve veri türü text/plain setType () yöntemini aşağıdaki gibi kullanarak -
emailIntent.setData(Uri.parse("mailto:"));
emailIntent.setType("text/plain");
Amaç Nesnesi - E-posta göndermek için ekstra
Android, amacı bir hedef e-posta istemcisine göndermeden önce amaca eklenebilen KİME, KONU, CC, METİN vb. Alanları eklemek için yerleşik desteğe sahiptir. E-postanızda aşağıdaki ekstra alanları kullanabilirsiniz -
Sr.No. | Ekstra Veri ve Açıklama |
---|---|
1 | EXTRA_BCC Gizli olarak kopyalanması gereken e-posta adreslerini tutan bir String []. |
2 | EXTRA_CC Karbon olarak kopyalanması gereken e-posta adreslerini tutan bir Dize []. |
3 | EXTRA_EMAIL Teslim edilmesi gereken e-posta adreslerini tutan bir String []. |
4 | EXTRA_HTML_TEXT HTML formatlı metin olarak EXTRA_TEXT'e bir alternatif sağlamak için ACTION_SEND ile kullanılan, Amaçla ilişkilendirilmiş sabit bir Dize. |
5 | EXTRA_SUBJECT Bir mesajın istenen konu satırını tutan sabit bir dize. |
6 | EXTRA_TEXT Gönderilecek değişmez verileri sağlamak için ACTION_SEND ile birlikte kullanılan, Amaç ile ilişkili sabit bir Karakter Dizisi. |
7 | EXTRA_TITLE ACTION_CHOOSER ile kullanıldığında kullanıcıya sağlamak için bir CharSequence iletişim kutusu başlığı. |
İşte amacınıza fazladan veriyi nasıl atayacağınızı gösteren bir örnek:
emailIntent.putExtra(Intent.EXTRA_EMAIL , new String[]{"Recipient"});
emailIntent.putExtra(Intent.EXTRA_SUBJECT, "subject");
emailIntent.putExtra(Intent.EXTRA_TEXT , "Message Body");
Yukarıdaki kodun çıktısı aşağıda bir resimde gösterildiği gibidir
E-posta Örneği
Misal
Aşağıdaki örnek, belirli alıcılara bir E-posta göndermek üzere E-posta istemcisini başlatmak için Amaç nesnesini pratik olarak nasıl kullanacağınızı göstermektedir.
Bu örnekle E-posta denemesi yapmak için, en son Android işletim sistemi ile donatılmış gerçek Mobil cihaza ihtiyacınız olacak, aksi takdirde düzgün çalışmayabilecek emülatörle mücadele edebilirsiniz. İkinci olarak, cihazınızda GMail (varsayılan olarak Gmail istemci Uygulamasına sahip her android sürümünde) veya K9mail gibi bir E-posta istemcisine sahip olmanız gerekir.
Adım | Açıklama |
---|---|
1 | Bir Android uygulaması oluşturmak için Android stüdyosunu kullanacak ve bunu com.example.tutorialspoint paketinin altında Tutorialspoint olarak adlandıracaksınız . |
2 | Src / MainActivity.java dosyasını değiştirin ve e-posta göndermeyle ilgilenmek için gerekli kodu ekleyin. |
3 | Düzen XML dosyasını değiştirin res / layout / activity_main.xml gerekirse herhangi bir GUI bileşeni ekleyin. E-posta İstemcisini başlatmak için basit bir düğme ekliyorum. |
4 | Değiştir res / değerler / strings.xml gerekli sabit değerler tanımlamak için |
5 | AndroidManifest.xml'yi aşağıda gösterildiği gibi değiştirin |
6 | Android öykünücüsünü başlatmak ve uygulamada yapılan değişikliklerin sonucunu doğrulamak için uygulamayı çalıştırın. |
Aşağıda, değiştirilen ana aktivite dosyasının içeriği yer almaktadır src/com.example.Tutorialspoint/MainActivity.java.
package com.example.tutorialspoint;
import android.net.Uri;
import android.os.Bundle;
import android.app.Activity;
import android.content.Intent;
import android.util.Log;
import android.view.Menu;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button startBtn = (Button) findViewById(R.id.sendEmail);
startBtn.setOnClickListener(new View.OnClickListener() {
public void onClick(View view) {
sendEmail();
}
});
}
protected void sendEmail() {
Log.i("Send email", "");
String[] TO = {""};
String[] CC = {""};
Intent emailIntent = new Intent(Intent.ACTION_SEND);
emailIntent.setData(Uri.parse("mailto:"));
emailIntent.setType("text/plain");
emailIntent.putExtra(Intent.EXTRA_EMAIL, TO);
emailIntent.putExtra(Intent.EXTRA_CC, CC);
emailIntent.putExtra(Intent.EXTRA_SUBJECT, "Your subject");
emailIntent.putExtra(Intent.EXTRA_TEXT, "Email message goes here");
try {
startActivity(Intent.createChooser(emailIntent, "Send mail..."));
finish();
Log.i("Finished sending email...", "");
} catch (android.content.ActivityNotFoundException ex) {
Toast.makeText(MainActivity.this, "There is no email client installed.", Toast.LENGTH_SHORT).show();
}
}
}
Aşağıdakilerin içeriği olacak res/layout/activity_main.xml dosya -
Burada abc, tutorialspoint logosu hakkında bilgi verir
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Sending Mail Example"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:textSize="30dp" />
<TextView
android:id="@+id/textView2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Tutorials point "
android:textColor="#ff87ff09"
android:textSize="30dp"
android:layout_above="@+id/imageButton"
android:layout_alignRight="@+id/imageButton"
android:layout_alignEnd="@+id/imageButton" />
<ImageButton
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/imageButton"
android:src="@drawable/abc"
android:layout_centerVertical="true"
android:layout_centerHorizontal="true" />
<Button
android:id="@+id/sendEmail"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/compose_email"/>
</LinearLayout>
Aşağıdakilerin içeriği olacak res/values/strings.xml iki yeni sabit tanımlamak için -
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="app_name">Tutorialspoint</string>
<string name="compose_email">Compose Email</string>
</resources>
Aşağıdaki varsayılan içeriktir AndroidManifest.xml -
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.Tutorialspoint" >
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name="com.example.tutorialspoint.MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
Hadi çalıştırmayı deneyelim tutorialspointuygulama. Gerçek Android Mobil cihazınızı bilgisayarınıza bağladığınızı varsayıyorum. Uygulamayı Android Studio'dan çalıştırmak için, projenizin etkinlik dosyalarından birini açın
Şimdi kullan Compose EmailTüm yüklü e-posta istemcilerini listelemek için düğmesine basın. Listeden, e-postanızı göndermek için e-posta istemcilerinden birini seçebilirsiniz. Sağlanan tüm varsayılan alanların aşağıda gösterildiği gibi mevcut olacak olan e-postamı göndermek için Gmail istemcisini kullanacağım. BurayaFrom: Android cihazınız için kaydettiğiniz varsayılan e-posta kimliği olacaktır.
Verilen varsayılan alanlardan birini değiştirebilir ve son olarak e-postanızı belirtilen alıcılara göndermek için e-posta gönder düğmesini kullanabilirsiniz.