本篇介紹在springboot中配置email服務的具體步驟,以及常見的異常分析。
具體案例以qq郵箱以及qq企業郵箱為例。
- qq郵箱發送方式
- qq企業郵箱發送方式
- 總結
tips:
下面提到的hashindex指的是一個元素put到hashmap中時,要根據其key.hashcode & (table.size()-1)來決定其在table中的位置。
table是一個數組,類型為node。node是hashmap的一個內部類,用來描述hashmap的元素的一些屬性。
1.相關依賴包
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
<parent> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-parent</artifactid> <version> 1.3 . 0 .release</version> </parent> <dependencies> <!-- springboot--> <dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-web</artifactid> <version> 1.3 . 0 .release</version> </dependency> <!-- email --> <dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-mail</artifactid> </dependency> <!-- html模板 --> <dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-velocity</artifactid> </dependency> </dependencies> |
springboot以及mail的依賴包就不做解釋了。
這里簡單介紹下velocity的作用:
velocity 是一個基于 java 的模板引擎框架,提供的模板語言可以使用在 java 中定義的對象和變量上。
作為郵件模板也是它的一個主要應用場景。
具體用法在下面會進行說明。
2.具體案例
1.使用qq郵箱進行發送
application.properties
1
2
3
4
5
6
7
8
|
#發送郵箱(可以填你自己的郵箱) email.from = xxxxxxx @qq .com #目標郵箱 email.to = #郵箱服務器 email.host = smtp.qq.com #授權碼,在qq郵箱客戶端生成 email.auth = kpzmxhrkqklwbbbd |
大家可能不理解auth授權碼是干什么用的。
這相當于是當以第三方形式登錄時用非密碼驗證的一種手段。
在qq郵箱->設置->賬戶 往下拉可以找到。
同時需要把pop3/smtp服務開啟。
javamailsender
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
import org.springframework.beans.factory.annotation.autowired; import org.springframework.context.annotation.bean; import org.springframework.context.annotation.configuration; import org.springframework.core.env.environment; import org.springframework.mail.javamail.javamailsender; import org.springframework.mail.javamail.javamailsenderimpl; import javax.mail.authenticator; import javax.mail.passwordauthentication; import java.util.properties; /** * author : qianweifeng * date : 16/4/9. * describe : */ @configuration public class mailconfig { @autowired private environment env; @bean (name = "javamailsender" ) public javamailsender getsender(){ javamailsenderimpl javamailsender = new javamailsenderimpl(); javamailsender.setusername(env.getproperty(configconstant.email_from)); javamailsender.sethost(env.getproperty(configconstant.email_host)); javamailsender.setport( 587 ); //① javamailsender.setdefaultencoding( "utf-8" ); properties props = new properties(); //② props.setproperty( "mail.smtp.host" , env.getproperty(configconstant.email_host)); props.setproperty( "mail.smtp.auth" , "true" ); javax.mail.session session = javax.mail.session.getdefaultinstance(props, new authenticator(){ @override protected passwordauthentication getpasswordauthentication(){ } }); javamailsender.setsession(session); //③ return javamailsender; } } |
這是java郵件發送的一個具體實現bean。
關于javamailsender的內容大家自行看源碼或者度娘。
這里說明3個方面。
1.javamailsender.setport(587) 這個端口不是隨意設置的,根據郵箱服務器以及協議來定的。我在網上找了相關資料,大家參考下:
2.關于properties的設置。這里只需要設置其郵箱服務器以及啟用授權碼驗證方式即可。
3.session完成的使用授權碼驗證郵件發送方,相當于建立起一個有效會話。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
|
import com.service.config.configconstant; import org.slf4j.logger; import org.slf4j.loggerfactory; import org.springframework.beans.factory.annotation.autowired; import org.springframework.context.smartlifecycle; import org.springframework.core.env.environment; import org.springframework.mail.javamail.javamailsender; import org.springframework.mail.javamail.mimemessagehelper; import org.springframework.mail.javamail.mimemessagepreparator; import org.springframework.stereotype.component; import javax.mail.internet.mimemessage; import java.util.concurrent.executors; import java.util.concurrent.scheduledexecutorservice; import java.util.concurrent.timeunit; import java.util.concurrent.atomic.atomicinteger; /** * author : qianweifeng * date : 16/4/9. * describe : */ @component public class mailutil implements smartlifecycle { @autowired private javamailsender javamailsender; @autowired private environment env; private logger logger = loggerfactory.getlogger(mailutil. class ); private scheduledexecutorservice service = executors.newscheduledthreadpool( 2 ); private final atomicinteger count = new atomicinteger( 1 ); public mimemessagepreparator send( final string text) { mimemessagepreparator preparator = new mimemessagepreparator() { public void prepare(mimemessage mimemessage) throws exception { mimemessagehelper message = new mimemessagehelper(mimemessage); message.setto(env.getproperty(configconstant.email_to)); message.setfrom(env.getproperty(configconstant.email_from)); message.setsubject( "java email send test" ); // string text = velocityengineutils.mergetemplateintostring(velocityengine, "velocity/report.vm", "utf-8", model); message.settext(text, true ); } }; return preparator; } @override public boolean isautostartup() { return true ; } @override public void stop(runnable runnable) { } @override public void start() { service.schedulewithfixeddelay( new runnable() { @override public void run() { try { if (count.get() == 2 ) { service.shutdown(); logger.info( "the task is down" ); } logger.info( "start send email and the index is " + count); javamailsender.send(send( "test !" + "*" + count.getandincrement())); logger.info( "send email success" ); } catch (exception e){ logger.error( "send email fail" , e); } } }, 2000 , 2000 , timeunit.milliseconds); } @override public void stop() { } @override public boolean isrunning() { return false ; } @override public int getphase() { return 0 ; } } |
使用方式:
將郵件服務器,授權碼,發送方,接受放在application.properties配置好。
項目啟動后就會開始發送,總共發送2封郵件。
使用velocity來構建郵件正文
1
2
3
4
5
6
7
8
9
10
11
|
public void send( final string date, final string date2) { final list<uvbean> uvbean = getuv(start, end); final list<userresandloginreport> resandloginreports = dao.registerandlogin(start, end); map model = new hashmap(); model.put( "uvbean" , uvbean); model.put( "resandloginreports" , resandloginreports); string text = velocityengineutils.mergetemplateintostring(velocityengine, "velocity/report.vm" , "utf-8" , model); } |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<h3> 1 .uv</h3> <table border= "1px" style= "border-collapse: collapse;" > <tr> <td nowrap= "nowarp" style= "width:80px;" class = "date" >日期</td> <td nowrap= "nowarp" style= "width:120px;" class = "head" >uv</td> </tr> #foreach( $data in $uvbean ) <tr> <td nowrap= "nowarp" class = "date" >${data.date}</td> <td nowrap= "nowarp" class = "count" >${data.data}</td> </tr> #end </table> ... |
假設我們需要在郵件中顯示的一些復雜內容,可以后臺以對象的形式包裝起來,放入一個hashmap中,在velocity解析出來,至于如何解析,那就是velocity的語義的問題了。
使用velocity可以在郵件正文中以html的方式來豐富化郵件。
2.使用qq企業郵箱進行發送
過程以及代碼幾乎相同
區別是郵件服務器為:smtp.exmail.qq.com或者pop.exmail.qq.com
沒有授權碼這一概念。
發送端口號25或者smtp協議下端口為465,pop協議下端口為995。
推薦驗證方式為直接用戶名+密碼,或者用ssl方式進行驗證。
具體參考
給出一個簡單的樣例:
1
2
3
4
5
6
7
|
javamailsenderimpl javamailsender = new javamailsenderimpl(); javamailsender.setusername(env.getproperty( "spring.mail.username" )); javamailsender.sethost(env.getproperty( "spring.mail.host" )); javamailsender.setpassword(env.getproperty( "spring.mail.password" )); javamailsender.setport( 25 ); javamailsender.setdefaultencoding( "utf-8" ); javamailsender.send(preparator); |
preparator就是上面出現過的mimemessagepreparator的實例。配置方法見上。
3.總結
1.發送郵件我們首要配置的包括:郵箱服務器,協議,端口。
2.一般驗證有兩種方式,一種是直接的用戶名密碼,另一種是通過授權碼或者ssl進行驗證。
3.郵件的正文可以是純文本,或者是html內容,html內容可以由velocity模板構建或者直接用字符串構建出html內容。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:http://blog.csdn.net/qianweifeng123/article/details/51160380