使用自己的QQ邮箱发送自动发送邮件

2020-04-03 08:53:06

话说网上发送邮件的代码很多,但是我由于不细心,导致拿别人的代码发送邮件老是失败,今天就说说几个要注意的地方吧!!!

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
public bool SendEmail()
 {
     MailMessage msg = new MailMessage();
 
     msg.To.Add("to@qq.com");//收件人地址 
     msg.CC.Add("cc@qq.com");//抄送人地址 
 
     msg.From = new MailAddress("from@qq.com""Edward");//发件人邮箱,名称 
 
     msg.Subject = "This is a test email from QQ";//邮件标题 
     msg.SubjectEncoding = Encoding.UTF8;//标题格式为UTF8 
 
     msg.Body = "this is body";//邮件内容 
     msg.BodyEncoding = Encoding.UTF8;//内容格式为UTF8 
 
     SmtpClient client = new SmtpClient();
 
     client.Host = "smtp.qq.com";//SMTP服务器地址 
     client.Port = 587;//SMTP端口,QQ邮箱填写587 
 
     client.EnableSsl = true;//启用SSL加密 
      //发件人邮箱账号,授权码(注意此处,是授权码你需要到qq邮箱里点设置开启Smtp服务,然后会提示你第三方登录时密码处填写授权码)
     client.Credentials = new System.Net.NetworkCredential("from@qq.com""password");
 
     try
     {
         client.Send(msg);//发送邮件
     }
     catch (Exception)
     {
         return false;
     }
     return true;
 }

  网上类似这段代码的代码很多,但是大多数都说的是client.Credentials = new System.Net.NetworkCredential("from@qq.com", "password")这块写的是password,其实可能之前的前辈们用的时候QQ邮箱需要的是密码,但是现在qq邮箱需要的则是授权码,下面就说怎么拿到这个授权码吧!

  首先发送邮件要开启一个smtp的服务(ps:我这菜鸟还是不久前才知道的,不过好像outlook不是smtp,反正协议很多的)

 第一步:打开qq邮箱点击设置:

 

   然后还有两步你就成功了

 第二步:点击账户

 

第三步:向下拉找到smtp字样的地方,然后全部开启

相信你能理解这句话,然后你开启的时候会自动弹出授权码,如果没有当时没有复制粘贴可以点击生成授权码 ,来重新生成:

就是这个东东了,拿这个复制粘贴到你代码的password处即可(ps:本菜鸟被坑的很惨啊,再说多一句163的邮箱也是这样的,只有开启smtp服务才能拿到授权码)


  • 2020-05-24 08:10:18

    echarts标题(title)配置

    show:true,//显示策略,默认值true,可选为:true(显示) | false(隐藏) text: '主标题',//主标题文本,'\n'指定换行 link:'',//主标题文本超链接,默认值true target: null,//指定窗口打开主标题超链接,支持'self' | 'blank',不指定等同为'blank'(新窗口) subtext: '副标题',//副标题文本,'\n'指定换行 sublink: '',//副标题文本超链接

  • 2020-06-02 08:57:12

    clipboard复制成功但是粘贴板是空的

    将文本复制到剪贴板应该不难。配置它不需要几十个步骤,也不需要加载数百KB的js文件 。但最重要的是,它不应该依赖Flash或任何臃肿的框架。这就是clipboard.js存在的原因。

  • 2020-06-04 13:54:21

    vue生成的__ob__: Observer无法解析jsonp

    computed 从vuex获得数据,watch监听数据 然而问题就出现在了监听上,监听不到,给个setTimeOut 1000 就能检测到数据了,不然打印时又数据,用的时候时空的,不知道时什么原因。

  • 2020-06-06 20:22:56

    laravel 接收json串

    在做项目的时候发现 用平时的$request->all() 无法获取到请求值

  • 2020-06-09 08:50:28

    LRU原理以及js实现

    LRU(Least recently used,最近最少使用)算法根据数据的历史访问记录来进行淘汰数据,其核心思想是“如果数据最近被访问过,那么将来被访问的几率也更高”。