1

我有一个带有“文件夹访问”的页面和一个CheckBox.

今天,在我的 中,对于此文件夹访问.cs中的每个checkbox检查,我都会向此文件夹的所有者发送电子邮件。为了收到这封电子邮件,我在我的页面中创建了一个 HiddenField to Email。

但是,现在,每个文件夹都有多个所有者。如果它继续这种方式,我有重复的行。如何获取每个文件夹的电子邮件列表?

我的.aspx

<Columns>
    <asp:BoundField DataField="FolderAccess" HeaderText="Folder Access" />
    <asp:TemplateField>
        <ItemTemplate>
            <asp:CheckBox ID="CheckBox1" runat="server" Text="Access to Read" OnCheckedChanged="CheckBox1_ChangeCheck"
                AutoPostBack="true" />
            <asp:HiddenField ID="Email" runat="server" Value='<%# Bind("Email") %>' />
        </ItemTemplate>
    </asp:TemplateField>
</Columns>

我的.cs

public class ListRequest
{
    public string Email { get; set; }
    public string FolderAccess { get; set; }
}

public List<ListRequest> PreencheValores(SqlDataReader reader)
{
    var lista = new List<ListRequest>();
    while (reader.Read())
    {
        var listRequest = new ListRequest();

        listRequest.Email = reader["Email"].ToString();
        listRequest.FolderAccess = reader["FolderAccess"].ToString();
        lista.Add(listRequest);
    }
    return lista;
}


public List<ListRequest> ConsultarRequest()
{
    var lstRetorno = new List<ListRequest>();
    using (objConexao = new SqlConnection(strStringConexao))
    {
        using (objCommand = new SqlCommand(strSelectPorID, objConexao))
        {
            try
            {
                objConexao.Open();
                var objDataReader = objCommand.ExecuteReader();
                if (objDataReader.HasRows)
                    lstRetorno = PreencheValores(objDataReader);
            }
            catch (Exception ex)
            {
                throw new Exception(ex.Message);
            }
            finally
            {
                objConexao.Close();
            }
        }
    }
    return lstRetorno;
}

protected void btnSend_OnClick(object sender, EventArgs e)
{
    foreach (GridViewRow row in GridView.Rows)
    {
        CheckBox check = (CheckBox)row.FindControl("CheckBox1");
        HiddenField hd1 = (HiddenField)row.FindControl("Email");
        string email = hd1.Value.ToString();

        if (check.Checked == true)
        {

            System.Net.Mail.MailMessage objEmail = new System.Net.Mail.MailMessage();
            objEmail.From = new MailAddress("caio.jesus@br.com", "XXX");
            objEmail.To.Add(email);
            objEmail.Priority = System.Net.Mail.MailPriority.High;
            objEmail.IsBodyHtml = true;
            objEmail.Subject = "System NDRSecurity - Novas Requisições.";
            objEmail.Body = "TEST";
            objEmail.SubjectEncoding = Encoding.GetEncoding("ISO-8859-1");
            objEmail.BodyEncoding = Encoding.GetEncoding("ISO-8859-1");
            SmtpClient objSmtp = new SmtpClient("XXX");
            objSmtp.EnableSsl = true;
            objSmtp.Port = 25;
            objSmtp.Credentials = new NetworkCredential("caio.jesus@br.com", "XXX");
            objSmtp.Send(objEmail);
        }
    }

    Response.Redirect("home.aspx");
}
4

2 回答 2

1

我想你可以让你的 ListRequest 对象包含一个电子邮件地址列表。然后您的隐藏字段将包含该列表。

public class ListRequest
{
    public List<string> EmailAddresses { get; set; }
    public string FolderAccess { get; set; }
}

然后你必须改变你的 onlcick 来循环 hd1 变量中的值。

if (check.Checked == true)
{
    foreach(string email in (List<string>hd1.Value))
    {
        System.Net.Mail.MailMessage objEmail = new System.Net.Mail.MailMessage();
        objEmail.From = new MailAddress("caio.jesus@br.com", "XXX");
        objEmail.To.Add(email);
        objEmail.Priority = System.Net.Mail.MailPriority.High;
        objEmail.IsBodyHtml = true;
        objEmail.Subject = "System NDRSecurity - Novas Requisições.";
        objEmail.Body = "TEST";
        objEmail.SubjectEncoding = Encoding.GetEncoding("ISO-8859-1");
        objEmail.BodyEncoding = Encoding.GetEncoding("ISO-8859-1");
        SmtpClient objSmtp = new SmtpClient("XXX");
        objSmtp.EnableSsl = true;
        objSmtp.Port = 25;
        objSmtp.Credentials = new NetworkCredential("caio.jesus@br.com", "XXX");
        objSmtp.Send(objEmail);
    }
}
于 2013-07-15T13:46:02.277 回答
0

除了 John Kraft 建议的之外,如果您仍想保留StringList 而不是 List,您可以使用 CSV 电子邮件地址。

String s = "email1@email.com, email2@email.com, email3@email.com";

然后使用 Regex 进行拆分(这会处理额外的空格):

foreach(string email in Regex.Split(s, @"\s*[,;]\s*"))
{ ... }
于 2013-07-15T14:16:49.913 回答