防止在 ASP.Net Web 窗体中从外部源触发电子邮件

Posted

技术标签:

【中文标题】防止在 ASP.Net Web 窗体中从外部源触发电子邮件【英文标题】:Prevent email triggering from external source in ASP.Net Web Forms 【发布时间】:2019-04-21 14:49:36 【问题描述】:

我正在使用 mailchimp 批量电子邮件订阅向我的客户发送简报电子邮件。但是,有人正在使用某种机制来触发来自我网站的电子邮件。

我不断地从我的网站收到大量电子邮件。

有什么方法可以阻止这种黑客活动吗?

因此,我的订阅即将结束,因为我每分钟使用更多电子邮件。

这是我的代码:

protected void btnSubmit_Click(object sender, EventArgs e)  
  
        //Fetching Settings from WEB.CONFIG file.  
        string emailSender = ConfigurationManager.AppSettings["emailsender"].ToString();  
        string emailSenderPassword = ConfigurationManager.AppSettings["password"].ToString();  
        string emailSenderHost = ConfigurationManager.AppSettings["smtpserver"].ToString();  
        int emailSenderPort = Convert.ToInt16(ConfigurationManager.AppSettings["portnumber"]);  
        Boolean emailIsSSL = Convert.ToBoolean(ConfigurationManager.AppSettings["IsSSL"]);  


        //Fetching Email Body Text from EmailTemplate File.  
        string FilePath = "D:\\MBK\\SendEmailByEmailTemplate\\EmailTemplates\\SignUp.html";  
        StreamReader str = new StreamReader(FilePath);  
        string MailText = str.ReadToEnd();  
        str.Close();  

        //Repalce [newusername] = signup user name   
        MailText = MailText.Replace("[newusername]", txtUserName.Text.Trim());  


        string subject = "Welcome to CSharpCorner.Com";  

        //Base class for sending email  
        MailMessage _mailmsg = new MailMessage();  

        //Make TRUE because our body text is html  
        _mailmsg.IsBodyHtml = true;  

        //Set From Email ID  
        _mailmsg.From = new MailAddress(emailSender);  

        //Set To Email ID  
        _mailmsg.To.Add(txtUserName.Text.ToString());  

        //Set Subject  
        _mailmsg.Subject = subject;  

        //Set Body Text of Email   
        _mailmsg.Body = MailText;  


        //Now set your SMTP   
        SmtpClient _smtp = new SmtpClient();  

        //Set HOST server SMTP detail  
        _smtp.Host = emailSenderHost;  

        //Set PORT number of SMTP  
        _smtp.Port = emailSenderPort;  

        //Set SSL --> True / False  
        _smtp.EnableSsl = emailIsSSL;  

        //Set Sender UserEmailID, Password  
        NetworkCredential _network = new NetworkCredential(emailSender, emailSenderPassword);  
        _smtp.Credentials = _network;  

        //Send Method will send your MailMessage create above.  
        _smtp.Send(_mailmsg);  



      
 

【问题讨论】:

【参考方案1】:

您的表单上应该有验证码:https://www.google.com/recaptcha/intro/v3.html

在您的网站上添加对 library/bin/Release/Recaptcha.dll 的引用:在 Visual Studio 网站菜单上,选择添加引用,然后单击对话框中的 .NET 选项卡。从 .NET 组件列表中选择 Recaptcha.dll 组件,然后单击确定。如果您没有看到该组件,请单击“浏览”选项卡并在硬盘驱动器上查找装配文件。 通过添加以下代码 sn-ps 将 reCAPTCHA 控件插入到您希望保护的表单中: 在 aspx 页面的顶部,插入:

<%@ Register TagPrefix="recaptcha" Namespace="Recaptcha" Assembly="Recaptcha" %>

然后在标签内插入reCAPTCHA控件:

<recaptcha:RecaptchaControl
    ID="recaptcha"
    runat="server"
    PublicKey="your_public_key"
    PrivateKey="your_private_key"
    />

您需要将您的公钥和私钥分别替换为 PublicKey 和 PrivateKey。

确保您使用 ASP.NET 验证来验证您的表单(您应该在提交时检查 Page.IsValid)。

【讨论】:

还有其他选择吗? 您需要阻止机器人提交表单,通过使用验证码您可以做到这一点。根据我的经验,Google ReCaptcha 是最好的选择。还有其他选项:codeproject.com/articles/773785/…

以上是关于防止在 ASP.Net Web 窗体中从外部源触发电子邮件的主要内容,如果未能解决你的问题,请参考以下文章

asp.net web应用程序和asp.net web窗体应用程序的区别?

如何在asp.net核心中从客户端调用web api方法?

ASP.NET Web 窗体和 ASP.NET 网页

如何在 ASP.NET Web 窗体环境中使用 DLL?

text 在Asp.net Web窗体中进行身份验证

ASP.NET Web 窗体用户数据 - 未存储在 SQL 中