支持office 365邮箱,默认展示微信登录框
This commit is contained in:
parent
c27b51d246
commit
b1da079f37
BIN
.VERSION.un~
Normal file
BIN
.VERSION.un~
Normal file
Binary file not shown.
67
common/email.go.bak
Normal file
67
common/email.go.bak
Normal file
@ -0,0 +1,67 @@
|
|||||||
|
package common
|
||||||
|
|
||||||
|
import (
|
||||||
|
"crypto/tls"
|
||||||
|
"encoding/base64"
|
||||||
|
"fmt"
|
||||||
|
"net/smtp"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
func SendEmail(subject string, receiver string, content string) error {
|
||||||
|
if SMTPFrom == "" { // for compatibility
|
||||||
|
SMTPFrom = SMTPAccount
|
||||||
|
}
|
||||||
|
encodedSubject := fmt.Sprintf("=?UTF-8?B?%s?=", base64.StdEncoding.EncodeToString([]byte(subject)))
|
||||||
|
mail := []byte(fmt.Sprintf("To: %s\r\n"+
|
||||||
|
"From: %s<%s>\r\n"+
|
||||||
|
"Subject: %s\r\n"+
|
||||||
|
"Content-Type: text/html; charset=UTF-8\r\n\r\n%s\r\n",
|
||||||
|
receiver, SystemName, SMTPFrom, encodedSubject, content))
|
||||||
|
auth := smtp.PlainAuth("", SMTPAccount, SMTPToken, SMTPServer)
|
||||||
|
addr := fmt.Sprintf("%s:%d", SMTPServer, SMTPPort)
|
||||||
|
to := strings.Split(receiver, ";")
|
||||||
|
var err error
|
||||||
|
if SMTPPort == 465 {
|
||||||
|
tlsConfig := &tls.Config{
|
||||||
|
InsecureSkipVerify: true,
|
||||||
|
ServerName: SMTPServer,
|
||||||
|
}
|
||||||
|
conn, err := tls.Dial("tcp", fmt.Sprintf("%s:%d", SMTPServer, SMTPPort), tlsConfig)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
client, err := smtp.NewClient(conn, SMTPServer)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer client.Close()
|
||||||
|
if err = client.Auth(auth); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if err = client.Mail(SMTPFrom); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
receiverEmails := strings.Split(receiver, ";")
|
||||||
|
for _, receiver := range receiverEmails {
|
||||||
|
if err = client.Rcpt(receiver); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
w, err := client.Data()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
_, err = w.Write(mail)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
err = w.Close()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
err = smtp.SendMail(addr, auth, SMTPAccount, to, mail)
|
||||||
|
}
|
||||||
|
return err
|
||||||
|
}
|
@ -29,7 +29,7 @@ const LoginForm = () => {
|
|||||||
}
|
}
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
const [showWeChatLoginModal, setShowWeChatLoginModal] = useState(false);
|
const [showWeChatLoginModal, setShowWeChatLoginModal] = useState(true);
|
||||||
|
|
||||||
const onGitHubOAuthClicked = () => {
|
const onGitHubOAuthClicked = () => {
|
||||||
window.open(
|
window.open(
|
||||||
|
Loading…
Reference in New Issue
Block a user