点击按钮,然后在全自动机器人发送电子邮件 [英] click on button then automaticly send email in android
问题描述
我有哪个用户会输入电子邮件到它的XML文件,那么当点击提交按钮,我希望应用程序自动与特定内容的邮件发送邮件。
任何好的教程或例子我可以从???帮助
包com.example.emailtest;
进口android.os.Bundle;
进口android.app.Activity;
进口android.view.Menu;
进口android.view.View;
进口android.widget.Button;
公共类主要的扩展活动{
公众按钮BSEND;
公共邮件米;
@覆盖
保护无效的onCreate(包savedInstanceState){
super.onCreate(savedInstanceState);
的setContentView(R.layout.activity_main);
BSEND =(按钮)findViewById(R.id.button1);
bsend.setOnClickListener(新View.OnClickListener(){
@覆盖
公共无效的onClick(查看为arg0){
邮件邮件=新邮件();
尝试 {
mail.send();
}赶上(例外五){
e.printStackTrace();
}}
});
}
@覆盖
公共布尔onCreateOptionsMenu(功能菜单){
//充气菜单;这增加了项目操作栏,如果它是present。
。getMenuInflater()膨胀(R.menu.main,菜单);
返回true;
}
}
logcat的
二月12日至一十三号:22:51.831:W / dalvikvm(2588):无法解析LCOM /例子/ emailtest /邮件超; (820)
二月12日至十三号:22:51.831:W / dalvikvm(2588):Link类的LCOM /例子/ emailtest /邮件;失败
二月12日至十三号:22:51.831:E / dalvikvm(2588):找不到类的com.example.emailtest.Mail,从法com.example.emailtest.MainActivity $ 1.onClick引用
二月12日至十三号:22:51.831:W / dalvikvm(2588):VFY:无法解析新的实例711(LCOM /例子/ emailtest /邮件;)在LCOM /例子/ emailtest / MainActivity $ 1;
二月12日至十三号:22:51.841:D / dalvikvm(2588):VFY:更换运code输入0x22为0x0000
二月12日至十三号:22:51.841:W / dalvikvm(2588):无法解析LCOM /例子/ emailtest /邮件超; (820)
二月12日至十三号:22:51.841:W / dalvikvm(2588):Link类的LCOM /例子/ emailtest /邮件;失败
二月12日至十三号:22:51.841:D / dalvikvm(2588):DexOpt:无法选择直接调用0x13b3在LCOM 0X02 /例子/ emailtest / MainActivity $ 1; .onClick
二月12日至十三号:22:52.101:D / gralloc_goldfish(2588):没有GPU的仿真模拟器检测。
二月12日至十三号:22:54.681:D / AndroidRuntime(2588):关闭虚拟机
二月12日至十三号:22:54.681:W / dalvikvm(2588):主题ID = 1:螺纹退出与未捕获的异常(组= 0xb4acab90)
二月12日至十三号:22:54.701:E / AndroidRuntime(2588):致命异常:主要
二月12日至十三号:22:54.701:E / AndroidRuntime(2588):工艺:com.example.emailtest,PID:2588
二月12日至十三号:22:54.701:E / AndroidRuntime(2588):java.lang.NoClassDefFoundError的:com.example.emailtest.Mail
二月12日至十三号:22:54.701:E / AndroidRuntime(2588):在com.example.emailtest.MainActivity $ 1.onClick(MainActivity.java:22)
二月12日至十三号:22:54.701:E / AndroidRuntime(2588):在android.view.View.performClick(View.java:4424)
二月12日至十三号:22:54.701:E / AndroidRuntime(2588):在android.view.View $ PerformClick.run(View.java:18383)
二月12日至十三号:22:54.701:E / AndroidRuntime(2588):在android.os.Handler.handleCallback(Handler.java:733)
二月12日至十三号:22:54.701:E / AndroidRuntime(2588):在android.os.Handler.dispatchMessage(Handler.java:95)
二月12日至十三号:22:54.701:E / AndroidRuntime(2588):在android.os.Looper.loop(Looper.java:137)
二月12日至十三号:22:54.701:E / AndroidRuntime(2588):在android.app.ActivityThread.main(ActivityThread.java:4998)
二月12日至十三号:22:54.701:E / AndroidRuntime(2588):在java.lang.reflect.Method.invokeNative(本机方法)
二月12日至十三号:22:54.701:E / AndroidRuntime(2588):在java.lang.reflect.Method.invoke(Method.java:515)
二月12日至十三号:22:54.701:E / AndroidRuntime(2588):在com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:777)
二月12日至十三号:22:54.701:E / AndroidRuntime(2588):在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:593)
二月12日至十三号:22:54.701:E / AndroidRuntime(2588):在dalvik.system.NativeStart.main(本机方法)
二月12日至十三号:22:58.121:I /过程(2588):发送信号。 PID:2588 SIG:9
在我来说,我用Java邮件API和code以下可以使用。请添加必要的细节,如用户名,密码,电子邮件ID等使用本教程<一个href="http://www.jondev.net/articles/Sending_Emails_without_User_Intervention_%28no_Intents%29_in_Android" rel="nofollow">http://www.jondev.net/articles/Sending_Emails_without_User_Intervention_%28no_Intents%29_in_Android
公共类邮件扩展javax.mail.Authenticator {
私人字符串_user;
私人字符串_pass;
私有String [_to]
私人字符串_from;
私人字符串_port;
私人字符串_sport;
私人字符串_host;
私人字符串_subject;
私人字符串_body;
私人布尔_auth;
私人布尔_debuggable;
私人多部分_multipart;
公共邮件(){
_host =smtp.gmail.com; //默认SMTP服务器
_port =465; //默认的SMTP端口
_sport =465; //默认的SocketFactory端口
_user =用户名; //用户名
_pass =密码; // 密码
_from =emailsentfrom@gmail.com; //电子邮件,发送
_to =新的String [] {toemail@gmail.com};
_subject =主题; // 电子邮件主题
_body =测试; //邮件正文
_debuggable = FALSE;打开或关闭//调试模式 - 默认关闭
_auth = TRUE; // SMTP认证 - 拖欠
_multipart =新MimeMultipart的();
//也有一些是错误的MAILCAP,JavaMail的找不到的处理程序/混合组成部分,所以这一点需要添加。
支持MailcapCommandMap MC =(支持MailcapCommandMap)CommandMap.getDefaultCommandMap();
mc.addMailcap(text / html的;;的X Java的内容处理器= com.sun.mail.handlers.text_html);
mc.addMailcap(文/ XML ;;的X Java的内容处理器= com.sun.mail.handlers.text_xml);
mc.addMailcap(text / plain的;;的X Java的内容处理器= com.sun.mail.handlers.text_plain);
mc.addMailcap(多部分/ * ;;的X Java的内容处理器= com.sun.mail.handlers.multipart_mixed);
mc.addMailcap(信息/ RFC822 ;;的X Java的内容处理器= com.sun.mail.handlers.message_rfc822);
CommandMap.setDefaultCommandMap(MC);
}
公共邮箱(用户字符串,字符串通){
_user =用户;
_pass =通;
}
公共布尔的send()抛出异常{
属性道具= _setProperties();
!如果(_ user.equals()及&安培;!_pass.equals()及&安培; _to.length大于0&安培;&安培;!_from.equals()及&安培;!_subject .equals()及&安培;!_body.equals()){
会话会话= Session.getInstance(道具,这一点);
的MimeMessage味精=新的MimeMessage(会议);
msg.setFrom(新网际(_from));
网际[] addressTo =新的网际[_to.length]
的for(int i = 0; I&LT; _to.length;我++){
addressTo [我] =新的网际(_to [I]);
}
msg.setRecipients(MimeMessage.RecipientType.TO,addressTo);
msg.setSubject(_subject);
msg.setSentDate(新日期());
//设置邮件正文
BodyPart的messageBodyPart =新MimeBodyPart();
messageBodyPart.setText(_body);
_multipart.addBodyPart(messageBodyPart);
//添加附件
addAttachment(文件名); //替换u需要的文件名
在消息//将部分
msg.setContent(_multipart);
// 发电子邮件
交通运输= session.getTransport(SMTPS);
transport.connect(_host,465,_user,_pass);
Transport.send(MSG);
返回true;
} 其他 {
返回false;
}
}
公共无效addAttachment(字符串文件名)抛出异常{
BodyPart的messageBodyPart =新MimeBodyPart();
数据源源=新FileDataSource(文件名);
messageBodyPart.setDataHandler(新的DataHandler(源));
messageBodyPart.setFileName(文件名);
_multipart.addBodyPart(messageBodyPart);
}
@覆盖
公共Password验证的getPasswordAuthentication(){
返回新的PasswordAuthentication(_user,_pass);
}
私人性质_setProperties(){
属性道具=新特性();
props.put(mail.smtp.host,_host);
如果(_debuggable){
props.put(mail.debug,真);
}
如果(_auth){
props.put(mail.smtp.auth,真);
}
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,假);
props.put(mail.smtp.starttls.enable,真);
返回道具;
}
// getter和setter
公共字符串getBody(){
返回_body;
}
公共无效setBody(字符串_body){
this._body = _body;
}
//更多的getter和setter的E ..
}
和写一个异步任务发送邮件
公共类SendTask扩展的AsyncTask&LT;字符串,整数,整数GT; {
私人ProgressDialog对话框;
私人语境mContext;
公共SendTask(上下文mContext){
this.mContext = mContext;
}
在preExecute保护无效(){
this.dialog =新ProgressDialog(mContext);
this.dialog.setCancelable(假);
this.dialog.setMessage(发送);
this.dialog.show();
}
保护整数doInBackground(字符串... IDS){
邮件邮件=新邮件();
尝试 {
mail.send();
}赶上(例外五){
e.printStackTrace();
}
返回1;
}
}
I have an xml file which user will enter an email into it, then when click on the submit button, I want the application to automatically send an email with specific content to that email ..
any good tutorials or examples I can get help from ???
package com.example.emailtest;
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.widget.Button;
public class main extends Activity{
public Button bsend;
public Mail m;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
bsend=(Button) findViewById(R.id.button1);
bsend.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View arg0) {
Mail mail = new Mail();
try {
mail.send();
} catch (Exception e) {
e.printStackTrace();
}}
});
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
}
logcat
12-13 02:22:51.831: W/dalvikvm(2588): Unable to resolve superclass of Lcom/example/emailtest/Mail; (820)
12-13 02:22:51.831: W/dalvikvm(2588): Link of class 'Lcom/example/emailtest/Mail;' failed
12-13 02:22:51.831: E/dalvikvm(2588): Could not find class 'com.example.emailtest.Mail', referenced from method com.example.emailtest.MainActivity$1.onClick
12-13 02:22:51.831: W/dalvikvm(2588): VFY: unable to resolve new-instance 711 (Lcom/example/emailtest/Mail;) in Lcom/example/emailtest/MainActivity$1;
12-13 02:22:51.841: D/dalvikvm(2588): VFY: replacing opcode 0x22 at 0x0000
12-13 02:22:51.841: W/dalvikvm(2588): Unable to resolve superclass of Lcom/example/emailtest/Mail; (820)
12-13 02:22:51.841: W/dalvikvm(2588): Link of class 'Lcom/example/emailtest/Mail;' failed
12-13 02:22:51.841: D/dalvikvm(2588): DexOpt: unable to opt direct call 0x13b3 at 0x02 in Lcom/example/emailtest/MainActivity$1;.onClick
12-13 02:22:52.101: D/gralloc_goldfish(2588): Emulator without GPU emulation detected.
12-13 02:22:54.681: D/AndroidRuntime(2588): Shutting down VM
12-13 02:22:54.681: W/dalvikvm(2588): threadid=1: thread exiting with uncaught exception (group=0xb4acab90)
12-13 02:22:54.701: E/AndroidRuntime(2588): FATAL EXCEPTION: main
12-13 02:22:54.701: E/AndroidRuntime(2588): Process: com.example.emailtest, PID: 2588
12-13 02:22:54.701: E/AndroidRuntime(2588): java.lang.NoClassDefFoundError: com.example.emailtest.Mail
12-13 02:22:54.701: E/AndroidRuntime(2588): at com.example.emailtest.MainActivity$1.onClick(MainActivity.java:22)
12-13 02:22:54.701: E/AndroidRuntime(2588): at android.view.View.performClick(View.java:4424)
12-13 02:22:54.701: E/AndroidRuntime(2588): at android.view.View$PerformClick.run(View.java:18383)
12-13 02:22:54.701: E/AndroidRuntime(2588): at android.os.Handler.handleCallback(Handler.java:733)
12-13 02:22:54.701: E/AndroidRuntime(2588): at android.os.Handler.dispatchMessage(Handler.java:95)
12-13 02:22:54.701: E/AndroidRuntime(2588): at android.os.Looper.loop(Looper.java:137)
12-13 02:22:54.701: E/AndroidRuntime(2588): at android.app.ActivityThread.main(ActivityThread.java:4998)
12-13 02:22:54.701: E/AndroidRuntime(2588): at java.lang.reflect.Method.invokeNative(Native Method)
12-13 02:22:54.701: E/AndroidRuntime(2588): at java.lang.reflect.Method.invoke(Method.java:515)
12-13 02:22:54.701: E/AndroidRuntime(2588): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:777)
12-13 02:22:54.701: E/AndroidRuntime(2588): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:593)
12-13 02:22:54.701: E/AndroidRuntime(2588): at dalvik.system.NativeStart.main(Native Method)
12-13 02:22:58.121: I/Process(2588): Sending signal. PID: 2588 SIG: 9
In my case I used Java Mail API and the code below you can use. Please add the necessary details like user name,password, email ids etc Use this tutorial http://www.jondev.net/articles/Sending_Emails_without_User_Intervention_%28no_Intents%29_in_Android
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"; // username
_pass = "password"; // password
_from = "emailsentfrom@gmail.com"; // email sent from
_to = new String[] {"toemail@gmail.com"};
_subject = "subject"; // email subject
_body = "test"; // 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) {
_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);
// adding attachment
addAttachment("filename");//replace with file name u need
// Put parts in message
msg.setContent(_multipart);
// send email
Transport transport = session.getTransport("smtps");
transport.connect(_host, 465,_user, _pass);
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");
props.put("mail.smtp.starttls.enable", "true");
return props;
}
// the getters and setters
public String getBody() {
return _body;
}
public void setBody(String _body) {
this._body = _body;
}
// more of the getters and setters É..
}
and write an Async task to send mail
public class SendTask extends AsyncTask<String, Integer, Integer> {
private ProgressDialog dialog;
private Context mContext;
public SendTask(Context mContext){
this.mContext = mContext;
}
protected void onPreExecute() {
this.dialog = new ProgressDialog(mContext);
this.dialog.setCancelable(false);
this.dialog.setMessage("sending");
this.dialog.show();
}
protected Integer doInBackground(String... ids) {
Mail mail = new Mail();
try {
mail.send();
} catch (Exception e) {
e.printStackTrace();
}
return 1;
}
}
这篇关于点击按钮,然后在全自动机器人发送电子邮件的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!