2
protected void Button2_Click(object sender, EventArgs e) {        
    //string vv;
    //vv = (string)Session["FID"];
    DateTime sdt = DateTime.Today;
    SqlConnection cn1 = new SqlConnection();
    SqlCommand cmd4 = new SqlCommand();

    cn1.ConnectionString = @"Data Source=BOPSERVER;Initial Catalog=Project;Integrated Security=True";

    String test = DateTime.Now.ToString("dd.MM.yyy");

    for (int i = 0; i <= GridView1.Rows.Count - 1; i++) {

       string toemail = GridView1.Rows[i].Cells[2].Text;
       string FID1 = GridView1.Rows[i].Cells[0].Text;
       GridViewRow row = GridView1.Rows[i];
       CheckBox Ckbox = (CheckBox)row.FindControl("CheckBoxMark1");
       if (Ckbox.Checked == true) {
           sendMail(toemail);

           //ClientScript.RegisterStartupScript(Page.GetType(), "validation", "<script language='javascript'>alert('Email send Succesfully')</script>");
           ClientScript.RegisterStartupScript(Page.GetType(), "validation", "<script language='javascript'>alert('Email sent  on " + test + "')</script>");

           cn1.Open();
           //cmd4.CommandText = "Insert into TrackingFaculty_det  (EmailsentDate)  values (@EmailsentDate) WHERE FID=@FID";
           cmd4.CommandText = "update TrackingFaculty_det SET EmailsentDate=@Email WHERE FID=@FID  ";
           cmd4.CommandType = CommandType.Text;
           cmd4.Connection = cn1;

           cmd4.Parameters.Clear();

           cmd4.Parameters.Add("@Email", SqlDbType.DateTime, 8);
           cmd4.Parameters["@Email"].Value = sdt;
           cmd4.Parameters.Add("@FID", SqlDbType.VarChar, 10);
           cmd4.Parameters["@FID"].Value = FID1;
           cmd4.ExecuteNonQuery();
           cn1.Close();
       }                      
   }
}

public void sendMail(String toemail) {
    try {
        MailMessage mail = new MailMessage();
        mail.To.Add(toemail);
        mail.From = new MailAddress("manipal.mcis1@gmail.com");
        mail.Subject = "Remember Mail";
        // string Body = "Please update profile";
        //mail.Body = Body;
        mail.Body = "  Dear Sir/Madam \n\n\n Please update your profile. . \n\n\n Thanks & Regards \n\n\n MCIS,Manipal.";
        //mail.Body = "<html><body> <h2" + "align=center>Dear Sir/Madam" + "</h2> Please update ur profile</body></html>";
        SmtpClient smtp = new SmtpClient();
        smtp.Host = "smtp.gmail.com";
        smtp.Port = 587;
        smtp.UseDefaultCredentials = false;
        smtp.Credentials = new System.Net.NetworkCredential("manipal.mcis1@gmail.com", "manipal15");
        smtp.EnableSsl = true;
        smtp.Send(mail);
    } catch (Exception ex) {            
        //System.ArgumentException argx = new System.ArgumentException("There is some problem in sending mail please try again later");
        //throw argx;
        //Console.WriteLine("There is some problem in sending mail please try again later", ex.Message);
        Response.Write(ex.ToString());
    }

これらのコード行により、mail使用中のsmtpポートを送信できるようになり、正常に動作します。他の見込み客を見ると、のようなexceptions入力の可能性がある場所があるかもしれませんし、特定の時間にメールを送信できない場所があるかもしれませんし、他の例外があるかもしれません。ポップアップウィンドウが表示されるか、メールが送信できないなどのエラーメッセージが表示されるはずですが、可能性はありますか?Dummy emailabc@gmail.comserver issues

4

2 に答える 2

0

<asp:Label>オーバー/アンダーを追加するだけGridViewで、例外が発生した場合はTextエラーメッセージに設定できます。

<asp:Label ID="lblMsg" runat="server"></asp:Label>

..

try{
    sendMail(toemail);
}
catch(Exception ex){
    lblMsg.Text = ex.Message; // or whatever message you want to show
    lblMsg.ForeColor = Color.Red // Red shows error
}

...

public void sendMail(String toemail){

    try{
        ...
    }
    catch(Exception ex){
        throw ex; // Don't use Response.Write
    }
}
于 2013-10-15T06:55:33.613 に答える