ডিফল্ট / অন্তর্নির্মিত অ্যাপ্লিকেশনটি ব্যবহার না করেই জাভমেল এপিআই ব্যবহার করে অ্যান্ড্রয়েডে ইমেল প্রেরণ


653

আমি অ্যান্ড্রয়েডে একটি মেল প্রেরণ অ্যাপ্লিকেশন তৈরি করার চেষ্টা করছি।

যদি আমি ব্যবহার করি:

Intent emailIntent = new Intent(android.content.Intent.ACTION_SEND);

এটি বিল্ট-ইন অ্যান্ড্রয়েড অ্যাপ্লিকেশন চালু করবে; আমি এই অ্যাপ্লিকেশনটি ব্যবহার না করে সরাসরি বোতামে মেলটি প্রেরণের চেষ্টা করছি ।


3
javax.mail.AuthenticationFiledException ইমেল প্রেরণের সময় ব্যবহারকারী / পাসওয়ার্ড ভেবেচিন্তে সঠিক হয়। কোন সমাধান?
টিডি এনগুইন

1
নোট করুন যে 1.5.5 হিসাবে,
জাভামেল

1
নয় SendGrid একটি বিকল্প? যতদূর আমি জানি যে আপনি প্রেরিত ইমাইয়ের পরিসংখ্যান পাওয়ার সম্ভাবনাও রয়েছে
স্টাম্যাটিস স্টিলিয়টস

উত্তর:


757

Gmail প্রমাণীকরণ ব্যবহার করে জাভমেল এপিআই ব্যবহার করে অ্যান্ড্রয়েডে ই-মেল প্রেরণ করুন।

একটি নমুনা প্রকল্প তৈরি করার পদক্ষেপ:

MailSenderActivity.java:

public class MailSenderActivity extends Activity {

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        final Button send = (Button) this.findViewById(R.id.send);
        send.setOnClickListener(new View.OnClickListener() {

            public void onClick(View v) {
                try {   
                    GMailSender sender = new GMailSender("username@gmail.com", "password");
                    sender.sendMail("This is Subject",   
                            "This is Body",   
                            "user@gmail.com",   
                            "user@yahoo.com");   
                } catch (Exception e) {   
                    Log.e("SendMail", e.getMessage(), e);   
                } 

            }
        });

    }
}

GMailSender.java:

public class GMailSender extends javax.mail.Authenticator {   
    private String mailhost = "smtp.gmail.com";   
    private String user;   
    private String password;   
    private Session session;   

    static {   
        Security.addProvider(new com.provider.JSSEProvider());   
    }  

    public GMailSender(String user, String password) {   
        this.user = user;   
        this.password = password;   

        Properties props = new Properties();   
        props.setProperty("mail.transport.protocol", "smtp");   
        props.setProperty("mail.host", mailhost);   
        props.put("mail.smtp.auth", "true");   
        props.put("mail.smtp.port", "465");   
        props.put("mail.smtp.socketFactory.port", "465");   
        props.put("mail.smtp.socketFactory.class",   
                "javax.net.ssl.SSLSocketFactory");   
        props.put("mail.smtp.socketFactory.fallback", "false");   
        props.setProperty("mail.smtp.quitwait", "false");   

        session = Session.getDefaultInstance(props, this);   
    }   

    protected PasswordAuthentication getPasswordAuthentication() {   
        return new PasswordAuthentication(user, password);   
    }   

    public synchronized void sendMail(String subject, String body, String sender, String recipients) throws Exception {   
        try{
        MimeMessage message = new MimeMessage(session);   
        DataHandler handler = new DataHandler(new ByteArrayDataSource(body.getBytes(), "text/plain"));   
        message.setSender(new InternetAddress(sender));   
        message.setSubject(subject);   
        message.setDataHandler(handler);   
        if (recipients.indexOf(',') > 0)   
            message.setRecipients(Message.RecipientType.TO, InternetAddress.parse(recipients));   
        else  
            message.setRecipient(Message.RecipientType.TO, new InternetAddress(recipients));   
        Transport.send(message);   
        }catch(Exception e){

        }
    }   

    public class ByteArrayDataSource implements DataSource {   
        private byte[] data;   
        private String type;   

        public ByteArrayDataSource(byte[] data, String type) {   
            super();   
            this.data = data;   
            this.type = type;   
        }   

        public ByteArrayDataSource(byte[] data) {   
            super();   
            this.data = data;   
        }   

        public void setType(String type) {   
            this.type = type;   
        }   

        public String getContentType() {   
            if (type == null)   
                return "application/octet-stream";   
            else  
                return type;   
        }   

        public InputStream getInputStream() throws IOException {   
            return new ByteArrayInputStream(data);   
        }   

        public String getName() {   
            return "ByteArrayDataSource";   
        }   

        public OutputStream getOutputStream() throws IOException {   
            throw new IOException("Not Supported");   
        }   
    }   
}  

JSSEProvider.java:

/*
 *  Licensed to the Apache Software Foundation (ASF) under one or more
 *  contributor license agreements.  See the NOTICE file distributed with
 *  this work for additional information regarding copyright ownership.
 *  The ASF licenses this file to You under the Apache License, Version 2.0
 *  (the "License"); you may not use this file except in compliance with
 *  the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 */

/**
 * @author Alexander Y. Kleymenov
 * @version $Revision$
 */


import java.security.AccessController;
import java.security.Provider;

public final class JSSEProvider extends Provider {

    public JSSEProvider() {
        super("HarmonyJSSE", 1.0, "Harmony JSSE Provider");
        AccessController.doPrivileged(new java.security.PrivilegedAction<Void>() {
            public Void run() {
                put("SSLContext.TLS",
                        "org.apache.harmony.xnet.provider.jsse.SSLContextImpl");
                put("Alg.Alias.SSLContext.TLSv1", "TLS");
                put("KeyManagerFactory.X509",
                        "org.apache.harmony.xnet.provider.jsse.KeyManagerFactoryImpl");
                put("TrustManagerFactory.X509",
                        "org.apache.harmony.xnet.provider.jsse.TrustManagerFactoryImpl");
                return null;
            }
        });
    }
}

আপনার অ্যান্ড্রয়েড প্রকল্পের নীচের লিঙ্কটিতে 3 টি জার যুক্ত করুন

এখানে ক্লিক করুন - কিভাবে বহিরাগত জার যোগ করতে

এবং আপনার ম্যানিফেস্টে এই লাইনটি যুক্ত করতে ভুলবেন না:

<uses-permission android:name="android.permission.INTERNET" />

শুধু কম সুরক্ষিত অ্যাপ্লিকেশানের জন্য পরিবর্তন অ্যাকাউন্ট অ্যাক্সেস করতে লিঙ্কটি নীচে ক্লিক https://www.google.com/settings/security/lesssecureapps

প্রকল্পটি চালান এবং মেলটির জন্য আপনার প্রাপক মেল অ্যাকাউন্টটি পরীক্ষা করুন। চিয়ার্স!

পিএস এবং ভুলে যাবেন না যে আপনি অ্যান্ড্রয়েডের কোনও ক্রিয়াকলাপ থেকে নেটওয়ার্ক অপারেশন করতে পারবেন না। অতএব এটি ব্যবহার করতে AsyncTaskবা IntentServiceমূল থ্রেড ব্যতিক্রমের নেটওয়ার্ক এড়ানো বাঞ্ছনীয় ।

জার ফাইলগুলি: https://code.google.com/archive/p/javamail-android/


52
আপনার কোডটি হার্ড কোডিং ব্যবহারকারীর নাম এবং পাসওয়ার্ড ব্যবহার করে বলে মনে হচ্ছে। এটি কি এখন কোনও সুরক্ষা ঝুঁকিপূর্ণ (অর্থাত, বাজারে আপলোড হওয়া এপিপিগুলি কি ক্ষয় হয়ে গেছে)?
ধনী

11
আমার জন্য কাজ !!! আপনার অ্যাপ্লিকেশন যুক্ত করতে ব্যবহারের অনুমতি ইন্টারনেট প্রকাশ করতে ভুলবেন না
আভি শুক্রন

15
কোডে পাসওয়ার্ড না রেখে কোনও ইমেল পাঠানোর উপায় আছে কি? আমি মনে করি ব্যবহারকারীরা যদি তাদের ইমেল ডাব্লুডুব জন্য জিজ্ঞাসা করতেন তবে তারা চমকে উঠবে ...
ডাব্লুডুব পাম্পি

7
হাই কোড জন্য ধন্যবাদ। কিন্তু আমি GMailSender প্রেরকের উপর java.lang.NoClassDefFoundError পেয়েছি = নতুন GMailSender (...) মেইলসেন্ডেরিটিভিটিতে। আমি সমস্ত জারগুলি অন্তর্ভুক্ত করেছি এবং পথ তৈরিতে যুক্ত করেছি। আমি এটি সমাধান করার জন্য কিছু সময় ব্যয় করেছি b তবে আমি সমাধান পাই না। আমাকে সাহায্য করুন.
মামুরালি

53
ব্যবহারকারীদের পাসওয়ার্ড কীভাবে পাবেন সে সম্পর্কে যারা অভিযোগ করছেন / জিজ্ঞাসা করছেন তাদের পক্ষে - এটি এখানে ধারণা নয়। এটি আপনার (বিকাশকারী) ই-মেইল অ্যাকাউন্টের সাথে ব্যবহার করার উদ্দেশ্যে। আপনি যদি ব্যবহারকারীর ই-মেইল অ্যাকাউন্টের উপর নির্ভর করতে চান তবে আপনার ই-মেইল উদ্দেশ্যটি ব্যবহার করা উচিত, যা অন্যান্য পোস্টগুলিতে বহুল আলোচিত discussed
টম

70

আপনার মূল্যবান তথ্যের জন্য আপনাকে ধন্যবাদ। কোড ভাল কাজ করছে। আমি নিম্নলিখিত কোড যুক্ত করে সংযুক্তি যুক্ত করতে সক্ষম হয়েছি।

private Multipart _multipart; 
_multipart = new MimeMultipart(); 

public void addAttachment(String filename,String subject) throws Exception { 
    BodyPart messageBodyPart = new MimeBodyPart(); 
    DataSource source = new FileDataSource(filename); 
    messageBodyPart.setDataHandler(new DataHandler(source)); 
    messageBodyPart.setFileName(filename); 
    _multipart.addBodyPart(messageBodyPart);

    BodyPart messageBodyPart2 = new MimeBodyPart(); 
    messageBodyPart2.setText(subject); 

    _multipart.addBodyPart(messageBodyPart2); 
} 



message.setContent(_multipart);

6
এটি GmailSender.java এ যোগ করুন
আবর্জনা

যখন আমি সেট কনটেন্টকে কল করি তখন এটি আমার দেহের সামগ্রীকে ওভাররোট করে। আমি কি কিছু ভুল করছি আমি অন্যান্য পাঠ্য দেহের সামগ্রীর সাথে সংযুক্তি যুক্ত করতে চাই
ক্যালভিন

1
জন্য filenameপরিবর্তনশীল এখানে, আপনি ফাইল পাথ নির্দিষ্ট করতে হবে। উদাহরণস্বরূপ:String path = Environment.getExternalStorageDirectory().getPath() + "/temp_share.jpg";

এই কোডটি আপনাকে একাধিক ফাইল যুক্ত করতে সহায়তা করে stackoverflow.com/a/3177640/2811343 ;) :)
AndroidManifester

54

এসএমটিপি হোস্টের সাথে সংযোগ করতে পারেনি: smtp.gmail.com, পোর্ট: 465

আপনার ম্যানিফেস্টে এই লাইনটি যুক্ত করুন:

<uses-permission android:name="android.permission.INTERNET" />

39

আপনি নিজের ইমেল কার্য পরিচালনা করতে জাভমেল এপিআই ব্যবহার করতে পারেন। জাভামেল এপিআই জাভাEE প্যাকেজে উপলব্ধ এবং এর জারটি ডাউনলোডের জন্য উপলব্ধ। দুঃখের বিষয় এটি এন্ড্রয়েড অ্যাপ্লিকেশনটিতে সরাসরি ব্যবহার করা যাবে না কারণ এটি এডাব্লুটি উপাদান ব্যবহার করে যা অ্যান্ড্রয়েডে সম্পূর্ণ বেমানান।

আপনি নিম্নলিখিত স্থানে জাভামেলের জন্য অ্যান্ড্রয়েড বন্দরটি পেতে পারেন: http://code.google.com/p/javamail-android/

আপনার অ্যাপ্লিকেশনটিতে জারগুলি যুক্ত করুন এবং এসএমটিপি পদ্ধতিটি ব্যবহার করুন


1
এর জন্য কোনও মেভেন ভাণ্ডার?
ব্যবহারকারী 1050755

দুঃখিত তবে আমি সে সম্পর্কে অবগত নই
ক্ষিতিজ আগরওয়াল

6
আমি সর্বশেষতম জাভামিলটি পোর্ট করেছি এবং এটি ম্যাভেন সেন্ট্রাল-এর অধীনে উপলব্ধ রয়েছেeu.ocathain.com.sun.mail:javax.mail:1.5.2
আর্টব্রিজটল

29

এসডিকে টার্গেট> 9 দিয়ে একটি নেটওয়ার্ক অন মেন থ্রেড ব্যতিক্রম প্রাপ্তদের সহায়তা করার জন্য। এটি উপরে droopie কোড ব্যবহার করছে তবে যে কোনওর জন্য একইভাবে কাজ করবে।

StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();

StrictMode.setThreadPolicy(policy); 

android.os.NetworkOnMainThreadException

আপনি নীচে AsyncTask ব্যবহার করতে পারেন

public void onClickMail(View view) {
    new SendEmailAsyncTask().execute();
}

class SendEmailAsyncTask extends AsyncTask <Void, Void, Boolean> {
    Mail m = new Mail("from@gmail.com", "my password");

    public SendEmailAsyncTask() {
        if (BuildConfig.DEBUG) Log.v(SendEmailAsyncTask.class.getName(), "SendEmailAsyncTask()");
        String[] toArr = { "to mail@gmail.com"};
        m.setTo(toArr);
        m.setFrom("from mail@gmail.com");
        m.setSubject("Email from Android");
        m.setBody("body.");
    }

    @Override
    protected Boolean doInBackground(Void... params) {
        if (BuildConfig.DEBUG) Log.v(SendEmailAsyncTask.class.getName(), "doInBackground()");
        try {
            m.send();
            return true;
        } catch (AuthenticationFailedException e) {
            Log.e(SendEmailAsyncTask.class.getName(), "Bad account details");
            e.printStackTrace();
            return false;
        } catch (MessagingException e) {
            Log.e(SendEmailAsyncTask.class.getName(), m.getTo(null) + "failed");
            e.printStackTrace();
            return false;
        } catch (Exception e) {
            e.printStackTrace();
            return false;
        }
    }

এই শ্রেণিটি কোথায় যুক্ত করবেন
গুণসিলান

25

ডেমো সহ 100% কার্যকারী কোড আপনি এই উত্তরটি ব্যবহার করে একাধিক ইমেলও প্রেরণ করতে পারেন।

প্রকল্প এখানে ডাউনলোড করুন

পদক্ষেপ 1: মেল, অ্যাক্টিভেশন, সংযোজনযুক্ত জার ফাইলগুলি ডাউনলোড করুন এবং অ্যান্ড্রয়েড স্টুডিওতে আপনার প্রকল্পের libs ফোল্ডারে যুক্ত করুন । আমি নীচে ডাউনলোড লিঙ্ক দেখুন একটি স্ক্রিন শট যুক্ত

libs যোগ করুন

Gmail এর সাথে লগ-ইন ( মেইল থেকে আপনার ব্যবহার ) এবং চালু বোতাম টগল LINK এ

বেশিরভাগ লোক এই পদক্ষেপটি ভুলে যায় আশা করি আপনি এটি করবেন না।

পদক্ষেপ 2: এই প্রক্রিয়াটি শেষ করার পরে। আপনার প্রকল্পে এই ক্লাসগুলি অনুলিপি করুন এবং গত করুন।

GMail.java

import android.util.Log;

import java.io.UnsupportedEncodingException;
import java.util.List;
import java.util.Properties;

import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.AddressException;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;

public class GMail {

    final String emailPort = "587";// gmail's smtp port
    final String smtpAuth = "true";
    final String starttls = "true";
    final String emailHost = "smtp.gmail.com";


    String fromEmail;
    String fromPassword;
    List<String> toEmailList;
    String emailSubject;
    String emailBody;

    Properties emailProperties;
    Session mailSession;
    MimeMessage emailMessage;

    public GMail() {

    }

    public GMail(String fromEmail, String fromPassword,
            List<String> toEmailList, String emailSubject, String emailBody) {
        this.fromEmail = fromEmail;
        this.fromPassword = fromPassword;
        this.toEmailList = toEmailList;
        this.emailSubject = emailSubject;
        this.emailBody = emailBody;

        emailProperties = System.getProperties();
        emailProperties.put("mail.smtp.port", emailPort);
        emailProperties.put("mail.smtp.auth", smtpAuth);
        emailProperties.put("mail.smtp.starttls.enable", starttls);
        Log.i("GMail", "Mail server properties set.");
    }

    public MimeMessage createEmailMessage() throws AddressException,
            MessagingException, UnsupportedEncodingException {

        mailSession = Session.getDefaultInstance(emailProperties, null);
        emailMessage = new MimeMessage(mailSession);

        emailMessage.setFrom(new InternetAddress(fromEmail, fromEmail));
        for (String toEmail : toEmailList) {
            Log.i("GMail", "toEmail: " + toEmail);
            emailMessage.addRecipient(Message.RecipientType.TO,
                    new InternetAddress(toEmail));
        }

        emailMessage.setSubject(emailSubject);
        emailMessage.setContent(emailBody, "text/html");// for a html email
        // emailMessage.setText(emailBody);// for a text email
        Log.i("GMail", "Email Message created.");
        return emailMessage;
    }

    public void sendEmail() throws AddressException, MessagingException {

        Transport transport = mailSession.getTransport("smtp");
        transport.connect(emailHost, fromEmail, fromPassword);
        Log.i("GMail", "allrecipients: " + emailMessage.getAllRecipients());
        transport.sendMessage(emailMessage, emailMessage.getAllRecipients());
        transport.close();
        Log.i("GMail", "Email sent successfully.");
    }

}

SendMailTask.java

import android.app.Activity;
import android.app.ProgressDialog;
import android.os.AsyncTask;
import android.util.Log;

import java.util.List;

public class SendMailTask extends AsyncTask {

    private ProgressDialog statusDialog;
    private Activity sendMailActivity;

    public SendMailTask(Activity activity) {
        sendMailActivity = activity;

    }

    protected void onPreExecute() {
        statusDialog = new ProgressDialog(sendMailActivity);
        statusDialog.setMessage("Getting ready...");
        statusDialog.setIndeterminate(false);
        statusDialog.setCancelable(false);
        statusDialog.show();
    }

    @Override
    protected Object doInBackground(Object... args) {
        try {
            Log.i("SendMailTask", "About to instantiate GMail...");
            publishProgress("Processing input....");
            GMail androidEmail = new GMail(args[0].toString(),
                    args[1].toString(), (List) args[2], args[3].toString(),
                    args[4].toString());
            publishProgress("Preparing mail message....");
            androidEmail.createEmailMessage();
            publishProgress("Sending email....");
            androidEmail.sendEmail();
            publishProgress("Email Sent.");
            Log.i("SendMailTask", "Mail Sent.");
        } catch (Exception e) {
            publishProgress(e.getMessage());
            Log.e("SendMailTask", e.getMessage(), e);
        }
        return null;
    }

    @Override
    public void onProgressUpdate(Object... values) {
        statusDialog.setMessage(values[0].toString());

    }

    @Override
    public void onPostExecute(Object result) {
        statusDialog.dismiss();
    }

}

পদক্ষেপ 3: এখন আপনি এই ক্লাসটি আপনার প্রয়োজন অনুসারে পরিবর্তন করতে পারেন এছাড়াও আপনি এই ক্লাসটি ব্যবহার করে একাধিক মেল পাঠাতে পারেন। আমি এক্সএমএল এবং জাভা ফাইল উভয়ই সরবরাহ করি।

activity_mail.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:paddingLeft="20dp"
    android:paddingRight="20dp"
    android:paddingTop="30dp">

    <TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingTop="10dp"
        android:text="From Email" />

    <EditText
        android:id="@+id/editText1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#FFFFFF"
        android:cursorVisible="true"
        android:editable="true"
        android:ems="10"
        android:enabled="true"
        android:inputType="textEmailAddress"
        android:padding="5dp"
        android:textColor="#000000">

        <requestFocus />
    </EditText>

    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingTop="10dp"
        android:text="Password (For from email)" />

    <EditText
        android:id="@+id/editText2"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#FFFFFF"
        android:ems="10"
        android:inputType="textPassword"
        android:padding="5dp"
        android:textColor="#000000" />

    <TextView
        android:id="@+id/textView3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingTop="10dp"
        android:text="To Email" />

    <EditText
        android:id="@+id/editText3"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#ffffff"
        android:ems="10"
        android:inputType="textEmailAddress"
        android:padding="5dp"
        android:textColor="#000000" />

    <TextView
        android:id="@+id/textView4"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingTop="10dp"
        android:text="Subject" />

    <EditText
        android:id="@+id/editText4"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#ffffff"
        android:ems="10"
        android:padding="5dp"
        android:textColor="#000000" />

    <TextView
        android:id="@+id/textView5"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingTop="10dp"
        android:text="Body" />

    <EditText
        android:id="@+id/editText5"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#ffffff"
        android:ems="10"
        android:inputType="textMultiLine"
        android:padding="35dp"
        android:textColor="#000000" />

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Send Email" />

</LinearLayout>

SendMailActivity.java

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;

import java.util.Arrays;
import java.util.List;

public class SendMailActivity extends Activity {

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        final Button send = (Button) this.findViewById(R.id.button1);

        send.setOnClickListener(new View.OnClickListener() {

            public void onClick(View v) {
                Log.i("SendMailActivity", "Send Button Clicked.");

                String fromEmail = ((TextView) findViewById(R.id.editText1))
                        .getText().toString();
                String fromPassword = ((TextView) findViewById(R.id.editText2))
                        .getText().toString();
                String toEmails = ((TextView) findViewById(R.id.editText3))
                        .getText().toString();
                List<String> toEmailList = Arrays.asList(toEmails
                        .split("\\s*,\\s*"));
                Log.i("SendMailActivity", "To List: " + toEmailList);
                String emailSubject = ((TextView) findViewById(R.id.editText4))
                        .getText().toString();
                String emailBody = ((TextView) findViewById(R.id.editText5))
                        .getText().toString();
                new SendMailTask(SendMailActivity.this).execute(fromEmail,
                        fromPassword, toEmailList, emailSubject, emailBody);
            }
        });
    }
}

দ্রষ্টব্য আপনার AndroidManLive.xML ফাইলে ইন্টারনেট অনুমতি যুক্ত করতে ভুলবেন না

<uses-permission android:name="android.permission.INTERNET"/>

আশা করি এটি যদি কাজ না করে তবে নীচে কেবল নীচে মন্তব্য করুন।


2
এটি কি নিরাপদ? যদি আমি হার্ডকোডযুক্ত ব্যবহারকারী এবং পাসওয়ার্ড দিয়ে "ফর্মইমেইল" এবং "থেকে পাসওয়ার্ড" প্রতিস্থাপন করি, তবে আমাকে কি সুরক্ষা সংক্রান্ত সমস্যা সম্পর্কে চিন্তা করতে হবে?
যোনাহ কার্প

আপনার পদ্ধতি ব্যবহার করে কি ইমেল পাওয়া সম্ভব? আমি একটি ইমেল পেতে চাই
user3051460

1
@ আরপিটপ্যাটেল এটি খুব সুন্দর করে কাজ করে। তবে আমি সুরক্ষা নিয়েও উদ্বিগ্ন। আপনি যদি জিমেইল ব্যবহার করেন, গুগল এমন কিছু অ্যাপ্লিকেশনকে ব্লক করতে পারে যা কেবল এটি করার চেষ্টা করে।
টোটুমাস ম্যাক্সিমাস

@ টোটুমাস ম্যাক্সিমাস যদি আপনি এপিআই ব্যবহার করে নিজের ইমেল এবং পাসওয়ার্ড ব্যবহার করতে পারেন তার চেয়ে সুরক্ষার বিষয়ে উদ্বিগ্ন হন
অর্পিত প্যাটেল

23

SMTP এর

এসএমটিপি ব্যবহার করা একদিকই পথ, এবং অন্যরা কীভাবে এটি করবেন তা ইতিমধ্যে নির্দেশ করেছেন। কেবলমাত্র নোট করুন যে এটি করার সময়, আপনি সম্পূর্ণরূপে বিল্ট ইন মেল অ্যাপ্লিকেশনটিকে ঘৃণা করেন এবং আপনাকে এই কোডটি স্থায়ীভাবে নিজের কোডে, এসএমটিপি সার্ভারের ঠিকানা, ব্যবহারকারীর নাম এবং পাসওয়ার্ড সরবরাহ করতে হবে বা ব্যবহারকারীর কাছ থেকে জিজ্ঞাসা করতে হবে ।

HTTP- র

অন্য কোনও উপায়ে পিএইচপি এর মতো একটি সাধারণ সার্ভার সাইড স্ক্রিপ্ট জড়িত হবে যা কিছু ইউআরএল প্যারামিটার নেয় এবং মেল প্রেরণে সেগুলি ব্যবহার করে। এইভাবে, আপনাকে কেবল ডিভাইস থেকে একটি HTTP অনুরোধ করতে হবে (লাইব্রেরিতে অন্তর্নির্মিত দিয়ে সহজেই সম্ভব) এবং ডিভাইসে এসএমটিপি লগইন ডেটা সঞ্চয় করার দরকার নেই। এটি সরাসরি এসএমটিপি ব্যবহারের তুলনায় আরও একটি নির্দেশনা, তবে এইচটিটিপি অনুরোধ করা এবং পিএইচপি থেকে মেলগুলি প্রেরণ করা খুব সহজ, এটি সরাসরি পথের চেয়ে সহজও হতে পারে।

মেল অ্যাপ্লিকেশন

যদি তিনি মেইল ​​ব্যবহারকারীদের ডিফল্ট মেল অ্যাকাউন্ট থেকে প্রেরণ করা হয় যা তিনি ইতিমধ্যে ফোনে নিবন্ধভুক্ত করেছেন, আপনাকে অন্য কোনও পদ্ধতি গ্রহণ করতে হবে। আপনার যদি পর্যাপ্ত সময় এবং অভিজ্ঞতা থাকে তবে আপনি অ্যান্ড্রয়েড ইমেল অ্যাপ্লিকেশনটির উত্স কোডটি পরীক্ষা করে দেখতে চান এটি ব্যবহারকারীর মিথস্ক্রিয়া ছাড়াই কোনও মেল প্রেরণের জন্য কোনও এন্ট্রি পয়েন্ট সরবরাহ করে কিনা (আমি জানি না, তবে সম্ভবত একটি আছে)।

এমনকি আপনি ব্যবহারকারীদের অ্যাকাউন্টের বিশদ অনুসন্ধানের উপায় খুঁজে পেয়েছেন (যাতে আপনি এটি এসএমটিপির জন্য ব্যবহার করতে পারেন), যদিও আমি অত্যন্ত সন্দেহ করি যে এটি সম্ভব, কারণ এটি একটি বিশাল সুরক্ষা ঝুঁকি হতে পারে এবং অ্যান্ড্রয়েড বরং সুরক্ষিতভাবে নির্মিত হয়েছে।


22

এখানে একটি Alt সংস্করণ যা আমার জন্যও কাজ করে এবং সংযুক্তি রয়েছে (উত্সের লিঙ্কের বিপরীতে ইতিমধ্যে উপরে তবে সম্পূর্ণ সংস্করণ, যা লোকেরা পোস্ট করেছে এটি হারিয়ে যাওয়ার তথ্য থেকে এটি কাজ করতে পারে না)

import java.util.Date; 
import java.util.Properties; 
import javax.activation.CommandMap; 
import javax.activation.DataHandler; 
import javax.activation.DataSource; 
import javax.activation.FileDataSource; 
import javax.activation.MailcapCommandMap; 
import javax.mail.BodyPart; 
import javax.mail.Multipart; 
import javax.mail.PasswordAuthentication; 
import javax.mail.Session; 
import javax.mail.Transport; 
import javax.mail.internet.InternetAddress; 
import javax.mail.internet.MimeBodyPart; 
import javax.mail.internet.MimeMessage; 
import javax.mail.internet.MimeMultipart; 


public class Mail extends javax.mail.Authenticator { 
  private String _user; 
  private String _pass; 

  private String[] _to; 
  private String _from; 

  private String _port; 
  private String _sport; 

  private String _host; 

  private String _subject; 
  private String _body; 

  private boolean _auth; 

  private boolean _debuggable; 

  private Multipart _multipart; 


  public Mail() { 
    _host = "smtp.gmail.com"; // default smtp server 
    _port = "465"; // default smtp port 
    _sport = "465"; // default socketfactory port 

    _user = ""; // username 
    _pass = ""; // password 
    _from = ""; // email sent from 
    _subject = ""; // email subject 
    _body = ""; // email body 

    _debuggable = false; // debug mode on or off - default off 
    _auth = true; // smtp authentication - default on 

    _multipart = new MimeMultipart(); 

    // There is something wrong with MailCap, javamail can not find a handler for the multipart/mixed part, so this bit needs to be added. 
    MailcapCommandMap mc = (MailcapCommandMap) CommandMap.getDefaultCommandMap(); 
    mc.addMailcap("text/html;; x-java-content-handler=com.sun.mail.handlers.text_html"); 
    mc.addMailcap("text/xml;; x-java-content-handler=com.sun.mail.handlers.text_xml"); 
    mc.addMailcap("text/plain;; x-java-content-handler=com.sun.mail.handlers.text_plain"); 
    mc.addMailcap("multipart/*;; x-java-content-handler=com.sun.mail.handlers.multipart_mixed"); 
    mc.addMailcap("message/rfc822;; x-java-content-handler=com.sun.mail.handlers.message_rfc822"); 
    CommandMap.setDefaultCommandMap(mc); 
  } 

  public Mail(String user, String pass) { 
    this(); 

    _user = user; 
    _pass = pass; 
  } 

  public boolean send() throws Exception { 
    Properties props = _setProperties(); 

    if(!_user.equals("") && !_pass.equals("") && _to.length > 0 && !_from.equals("") && !_subject.equals("") && !_body.equals("")) { 
      Session session = Session.getInstance(props, this); 

      MimeMessage msg = new MimeMessage(session); 

      msg.setFrom(new InternetAddress(_from)); 

      InternetAddress[] addressTo = new InternetAddress[_to.length]; 
      for (int i = 0; i < _to.length; i++) { 
        addressTo[i] = new InternetAddress(_to[i]); 
      } 
        msg.setRecipients(MimeMessage.RecipientType.TO, addressTo); 

      msg.setSubject(_subject); 
      msg.setSentDate(new Date()); 

      // setup message body 
      BodyPart messageBodyPart = new MimeBodyPart(); 
      messageBodyPart.setText(_body); 
      _multipart.addBodyPart(messageBodyPart); 

      // Put parts in message 
      msg.setContent(_multipart); 

      // send email 
      Transport.send(msg); 

      return true; 
    } else { 
      return false; 
    } 
  } 

  public void addAttachment(String filename) throws Exception { 
    BodyPart messageBodyPart = new MimeBodyPart(); 
    DataSource source = new FileDataSource(filename); 
    messageBodyPart.setDataHandler(new DataHandler(source)); 
    messageBodyPart.setFileName(filename); 

    _multipart.addBodyPart(messageBodyPart); 
  } 

  @Override 
  public PasswordAuthentication getPasswordAuthentication() { 
    return new PasswordAuthentication(_user, _pass); 
  } 

  private Properties _setProperties() { 
    Properties props = new Properties(); 

    props.put("mail.smtp.host", _host); 

    if(_debuggable) { 
      props.put("mail.debug", "true"); 
    } 

    if(_auth) { 
      props.put("mail.smtp.auth", "true"); 
    } 

    props.put("mail.smtp.port", _port); 
    props.put("mail.smtp.socketFactory.port", _sport); 
    props.put("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory"); 
    props.put("mail.smtp.socketFactory.fallback", "false"); 

    return props; 
  } 

  // the getters and setters 
  public String getBody() { 
    return _body; 
  } 

  public void setBody(String _body) { 
    this._body = _body; 
  }

  public void setTo(String[] toArr) {
      // TODO Auto-generated method stub
      this._to=toArr;
  }

  public void setFrom(String string) {
      // TODO Auto-generated method stub
      this._from=string;
  }

  public void setSubject(String string) {
      // TODO Auto-generated method stub
      this._subject=string;
  }  

  // more of the getters and setters ….. 
}

এবং এটিকে একটি ক্রিয়াকলাপে কল করতে ...

@Override 
public void onCreate(Bundle icicle) { 
  super.onCreate(icicle); 
  setContentView(R.layout.main); 

  Button addImage = (Button) findViewById(R.id.send_email); 
  addImage.setOnClickListener(new View.OnClickListener() { 
    public void onClick(View view) { 
      Mail m = new Mail("gmailusername@gmail.com", "password"); 

      String[] toArr = {"bla@bla.com", "lala@lala.com"}; 
      m.setTo(toArr); 
      m.setFrom("wooo@wooo.com"); 
      m.setSubject("This is an email sent using my Mail JavaMail wrapper from an Android device."); 
      m.setBody("Email body."); 

      try { 
        m.addAttachment("/sdcard/filelocation"); 

        if(m.send()) { 
          Toast.makeText(MailApp.this, "Email was sent successfully.", Toast.LENGTH_LONG).show(); 
        } else { 
          Toast.makeText(MailApp.this, "Email was not sent.", Toast.LENGTH_LONG).show(); 
        } 
      } catch(Exception e) { 
        //Toast.makeText(MailApp.this, "There was a problem sending the email.", Toast.LENGTH_LONG).show(); 
        Log.e("MailApp", "Could not send email", e); 
      } 
    } 
  }); 
} 

@ কেএলাইমপীফোনঅ্যান্ড্রয়েড আপনার ম্যানিফেস্টে ইন্টারনেট অনুমতি যুক্ত করুন
noob

আমি যদি আমার org এর মতো অন্য কোনও ইমেল ক্লায়েন্ট ব্যবহার করতে চাই তবে এই কোডটি কীভাবে ব্যবহার করব? শুধু হোস্টের নাম এবং পোর্ট পরিবর্তন করা কি যথেষ্ট হবে?
রজার_টি

javax.mail.AuthenticationFiledEx Android 4.4.4 এর কোনও সমাধান?
টিডি এনগুইন

2
javax.mail.AuthenticationFiledException এর জন্য আপনাকে এই সেটিংটি চালু করতে হবে google.com/settings/security/lesssecureapps
রাজেল সোসো

1
সমাধানের জন্য Could not send email android.os.NetworkOnMainThreadException at android.os.StrictMode$AndroidBlockGuardPolicy.onNetworkএটা এই সমাধান দেখতে প্রয়োজনীয় stackoverflow.com/questions/25093546/...
jgrocha

14

জিমেইলব্যাকগ্রাউন্ডটি ব্যবহারকারীর মিথস্ক্রিয়া ছাড়াই পটভূমিতে একটি ইমেল প্রেরণের জন্য একটি ছোট লাইব্রেরি:

ব্যবহার:

    BackgroundMail.newBuilder(this)
            .withUsername("username@gmail.com")
            .withPassword("password12345")
            .withMailto("toemail@gmail.com")
            .withType(BackgroundMail.TYPE_PLAIN)
            .withSubject("this is the subject")
            .withBody("this is the body")
            .withOnSuccessCallback(new BackgroundMail.OnSuccessCallback() {
                @Override
                public void onSuccess() {
                    //do some magic
                }
            })
            .withOnFailCallback(new BackgroundMail.OnFailCallback() {
                @Override
                public void onFail() {
                    //do some magic
                }
            })
            .send();

কনফিগারেশন:

repositories {
    // ...
    maven { url "https://jitpack.io" }
 }
 dependencies {
            compile 'com.github.yesidlazaro:GmailBackground:1.2.0'
    }

অনুমতিসমূহ:

<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.INTERNET"/>

সংযুক্তিগুলির জন্যও, আপনাকে READ_EXTERNAL_STORAGE অনুমতি সেট করতে হবে:

<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>

সূত্র

(আমি নিজে এটি পরীক্ষা করেছি)


আমি এটি ব্যবহার করে নিখুঁত কাজ করি। তবে আমি এটির জন্য বিভিন্ন ইমেল সরবরাহকারীর সাথে ব্যবহারের জন্য কিছু পরিবর্তন করেছি এবং Gmail এ ইমেল প্রেরণে এটি আমাকে "ফর্ম" শিরোনামটি অনুপস্থিত ... এটি কীভাবে সমাধান করবেন?
এরিক গার্সিয়া

হ্যালো, আমি এই অ্যাপিকে আমার অ্যাপ্লিকেশনটিতে ব্যবহার করছি তবে এটি কাজ করছে না এবং সর্বদা অনফেলক্যালব্যাক কল করে
জাওয়াদ মালিক

13

"Smtp.gmail.com" কে ডিফল্ট এসএমটিপি সার্ভার হিসাবে ব্যবহার করে সতর্কতার শব্দ।

Google তাদের উত্সাহযুক্ত "সন্দেহজনক কার্যকলাপ" নীতিগুলির কারণে আপনাকে বারবার আপনার লিঙ্কযুক্ত ইমেল অ্যাকাউন্টের পাসওয়ার্ড পরিবর্তন করতে বাধ্য করবে। সংক্ষেপে এটি স্বল্প সময়ের মধ্যে বিভিন্ন দেশ থেকে বারবার এসএমটিপি অনুরোধগুলিকে "সন্দেহজনক কার্যকলাপ" হিসাবে বিবেচনা করে। তারা আপনাকে ধরে নিলে (ইমেল অ্যাকাউন্টধারক) কেবল একবারে এক দেশে থাকতে পারে।

যখন গুগল সিস্টেমগুলি "সন্দেহজনক ক্রিয়াকলাপ" শনাক্ত করে আপনি পাসওয়ার্ড পরিবর্তন না করা এটি পরবর্তী ইমেলগুলি প্রতিরোধ করবে। যেহেতু আপনি অ্যাপ্লিকেশনটিতে পাসওয়ার্ডটি কঠোরভাবে কোড করেছেন, প্রতিবার এটি ঘটলে অ্যাপটি পুনরায় প্রকাশ করতে হবে, আদর্শ নয়। এটি আমার কাছে সপ্তাহে 3 বার ঘটেছিল, আমি এমনকি অন্য সার্ভারে পাসওয়ার্ডটি সংরক্ষণ করেছিলাম এবং প্রতিটি সময় গুগল আমাকে এটি পরিবর্তন করতে বাধ্য করে পাসওয়ার্ডটি গতিশীলভাবে এনেছিল।

সুতরাং আমি এই সুরক্ষা সমস্যাটি এড়াতে "smtp.gmail.com" এর পরিবর্তে অনেকগুলি বিনামূল্যে SMTP সরবরাহকারীর মধ্যে একটি ব্যবহার করার পরামর্শ দিচ্ছি। একই কোড ব্যবহার করুন তবে আপনার নতুন smtp ফরোয়ার্ডিং হোস্টে "smtp.gmail.com" পরিবর্তন করুন।


2
এটি একটি ভাল পয়েন্ট। তবে আপনি দয়া করে বিকল্প ইমেল সরবরাহকারীর একটি উদাহরণ দিতে পারেন যা কোড সহ কাজ করেছে (কেবলমাত্র এসএমটিপি এবং লগইন বিশদ প্রতিস্থাপন করে)। আমি এটি চেষ্টা করেছি হুশমেল এবং ইমেল ডটকম দিয়ে কিন্তু সফলতা ছাড়াই। অন্যের সাথে চেষ্টা চালিয়ে যাবে।
পাওলো মাতুকি

@ পাওলোমাতুকি, @ মার্ক, হাই, আপনারা কি লোকেরা suspicioud activityসমস্যার সমাধান করেছেন ?
ওয়েসলি

7

সম্পাদনা করুন: জাভামেল ০.৫.৫ অ্যান্ড্রয়েড সমর্থন করার দাবি করে , সুতরাং আপনার আর কোনও প্রয়োজন হবে না should

আমি অ্যান্ড্রয়েডে সর্বশেষতম জাভামেলটি (1.5.4) পোর্ট করেছি। এটি মাভেন সেন্ট্রালে উপলব্ধ, কেবল নিম্নলিখিতটি following এ যুক্ত করুন build.gradle~~

compile 'eu.ocathain.com.sun.mail:javax.mail:1.5.4'

তারপরে আপনি অফিশিয়াল টিউটোরিয়ালটি অনুসরণ করতে পারেন ।

উত্স কোডটি এখানে উপলভ্য: https://bitbucket.org/artbristol/javamail-forked-android


সেই ম্যাভেন / গ্রেডলাইন আমার পক্ষে কাজ করে না। আপনার বিটবাকেট থেকে 1.5.4 ডাউনলোড করাও আমার পক্ষে কার্যকর হয়নি। এটি নিয়মিত অ-অ্যান্ড্রয়েড জাভামাইলের মতো একই লাইনে ব্যর্থ হয়েছিল, যা মাইমেসেজ.সেটটেক্সট (পাঠ্য)।
র্যাপ্পেরাপ্পস

@ ব্র্যাপেরপ্পস এটি শুনে দুঃখিত। "এটা আমার জন্য কাজ করে!".
বিটবাকেট রেপোতে

7

যাদের সাহায্যের প্রয়োজন তাদের জন্য আমি একটি সংক্ষিপ্ত বিকল্প পেয়েছি। কোডটি হ'ল:

package com.example.mail;

import java.util.Properties;

import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.PasswordAuthentication;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;

public class SendMailTLS {

    public static void main(String[] args) {

        final String username = "username@gmail.com";
        final String password = "password";

        Properties props = new Properties();
        props.put("mail.smtp.auth", "true");
        props.put("mail.smtp.starttls.enable", "true");
        props.put("mail.smtp.host", "smtp.gmail.com");
        props.put("mail.smtp.port", "587");

        Session session = Session.getInstance(props,
          new javax.mail.Authenticator() {
            protected PasswordAuthentication getPasswordAuthentication() {
                return new PasswordAuthentication("username", "password");
            }
          });

        try {

            Message message = new MimeMessage(session);
            message.setFrom(new InternetAddress("from-email@gmail.com"));
            message.setRecipients(Message.RecipientType.TO,
                InternetAddress.parse("to-email@gmail.com"));
            message.setSubject("Testing Subject");
            message.setText("Dear Mail Crawler,"
                + "\n\n No spam to my email, please!");

            Transport.send(message);

            System.out.println("Done");

        } catch (MessagingException e) {
            throw new RuntimeException(e);
        }
    }
}

উত্স: জাভামেল এপিআই এর মাধ্যমে ইমেল প্রেরণ

আশাকরি এটা সাহায্য করবে! শুভকামনা!


5

যারা ClassDefNotFoundErrorআপনার প্রকল্পের ফোল্ডারটি লিব করার জন্য এই তিনটি জার ফাইল সরানোর চেষ্টা করছেন, এটি আমার পক্ষে কাজ করেছিল !!


4

সংযুক্তি সহ একটি মেল প্রেরণের জন্য ..

public class SendAttachment{
                    public static void main(String [] args){ 
             //to address
                    String to="abc@abc.com";//change accordingly
                    //from address
                    final String user="efg@efg.com";//change accordingly
                    final String password="password";//change accordingly 
                     MailcapCommandMap mc = (MailcapCommandMap) CommandMap.getDefaultCommandMap();
                   mc.addMailcap("text/html;; x-java-content-handler=com.sun.mail.handlers.text_html");
                  mc.addMailcap("text/xml;; x-java-content-handler=com.sun.mail.handlers.text_xml");
                  mc.addMailcap("text/plain;; x-java-content-handler=com.sun.mail.handlers.text_plain");
                  mc.addMailcap("multipart/*;; x-java-content-handler=com.sun.mail.handlers.multipart_mixed");
                  mc.addMailcap("message/rfc822;; x-java-content-handler=com.sun.mail.handlers.message_rfc822");
                  CommandMap.setDefaultCommandMap(mc); 
                  //1) get the session object   
                  Properties properties = System.getProperties();
                  properties.put("mail.smtp.port", "465"); 
                  properties.put("mail.smtp.host", "smtp.gmail.com");
                    properties.put("mail.smtp.socketFactory.port", "465");
                    properties.put("mail.smtp.socketFactory.class",
                            "javax.net.ssl.SSLSocketFactory");
                    properties.put("mail.smtp.auth", "true");
                    properties.put("mail.smtp.port", "465");

                  Session session = Session.getDefaultInstance(properties,
                   new javax.mail.Authenticator() {
                   protected PasswordAuthentication getPasswordAuthentication() {
                   return new PasswordAuthentication(user,password);
                   }
                  });

                  //2) compose message   
                  try{ 
                    MimeMessage message = new MimeMessage(session);
                    message.setFrom(new InternetAddress(user));
                    message.addRecipient(Message.RecipientType.TO,new InternetAddress(to));
                    message.setSubject("Hii"); 
                    //3) create MimeBodyPart object and set your message content    
                    BodyPart messageBodyPart1 = new MimeBodyPart();
                    messageBodyPart1.setText("How is This"); 
                    //4) create new MimeBodyPart object and set DataHandler object to this object    
                    MimeBodyPart messageBodyPart2 = new MimeBodyPart();
                //Location of file to be attached
                    String filename = Environment.getExternalStorageDirectory().getPath()+"/R2832.zip";//change accordingly
                    DataSource source = new FileDataSource(filename);
                    messageBodyPart2.setDataHandler(new DataHandler(source));
                    messageBodyPart2.setFileName("Hello"); 
                    //5) create Multipart object and add MimeBodyPart objects to this object    
                    Multipart multipart = new MimeMultipart();
                    multipart.addBodyPart(messageBodyPart1);
                    multipart.addBodyPart(messageBodyPart2); 
                    //6) set the multiplart object to the message object
                    message.setContent(multipart ); 
                    //7) send message 
                    Transport.send(message); 
                   System.out.println("MESSAGE SENT....");
                   }catch (MessagingException ex) {ex.printStackTrace();}
                  }
                }

জারের ফাইলগুলি অ্যাক্টিভেশন.জার, সংযোজন.জার, জাভ্যাক্স.মেল.জার
রশিদ

1
আপনার পদ্ধতির চেষ্টা করার সময় আমি নিম্নলিখিত ত্রুটিটি পেয়েছি: 05-13 11: 51: 50.454: ই / অ্যান্ড্রয়েডআরটাইম (4273): android.os.NetworkOnMainThreadException 05-13 11: 51: 50.454: ই / অ্যান্ড্রয়েডআরটাইম (4273): অ্যান্ড্রয়েড এ। os.StrictMode $ AndroidBlockGuardPolicy.onNetwork (StrictMode.java:1156)। আমার কাছে ইন্টারনেট অনুমতি রয়েছে। কোন পরামর্শ?
কোডার্টা

1
কোনও থ্রেডের ভিতরে পদ্ধতিটি কল করার চেষ্টা করুন ... এটি একটি সময়সাপেক্ষ প্রক্রিয়া ... এটি মূল থ্রেডে চলতে পারে না ...
রশিদ

আমার অ্যান্ড্রয়েড প্রজেক্টে ঠিক এই কোডটি ব্যবহার করছি mail মেলটি আমার জন্য ভাল কাজ করছে। তবে সংযুক্তি অংশটি কাজ করছে না। আমি একটি টেক্সট ফাইল সংযুক্ত করার চেষ্টা করছি B তবে যে মেইলটি পেয়ে যাচ্ছে তাতে একটি অজানা ধরণের ফাইল রয়েছে যা খুলতে অক্ষম। সাহায্য করুন.
সায়ন্তক বসু

@ রাশিদ অবশ্যই আমি তা করেছি। আমি যখন ইন্টেন্ট আগে ব্যবহার করছিলাম তখন আমার সংযুক্ত ফাইলটি ঠিক আসছিল।
সায়ন্তক বসু

4

আমি বিনায়ক বি এর কোড চালাতে অক্ষম। অবশেষে আমি নিম্নলিখিতটির দ্বারা এই সমস্যাটি সমাধান করেছি:

এই ব্যবহার

2. AsyncTask প্রয়োগ করা হচ্ছে।

প্রেরক জিমেইল অ্যাকাউন্টের নিরাপত্তা ইস্যু 3.Changing। মধ্যে ( "চালু করুন" এ পরিবর্তন) এই


3

আপনি অ্যাপাচি কমন্স নেট ব্যবহার বিবেচনা করেছেন? ৩.৩ থেকে, কেবলমাত্র একটি জার (এবং আপনি গ্রেডেল বা ম্যাভেন ব্যবহার করে এটির উপর নির্ভর করতে পারেন) এবং আপনি সম্পন্ন করেছেন: http://blog.dahanne.net/2013/06/17/sending-a-mail-in-java- এবং-অ্যান্ড্রয়েড-সঙ্গে-Apache-Commons-নেট /


3

ব্যবহারকারীর হস্তক্ষেপ ব্যতীত, আপনি নিম্নলিখিত হিসাবে প্রেরণ করতে পারেন:

  1. ক্লায়েন্ট apk থেকে ইমেল প্রেরণ করুন। এখানে মেইল.জার, অ্যাক্টিভেশন.জারের জাভা ইমেল প্রেরণের প্রয়োজন। যদি এই জারগুলি যুক্ত করা হয় তবে এটি APK আকার বাড়িয়ে তুলতে পারে।

  2. বিকল্পভাবে, আপনি সার্ভার সাইড কোডে একটি ওয়েব-পরিষেবা ব্যবহার করতে পারেন, যা ইমেল প্রেরণের জন্য একই মেইল.জার এবং অ্যাক্টিভেশন.জার ব্যবহার করবে। আপনি অ্যাসিঙ্কটাস্কের মাধ্যমে ওয়েব-পরিষেবাটিতে কল করতে এবং ইমেল প্রেরণ করতে পারেন। একই লিঙ্কটি উল্লেখ করুন।

(তবে, আপনাকে মেল অ্যাকাউন্টের শংসাপত্রগুলি জানতে হবে)


2

আপনার কাছে জারের লাইব্রেরিটি যতটা সম্ভব ছোট রাখার জন্য দাবি করা হয়েছে সেই ক্ষেত্রে, "ডেক্সে অনেকগুলি পদ্ধতি" সমস্যা এড়াতে আপনি আলাদাভাবে এসএমটিপি / পিওপি 3 / আইএমএপি ফাংশন অন্তর্ভুক্ত করতে পারেন।

আপনি জাভানেট ওয়েব পৃষ্ঠা থেকে ওয়ান্ড জার লাইব্রেরিগুলি চয়ন করতে পারেন , উদাহরণস্বরূপ, মাইলাপি.জার + ইমাম.পাজার আপনাকে আইএমএপি প্রোটোকলে আইক্লাউড, হটমেইল মেল সার্ভার অ্যাক্সেস করতে সক্ষম করতে পারে। (অতিরিক্ত.জার এবং অ্যাক্টিভেশন.জারের সহায়তায়)


2

@ বিনায়াক বি জমা দেওয়া কোডটি ব্যবহার করার চেষ্টা করেছি। তবে আমি এই বলে ত্রুটি পাচ্ছি: এসএমটিপি-র জন্য কোনও সরবরাহকারী নেই

আমার আরও তথ্যের সঙ্গে এই জন্য একটি নতুন প্রশ্ন সৃষ্টি এখানে

আমি নিজেকে সর্বোপরি এটি ঠিক করতে সক্ষম হয়েছি। আমাকে অন্য একটি মেইল.জার ব্যবহার করতে হয়েছিল এবং আমার " কম সুরক্ষিত অ্যাপ্লিকেশনগুলির জন্য অ্যাক্সেস " চালু আছে কিনা তা নিশ্চিত করতে হয়েছিল।

আমি আশা করি যে একই সমস্যা আছে এমন কাউকে এটি সহায়তা করে। এটি হয়ে গেলে, এই টুকরো কোডটি গুগল গ্লাসেও কাজ করে।


2

অন্যান্য উত্তরের প্রদত্ত সমস্ত কোড সঠিক এবং এটি দুর্দান্ত কাজ করছে, তবে কিছুটা অগোছালো, তাই আমি এটি একটি সহজ উপায়ে ব্যবহার করার জন্য একটি লাইব্রেরি (যদিও এখনও বিকাশে রয়েছে) প্রকাশ করার সিদ্ধান্ত নিয়েছি: অ্যান্ড্রয়েডমাইল

আপনার কেবল একটি মেলসেন্ডার তৈরি করতে হবে, একটি মেল তৈরি করতে হবে এবং এটি প্রেরণ করতে হবে (ইতিমধ্যে একটি অ্যাসিঙ্কটাস্কের সাথে পটভূমিতে পরিচালনা করা হয়েছে)।

MailSender mailSender = new MailSender(email, password);

Mail.MailBuilder builder = new Mail.MailBuilder();
Mail mail = builder
    .setSender(senderMail)
    .addRecipient(new Recipient(recipient))
    .setText("Hello")
    .build();

mailSender.sendMail(mail);

আপনি প্রেরিত ইমেলের জন্য একটি বিজ্ঞপ্তি পেতে পারেন এবং এতে বিভিন্ন প্রাপক প্রকারের (টিও, সিসি এবং বিসিসি), সংযুক্তি এবং এইচটিএমএল সমর্থনও রয়েছে:

MailSender mailSender = new MailSender(email, password);

Mail.MailBuilder builder = new Mail.MailBuilder();
Mail mail = builder
    .setSender(senderMail)
    .addRecipient(new Recipient(recipient))
    .addRecipient(new Recipient(Recipient.TYPE.CC, recipientCC))
    .setText("Hello")
    .setHtml("<h1 style=\"color:red;\">Hello</h1>")
    .addAttachment(new Attachment(filePath, fileName))
    .build();

mailSender.sendMail(mail, new MailSender.OnMailSentListener() {

    @Override
    public void onSuccess() {
        // mail sent!
    }

    @Override
    public void onError(Exception error) {
        // something bad happened :(
    }
});

আপনি এটি গ্রেডেল বা মাভেনের মাধ্যমে পেতে পারেন:

compile 'it.enricocandino:androidmail:1.0.0-SNAPSHOT'

আপনার যদি এটি নিয়ে কোনও সমস্যা থাকে তবে দয়া করে আমাকে জানান! :)


1

এখানে অনেকগুলি সমাধান রয়েছে। তবে আমি মনে করি কম সুরক্ষিত ডিভাইস থেকে অ্যাক্সেস করার জন্য আমাদের অবশ্যই GMail এর কনফিগারেশনটি পরিবর্তন করতে হবে। নীচের লিঙ্কে যান এবং এটি সক্ষম করুন। এটা আমার জন্য কাজ করে

https://myaccount.google.com/lesssecureapps?pli=1


0
 Add jar files mail.jar,activation.jar,additionnal.jar

 String sub="Thank you for your online registration" ; 
 Mail m = new Mail("emailid", "password"); 

 String[] toArr = {"ekkatrainfo@gmail.com",sEmailId};
 m.setFrom("ekkatrainfo@gmail.com"); 

     m.setTo(toArr);
     m.setSubject(sub);
    m.setBody(msg);



                     try{


                            if(m.send()) { 

                            } else { 

                            } 
                          } catch(Exception e) { 

                            Log.e("MailApp", "Could not send email", e); 
                          } 

  package com.example.ekktra;

   import java.util.Date;
   import java.util.Properties;

   import javax.activation.CommandMap;
   import javax.activation.DataHandler;
   import javax.activation.DataSource;
   import javax.activation.FileDataSource;
   import javax.activation.MailcapCommandMap;
   import javax.mail.BodyPart;
   import javax.mail.Multipart;
   import javax.mail.PasswordAuthentication;
   import javax.mail.Session;
   import javax.mail.Transport;
   import javax.mail.internet.InternetAddress;
   import javax.mail.internet.MimeBodyPart;
   import javax.mail.internet.MimeMessage;
   import javax.mail.internet.MimeMultipart;

   public class Mail extends javax.mail.Authenticator { 
     private String _user; 
     private String _pass; 

     private String[] _to; 

     private String _from; 

     private String _port; 
     private String _sport; 

     private String _host; 

     private String _subject; 
     private String _body; 

     private boolean _auth; 

     private boolean _debuggable; 

     private Multipart _multipart; 


   public Mail() { 
      _host = "smtp.gmail.com"; // default smtp server 
      _port = "465"; // default smtp port 
      _sport = "465"; // default socketfactory port 

      _user = ""; // username 
      _pass = ""; // password 
      _from = ""; // email sent from 
      _subject = ""; // email subject 
      _body = ""; // email body 

      _debuggable = false; // debug mode on or off - default off 
      _auth = true; // smtp authentication - default on 

      _multipart = new MimeMultipart(); 

      // There is something wrong with MailCap, javamail can not find a handler for the        multipart/mixed part, so this bit needs to be added. 
      MailcapCommandMap mc = (MailcapCommandMap) CommandMap.getDefaultCommandMap(); 
   mc.addMailcap("text/html;; x-java-content-handler=com.sun.mail.handlers.text_html"); 
   mc.addMailcap("text/xml;; x-java-content-handler=com.sun.mail.handlers.text_xml"); 
   mc.addMailcap("text/plain;; x-java-content-  handler=com.sun.mail.handlers.text_plain"); 
   mc.addMailcap("multipart/*;; x-java-content-handler=com.sun.mail.handlers.multipart_mixed"); 
   mc.addMailcap("message/rfc822;; x-java-content- handler=com.sun.mail.handlers.message_rfc822"); 
    CommandMap.setDefaultCommandMap(mc); 
   } 

 public Mail(String user, String pass) { 
  this(); 

  _user = user; 
   _pass = pass; 
 } 

public boolean send() throws Exception { 
   Properties props = _setProperties(); 

  if(!_user.equals("") && !_pass.equals("") && _to.length > 0 && !_from.equals("") &&   !_subject.equals("") /*&& !_body.equals("")*/) { 
    Session session = Session.getInstance(props, this); 

    MimeMessage msg = new MimeMessage(session); 

     msg.setFrom(new InternetAddress(_from)); 

    InternetAddress[] addressTo = new InternetAddress[_to.length]; 
     for (int i = 0; i < _to.length; i++) { 
      addressTo[i] = new InternetAddress(_to[i]); 
    } 
      msg.setRecipients(MimeMessage.RecipientType.TO, addressTo); 

    msg.setSubject(_subject); 
    msg.setSentDate(new Date()); 

  // setup message body 
  BodyPart messageBodyPart = new MimeBodyPart(); 
    messageBodyPart.setText(_body); 
    _multipart.addBodyPart(messageBodyPart); 

     // Put parts in message 
    msg.setContent(_multipart); 

    // send email 
    Transport.send(msg); 

    return true; 
   } else { 
     return false; 
   } 
  } 

   public void addAttachment(String filename) throws Exception { 
    BodyPart messageBodyPart = new MimeBodyPart(); 
    DataSource source = new FileDataSource(filename); 
      messageBodyPart.setDataHandler(new DataHandler(source)); 
    messageBodyPart.setFileName(filename); 

   _multipart.addBodyPart(messageBodyPart); 
 } 

  @Override 
  public PasswordAuthentication getPasswordAuthentication() { 
     return new PasswordAuthentication(_user, _pass); 
  } 

   private Properties _setProperties() { 
   Properties props = new Properties(); 

    props.put("mail.smtp.host", _host); 

  if(_debuggable) { 
    props.put("mail.debug", "true"); 
  } 

  if(_auth) { 
    props.put("mail.smtp.auth", "true"); 
   } 

    props.put("mail.smtp.port", _port); 
    props.put("mail.smtp.socketFactory.port", _sport); 
    props.put("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory"); 
    props.put("mail.smtp.socketFactory.fallback", "false"); 

    return props; 
   } 

   // the getters and setters 
  public String getBody() { 
   return _body; 
 } 

 public void setBody(String _body) { 
  this._body = _body; 
 }

  public void setTo(String[] toArr) {
     // TODO Auto-generated method stub
    this._to=toArr;
 }

public void setFrom(String string) {
    // TODO Auto-generated method stub
    this._from=string;
}

 public void setSubject(String string) {
    // TODO Auto-generated method stub
    this._subject=string;
  }  


   }

0

প্রোগ্রামিনালি কোটলিনের সাথে ইমেল প্রেরণ।

  • সাধারণ ইমেল প্রেরণ, অন্যান্য সমস্ত বৈশিষ্ট্য নয় (সংযুক্তিগুলির মতো)।
  • টিএলএস সর্বদা চালু থাকে
  • কেবলমাত্র 1 গ্রেড ইমেল নির্ভরতা প্রয়োজন।

আমি এই ইমেল পিওপি পরিষেবাগুলির এই তালিকাটি সত্যই সহায়ক বলে খুঁজে পেয়েছি:

https://support.office.com/en-gb/article/pop-and-imap-email-settings-for-outlook-8361e398-8af4-4e97-b147-6c6c4ac95353

ব্যবহারবিধি:

    val auth = EmailService.UserPassAuthenticator("you@gmail.com", "yourPassword")
    val to = listOf(InternetAddress("to@email.com"))
    val from = InternetAddress("you@gmail.com")
    val email = EmailService.Email(auth, to, from, "Test Subject", "Hello Body World")
    val emailService = EmailService("smtp.gmail.com", 465)

    GlobalScope.launch { // or however you do background threads
        emailService.send(email)
    }

কোড:

import java.util.*
import javax.mail.*
import javax.mail.internet.InternetAddress
import javax.mail.internet.MimeBodyPart
import javax.mail.internet.MimeMessage
import javax.mail.internet.MimeMultipart

class EmailService(private val server: String, private val port: Int) {

    data class Email(
        val auth: Authenticator,
        val toList: List<InternetAddress>,
        val from: Address,
        val subject: String,
        val body: String
    )

    class UserPassAuthenticator(private val username: String, private val password: String) : Authenticator() {
        override fun getPasswordAuthentication(): PasswordAuthentication {
            return PasswordAuthentication(username, password)
        }
    }

    fun send(email: Email) {
        val props = Properties()
        props["mail.smtp.auth"] = "true"
        props["mail.user"] = email.from
        props["mail.smtp.host"] = server
        props["mail.smtp.port"] = port
        props["mail.smtp.starttls.enable"] = "true"
        props["mail.smtp.ssl.trust"] = server
        props["mail.mime.charset"] = "UTF-8"
        val msg: Message = MimeMessage(Session.getDefaultInstance(props, email.auth))
        msg.setFrom(email.from)
        msg.sentDate = Calendar.getInstance().time
        msg.setRecipients(Message.RecipientType.TO, email.toList.toTypedArray())
//      msg.setRecipients(Message.RecipientType.CC, email.ccList.toTypedArray())
//      msg.setRecipients(Message.RecipientType.BCC, email.bccList.toTypedArray())
        msg.replyTo = arrayOf(email.from)

        msg.addHeader("X-Mailer", CLIENT_NAME)
        msg.addHeader("Precedence", "bulk")
        msg.subject = email.subject

        msg.setContent(MimeMultipart().apply {
            addBodyPart(MimeBodyPart().apply {
                setText(email.body, "iso-8859-1")
                //setContent(email.htmlBody, "text/html; charset=UTF-8")
            })
        })
        Transport.send(msg)
    }

    companion object {
        const val CLIENT_NAME = "Android StackOverflow programmatic email"
    }
}

Gradle:

dependencies {
    implementation 'com.sun.mail:android-mail:1.6.4'
    implementation "org.jetbrains.kotlinx:kotlinx-coroutines-core:1.3.3"
}

AndroidManifest:

<uses-permission name="android.permission.INTERNET" />

-3

সংযুক্তি যুক্ত করতে, যুক্ত করতে ভুলবেন না।

MailcapCommandMap mc = (MailcapCommandMap) CommandMap
            .getDefaultCommandMap();
    mc.addMailcap("text/html;; x-java-content-handler=com.sun.mail.handlers.text_html");
    mc.addMailcap("text/xml;; x-java-content-handler=com.sun.mail.handlers.text_xml");
    mc.addMailcap("text/plain;; x-java-content-handler=com.sun.mail.handlers.text_plain");
    mc.addMailcap("multipart/*;; x-java-content-handler=com.sun.mail.handlers.multipart_mixed");
    mc.addMailcap("message/rfc822;; x-java-content-handler=com.sun.mail.handlers.message_rfc822");
    CommandMap.setDefaultCommandMap(mc);
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.