我有一个带有“文件夹访问”的页面和一个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");
}