在Android应用程序中,我可以监听GMAIL中发送的电子邮件吗?
我可以收听收到的短信,但在搜索之后,我找不到一种方法来收听GMAIL中收到的电子邮件。我将在任何级别的操作系统上采取任何可能的方式。谢谢。有关工作示例,请参阅的 复制/粘贴下面的源代码以供参考,以防URL不可用在Android应用程序中,我可以监听GMAIL中发送的电子邮件吗?,android,api,email,gmail,Android,Api,Email,Gmail,我可以收听收到的短信,但在搜索之后,我找不到一种方法来收听GMAIL中收到的电子邮件。我将在任何级别的操作系统上采取任何可能的方式。谢谢。有关工作示例,请参阅的 复制/粘贴下面的源代码以供参考,以防URL不可用 /* * Copyright 2012 Google Inc. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use t
/*
* Copyright 2012 Google Inc. All Rights Reserved.
*
* Licensed 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.
*/
package com.google.android.apps.dashclock.gmail;
import android.content.Context;
import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
import android.content.pm.PackageManager.NameNotFoundException;
import android.content.pm.PermissionInfo;
import android.content.pm.ProviderInfo;
import android.net.Uri;
import android.text.TextUtils;
/**
* <p>Contract for use with the Gmail content provider.</p>
*
* <p>Developers can use this content provider to display label information to the user.
* <br/>
* The label information includes:
* <ul>
* <li>Label name</li>
* <li>Total number of conversations</li>
* <li>Number of unread conversations</li>
* <li>Label text color</li>
* <li>Label background color</li>
* </ul></p>
*
* <p>This content provider is available in Gmail version 2.3.6 or newer for Froyo/Gingerbread
* and version 4.0.5 and newer for Honeycomb and Ice Cream Sandwich</p>
* <p>An application can query the
* <a href="http://developer.android.com/reference/android/content/ContentResolver.html">
* Content Resolver</a> directly
* (or use a <a href="http://developer.android.com/guide/topics/fundamentals/loaders.html"
* target="_blank">Loader</a>)
* to obtain a Cursor with information for all labels on an account</p>
* <code>Cursor labelsCursor = getContentResolver().query(GmailContract.Labels.getLabelsUri(
* selectedAccount), null, null, null, null);</code>
*/
public final class GmailContract {
private GmailContract() {}
/**
* Permission required to access this {@link android.content.ContentProvider}
*/
public static final String PERMISSION =
"com.google.android.gm.permission.READ_CONTENT_PROVIDER";
/**
* Authority for the Gmail content provider.
*/
public static final String AUTHORITY = "com.google.android.gm";
static final String LABELS_PARAM = "/labels";
static final String LABEL_PARAM = "/label/";
static final String BASE_URI_STRING = "content://" + AUTHORITY;
static final String PACKAGE = "com.google.android.gm";
/**
* Check if the installed Gmail app supports querying for label information.
*
* @param c an application Context
* @return true if it's safe to make label API queries
*/
public static boolean canReadLabels(Context c) {
boolean supported = false;
try {
final PackageInfo info = c.getPackageManager().getPackageInfo(PACKAGE,
PackageManager.GET_PROVIDERS | PackageManager.GET_PERMISSIONS);
boolean allowRead = false;
if (info.permissions != null) {
for (int i = 0, len = info.permissions.length; i < len; i++) {
final PermissionInfo perm = info.permissions[i];
if (PERMISSION.equals(perm.name)
&& perm.protectionLevel < PermissionInfo.PROTECTION_SIGNATURE) {
allowRead = true;
break;
}
}
}
if (allowRead && info.providers != null) {
for (int i = 0, len = info.providers.length; i < len; i++) {
final ProviderInfo provider = info.providers[i];
if (AUTHORITY.equals(provider.authority) &&
TextUtils.equals(PERMISSION, provider.readPermission)) {
supported = true;
}
}
}
} catch (NameNotFoundException e) {
// Gmail app not found
}
return supported;
}
/**
* Table containing label information.
*/
public static final class Labels {
/**
* Label canonical names for default Gmail system labels.
*/
public static final class LabelCanonicalNames {
/**
* Canonical name for the Inbox label
*/
public static final String CANONICAL_NAME_INBOX = "^i";
/**
* Canonical name for the Priority Inbox label
*/
public static final String CANONICAL_NAME_PRIORITY_INBOX = "^iim";
/**
* Canonical name for the Starred label
*/
public static final String CANONICAL_NAME_STARRED = "^t";
/**
* Canonical name for the Sent label
*/
public static final String CANONICAL_NAME_SENT = "^f";
/**
* Canonical name for the Drafts label
*/
public static final String CANONICAL_NAME_DRAFTS = "^r";
/**
* Canonical name for the All Mail label
*/
public static final String CANONICAL_NAME_ALL_MAIL = "^all";
/**
* Canonical name for the Spam label
*/
public static final String CANONICAL_NAME_SPAM = "^s";
/**
* Canonical name for the Trash label
*/
public static final String CANONICAL_NAME_TRASH = "^k";
private LabelCanonicalNames() {}
}
/**
* The MIME-type of uri providing a directory of
* label items.
*/
public static final String CONTENT_TYPE =
"vnd.android.cursor.dir/vnd.com.google.android.gm.label";
/**
* The MIME-type of a label item.
*/
public static final String CONTENT_ITEM_TYPE =
"vnd.android.cursor.item/vnd.com.google.android.gm.label";
/**
* This string value is the canonical name of a label. Canonical names are not localized and
* are not user-facing.
*
* <p>Type: TEXT</p>
*/
public static final String CANONICAL_NAME = "canonicalName";
/**
* This string value is the user-visible name of a label. Names of system labels
* (Inbox, Sent, Drafts...) are localized.
*
* <p>Type: TEXT</p>
*/
public static final String NAME = "name";
/**
* This integer value is the number of conversations in this label.
*
* <p>Type: INTEGER</p>
*/
public static final String NUM_CONVERSATIONS = "numConversations";
/**
* This integer value is the number of unread conversations in this label.
*
* <p>Type: INTEGER</p>
*/
public static final String NUM_UNREAD_CONVERSATIONS = "numUnreadConversations";
/**
* This integer value is the label's foreground text color in 32-bit 0xAARRGGBB format.
*
* <p>Type: INTEGER</p>
*/
public static final String TEXT_COLOR = "text_color";
/**
* This integer value is the label's background color in 32-bit 0xAARRGGBB format.
*
* <p>Type: INTEGER</p>
*/
public static final String BACKGROUND_COLOR = "background_color";
/**
* This string column value is the uri that can be used in subsequent calls to
* {@link android.content.ContentProvider#query()} to query for information on the single
* label represented by this row.
*
* <p>Type: TEXT</p>
*/
public static final String URI = "labelUri";
/**
* Returns a URI that, when queried, will return the list of labels for an
* account.
* <p>
* To use the Labels API, an app must first find the email address of a
* valid Gmail account to query for label information. The <a href=
* "http://developer.android.com/reference/android/accounts/AccountManager.html"
* target="_blank">AccountManager</a> can return this information (<a
* href="https://developers.google.com/gmail/android">example</a>).
* </p>
*
* @param account Name of a valid Google account.
* @return The URL that can be queried to retrieve the the label list.
*/
public static Uri getLabelsUri(String account) {
return Uri.parse(BASE_URI_STRING + "/" + account + LABELS_PARAM);
}
private Labels() {}
}
}
希望这有帮助。据我所知,直接访问实际信息是不可能的。我所知道的最好的方法是使用Java MAIL for Android库()并使用IMAP协议来获取您要查找的消息 但你真正的问题是从gmail获取事件。要获取它们,可以使用ContentObserver。首先,声明您自己的ContentObserver子类:
class GmailContentObserver extends ContentObserver {
public GmailContentObserver(Handler handler) {
super(handler);
}
@Override
public void onChange(boolean selfChange) {
onChange(selfChange, null);
}
@Override
public void onChange(boolean selfChange, Uri uri) {
// This is where you will get your change notifications
// for each received e-mails. This method will be called multiple times per
// received e-mail. At least 3, but it depends on the way you register
// your observer and on your gmail account set up (number of labels).
// You will also get calls for other events. Remember that this method is
// called for any change on the local gmail repository. Receiving an e-mail
// is only one of many actions that will change this repository.
Toast.makeText(MainActivity.this,"gmail event",Toast.LENGTH_LONG).show();
}
}
GmailContentObserver gco = new GmailContentObserver(new Handler());
ContentResolver cr = getContentResolver();
cr.registerContentObserver(Uri.parse("content://gmail-ls"),true,gco);
然后注册您的ContentObserver:
class GmailContentObserver extends ContentObserver {
public GmailContentObserver(Handler handler) {
super(handler);
}
@Override
public void onChange(boolean selfChange) {
onChange(selfChange, null);
}
@Override
public void onChange(boolean selfChange, Uri uri) {
// This is where you will get your change notifications
// for each received e-mails. This method will be called multiple times per
// received e-mail. At least 3, but it depends on the way you register
// your observer and on your gmail account set up (number of labels).
// You will also get calls for other events. Remember that this method is
// called for any change on the local gmail repository. Receiving an e-mail
// is only one of many actions that will change this repository.
Toast.makeText(MainActivity.this,"gmail event",Toast.LENGTH_LONG).show();
}
}
GmailContentObserver gco = new GmailContentObserver(new Handler());
ContentResolver cr = getContentResolver();
cr.registerContentObserver(Uri.parse("content://gmail-ls"),true,gco);
就这样
请注意,当您不再需要观察者或当您的应用程序/服务关闭时,您也应该注销它
在实例化观察者时,还要注意新的Hanlder()。这将确定将在哪个线程上调用onChange方法。创建处理程序对象的线程是调用onChange的线程(在我的示例中,您看不到这一点,但它是UI线程,在我的活动中调用onCreate的线程)
注册观察者时,有两个参数:要观察的URI和是否要观察后代。在上面的示例代码中,您将收到URI的通知content://gmail-ls
但也可用于content://gmail-ls/foo@gmail.com
,foo@gmail.com成为你的gmail帐号。还有更多的派生URI(特别是标签)。要获得较少的事件,您可以为content://gmail-ls/foo@gmail.com
并将第二个参数设置为false
考虑到这种机制,理论上如果你想观察给定gmail标签上的变化,你可以查询标签id(参见gmail api)并注册相应的URIcontent://gmail-ls/foo@gmail.com/label/80
,80是标签id。但由于某些原因,这不起作用
另外,检查已经提到的gmail api的代码,以确定安装的gmail应用程序是否有内容提供商(取决于gmail的版本)。如果您想获取电子邮件的内容,我建议使用gmail REST api非常好(但您需要在应用程序中获得用户授权)
我们已经在我们的应用程序(无耻插件)中使用了它,这是一个使用javascript和gmail API的cordova应用程序,对我们来说非常好 你可以听短信,因为它是安卓系统内置的api,gmail不是,也许gmail可能有某种api与他们的应用程序通信。然而,你最好的办法是连接到gmail邮件服务器本身,可能是通过SMTP连接,然后直接检查邮件。gmail api:我已经尝试过了,但它似乎无法访问实际邮件。。只是标签上的名字。如果该应用程序收到GMAIL发送的电子邮件通知,效果也会更好。我尝试在生成通知时连接到可访问性服务,但它们并不总是显示发件人的电子邮件。这意味着您没有投入足够的精力:)DashClock小部件工作得非常好,就像您描述目标的方式一样。让我加倍努力,再试一次,看看我错过了什么。谢谢。在你的问题中,你说“在任何级别的操作系统上”。如果你的设备是根设备,你应该能够直接访问gmail的数据存储(可能是一个SQLite数据库),如果这也是你想要的,你应该能够获取消息内容。