gmail 邮箱附件大小 突破10M


        今天找到一个小秘密,按照google mail的下列帮助,可知google mail 的附件大小只有10M,还包括了邮件本身,但是实际却不是这样,我今天一个文件,我并没有看大小,结果误把一个大约14M的文件上传成功了,这是Google工程师的一次失误吗?
1、google可能是对抗yahoo超大邮箱3.8g,大于20M附件的一次小反击,只不过没有声张,以免造成服务器的负担,毕竟这样的服务未必能够给他们带来利润,因为google的邮箱广告是做得最好的,完全可以订制,可有可无,不强加给网民,不会影响速度,如果你还有机会使用原始老猫上网,你就知道google是多么为你节省时间了。
2、当然如果真的是google工程师的一次失误,希望他们没有看到我的blog,因为google mail 完全可以不借助第三方软件变成一个十足的网络硬盘了。


这是google附件大小帮助文件:
 
What's the maximum attachment size?
With Gmail, you can send and receive messages up to 10 megabytes (MB) in size. However, the precise amount allowable will depend on the attachment.
When you add an attachment, the size of a file may increase because transport encodings are automatically added. (Transport encodings are the information that allows your message to be safely sent and read.)
This means that in some cases, attachments that are 6 to 10MB in size may push the total message size above 10MB. When this happens, Gmail displays a warning that your message exceeds the 10MB limit. 

 

 
以下是使用golang下载gmail邮件附件的示例代码: ```go package main import ( "encoding/base64" "fmt" "io" "log" "net/mail" "net/smtp" "os" "path/filepath" "strings" "github.com/joho/godotenv" "golang.org/x/net/context" "golang.org/x/oauth2" "golang.org/x/oauth2/google" "google.golang.org/api/gmail/v1" ) func main() { // 加载.env环境变量文件 err := godotenv.Load() if err != nil { log.Fatalf("Error loading .env file: %v", err) } // 获取OAuth2访问令牌 ctx := context.Background() config, err := google.ConfigFromJSON([]byte(os.Getenv("GOOGLE_CLIENT_SECRET")), gmail.GmailReadonlyScope) if err != nil { log.Fatalf("Unable to parse client secret file to config: %v", err) } token := &oauth2.Token{ AccessToken: os.Getenv("GOOGLE_ACCESS_TOKEN"), RefreshToken: os.Getenv("GOOGLE_REFRESH_TOKEN"), TokenType: "Bearer", Expiry: oauth2.Now(), } client := config.Client(ctx, token) // 创建Gmail服务 srv, err := gmail.New(client) if err != nil { log.Fatalf("Unable to retrieve Gmail client: %v", err) } // 获取最新的10封邮件 user := "me" r, err := srv.Users.Messages.List(user).MaxResults(10).Q("is:unread").Do() if err != nil { log.Fatalf("Unable to retrieve messages: %v", err) } // 下载每个邮件的附件 for _, m := range r.Messages { msg, err := srv.Users.Messages.Get(user, m.Id).Do() if err != nil { log.Fatalf("Unable to retrieve message %v: %v", m.Id, err) } // 解析邮件头部 h := msg.Payload.Headers var subject, from, date string for _, v := range h { switch v.Name { case "Subject": subject = v.Value case "From": from = v.Value case "Date": date = v.Value } } // 下载附件 for _, p := range msg.Payload.Parts { if p.Filename != "" { part := p.Body data, err := base64.URLEncoding.DecodeString(part.Data) if err != nil { log.Fatalf("Unable to decode attachment %v: %v", p.Filename, err) } // 将附件保存到本地 ext := filepath.Ext(p.Filename) filename := fmt.Sprintf("%s_%s%s", strings.ReplaceAll(from, "@", "_"), subject, ext) f, err := os.Create(filename) if err != nil { log.Fatalf("Unable to create file %v: %v", filename, err) } defer f.Close() _, err = io.Copy(f, strings.NewReader(string(data))) if err != nil { log.Fatalf("Unable to save file %v: %v", filename, err) } log.Printf("Attachment saved: %v", filename) } } } } ``` 在上面的代码中,首先加载.env文件,该文件包含Google应用程序凭据和OAuth2访问令牌。 然后使用OAuth2访问令牌创建Gmail客户端,并使用该客户端获取最新的10封未读邮件。 对于每个邮件,我们获取其详细信息,包括邮件头部和附件。然后,我们使用base64解码附件数据,并将其保存到本地文件中。文件名采用发送方的电子邮件地址、主题和附件扩展名的组合。 最后,我们在控制台输出“Attachment saved: filename”以指示附件已成功保存。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值