Как отправлять почту программно в android с использованием маркера OAuth2.0

Я разрабатываю приложение, в котором я хочу отправлять почту программно с использованием учетных данных Gmail, я знаю, как получить доступ к идентификатору и токене почты устройства с помощью AccountManager . Пожалуйста, предложите мне отправить почту с использованием учетных данных с помощью какого-либо кода или учебника. Я новичок в Android. Пожалуйста, помогите мне заранее.

После очень тяжелой работы теперь я могу войти в Google, используя Oauth 2. Теперь я поделился здесь, потому что многие вопросы остались без ответа. Ниже приведены шаги для входа в Google.

1- Выберите учетную запись на своем устройстве, используя

 public static AccountManager accountManager; accountManager = AccountManager.get(this); Account[] accounts = accountManager.getAccountsByType("com.google"); 

2- Получить токен из выбранной учетной записи, используя

 private void onAccountSelected(final Account account) { accountManager.getAuthToken(account, AUTH_TOKEN_TYPE, null, this, new AccountManagerCallback<Bundle>() { public void run(AccountManagerFuture<Bundle> future) { try { String token = future.getResult().getString(AccountManager.KEY_AUTHTOKEN); useToken(account, token); } catch (OperationCanceledException e) { onAccessDenied(); } catch (Exception e) { handleException(e); } } }, null); 

}

3- теперь аутентифицируйте токен, используя учетную запись пользователя и токен. Вы сможете войти в Google.

Примечание. После некоторого токена вы получаете неавторизованный доступ к логину, поэтому вам необходимо аннулировать токен.

4- для повторного входа вы должны аннулировать токен, используя

 accountManager.invalidateAuthToken("com.google", token); 

5- после недействительности вы должны получить новый токен, используя

  String newToken = AccountManager.get(this).getAuthToken(new Account(account, "com.google"), AUTH_TOKEN_TYPE, true, null, null).getResult().getString(AccountManager.KEY_AUTHTOKEN); 

6- в вашем AndroidManifest.xml добавить ниже использует разрешения

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

Это все, что вам нужно, теперь наслаждайтесь

  fist you download activation.jar,mail.jar,additionnal.jar and add to built to your project And code r following ---------Create GMailSender.class import javax.activation.DataHandler; import javax.activation.DataSource; import javax.mail.Message; import javax.mail.PasswordAuthentication; import javax.mail.Session; import javax.mail.Transport; import javax.mail.internet.InternetAddress; import javax.mail.internet.MimeMessage; import java.io.ByteArrayInputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.security.Security; import java.util.Properties; 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 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){ e.printStackTrace(); } } 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"); } } } 2-Create JSSEProvider.class 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-use This code in to your Activity button click etc.. try { GMailSender sender = new GMailSender("sender gmail ID", "password"); sender.sendMail("This is Subject", "This is Body", "receiverID", "receiverID"); } catch (Exception e) { Log.e("SendMail", e.getMessage(), e); } 

Источник: https://stackoverflow.com/a/2033124/865900 (кредит, в котором должен быть предоставлен кредит)