2012-07-29 39 views
0

我很努力地爲使用C#Mail函數發送的HTML郵件中的此嵌入式圖像獲取地圖。一切正常,系統發送電子郵件,圖像顯示在該電子郵件中,但沒有任何映射。 你能幫我解決這個問題嗎?如何讓這個圖像的地圖在郵件功能中運行良好?

注意:圖像上的映射區域應該是固定的,它不應該通過調整窗口大小等來影響。

C#郵件功能:

protected void Page_Load(object sender, EventArgs e) 
    { 
     Send(); 
    } 


    protected void SendEmail(string toAddresses, string fromAddress, string MailSubject, string MessageBody, bool isBodyHtml, AlternateView av) 
    { 
     SmtpClient sc = new SmtpClient("Mail Address"); 
     try 
     { 
      MailMessage msg = new MailMessage(); 
      msg.From = new MailAddress("[email protected]", "Test Sys."); 


      msg.Bcc.Add(toAddresses); 
      msg.Subject = MailSubject; 
      msg.Body = MessageBody; 
      msg.IsBodyHtml = isBodyHtml; 
      msg.AlternateViews.Add(av); 
      sc.Send(msg); 
     } 
     catch (Exception ex) 
     { 
      throw ex; 
     } 

    } 

    protected void Send() 
    { 
     string connString = "Data Source=localhost;Initial Catalog=TestDB;Integrated Security=True"; 

     using (SqlConnection conn = new SqlConnection(connString)) 
     { 
      var sbEmailAddresses = new System.Text.StringBuilder(2000); 
      string quizid = ""; 

      // Open DB connection. 
      conn.Open(); 

      string cmdText = "SELECT MIN (QuizID) As mQuizID FROM dbo.QUIZ WHERE IsSent <> 1"; 
      using (SqlCommand cmd = new SqlCommand(cmdText, conn)) 
      { 
       SqlDataReader reader = cmd.ExecuteReader(); 
       if (reader != null) 
       { 
        while (reader.Read()) 
        { 
         // There is only 1 column, so just retrieve it using the ordinal position 
         quizid = reader["mQuizID"].ToString(); 

        } 
       } 
       reader.Close(); 
      } 

      string cmdText2 = "SELECT Username FROM dbo.employee"; 
      using (SqlCommand cmd = new SqlCommand(cmdText2, conn)) 
      { 
       SqlDataReader reader = cmd.ExecuteReader(); 
       if (reader != null) 
       { 
        while (reader.Read()) 
        { 
         var sName = reader.GetString(0); 
         if (!string.IsNullOrEmpty(sName)) 
         { 
          if (sbEmailAddresses.Length != 0) 
          { 
           sbEmailAddresses.Append(","); 
          } 
          // Just use the ordinal position for the user name since there is only 1 column 
          sbEmailAddresses.Append(sName).Append("@mailAddress.com"); 
         } 
        } 
       } 
       reader.Close(); 
      } 

      string cmdText3 = "UPDATE dbo.Quiz SET IsSent = 1 WHERE QuizId = @QuizID"; 
      using (SqlCommand cmd = new SqlCommand(cmdText3, conn)) 
      { 
       // Add the parameter to the command 
       var oParameter = cmd.Parameters.Add("@QuizID", SqlDbType.Int); 

       var sEMailAddresses = sbEmailAddresses.ToString(); 
       string link = "<a href='http://localhost/test.aspx?testid=" + quizid + "'> Click here to participate </a>"; 
       string body = @"............................"; 


       body += "<map id =\"clickMap\" name=\"clickMap\"> " + 
        "<area shape =\"rect\" coords =\"752,394,1394,491\" href =" + link + " alt=\"Quiz\" /></map>"; 


       AlternateView av = AlternateView.CreateAlternateViewFromString(body, null, MediaTypeNames.Text.Html); 
       LinkedResource lr = new LinkedResource(@"WelcomeMessage.png", MediaTypeNames.Image.Jpeg); 
       lr.ContentId="image1"; 
       av.LinkedResources.Add(lr); 


       int sendCount = 0; 
       List<string> addressList = new List<string>(sEMailAddresses.Split(',')); 
       StringBuilder addressesToSend = new StringBuilder(); 

       if (!string.IsNullOrEmpty(quizid)) 
       { 
        for (int userIndex = 0; userIndex < addressList.Count; userIndex++) 
        { 
         sendCount++; 
         if (addressesToSend.Length > 0) 
          addressesToSend.Append(","); 

         addressesToSend.Append(addressList[userIndex]); 
         if (sendCount == 10 || userIndex == addressList.Count - 1) 
         { 
          SendEmail(addressesToSend.ToString(), "", "Notification", body, true, av); 
          addressesToSend.Clear(); 
          sendCount = 0; 
         } 
        } 

        // Update the parameter for the current quiz 
        oParameter.Value = quizid; 
        // And execute the command 
        cmd.ExecuteNonQuery(); 
       } 

      } 
      conn.Close(); 
     } 
    } 

* UPDATE: *

最後,我可能是能夠使被點擊的用戶的那部分。我現在想要的是不管窗口的大小如何,都要固定位置。這意味着如果用戶在小窗口或大窗口中打開電子郵件,這不會影響點擊的位置。怎麼做?

回答

0

試試這個:

LinkedResource(Server.MapPath(".") + (@"\images\WelcomeMessage.png", MediaTypeNames.Image.Jpeg); 
+0

感謝您的幫助,但我得到了我把這個錯誤的錯誤:**異常詳細信息:System.NotSupportedException:指定路徑的格式不支持** – 2012-07-29 07:49:47

+0

另外,我正在談論映射要點擊的圖像的特定部分。我已經收到了電子郵件中的圖片。我想要的是映射它的特定部分來點擊。 – 2012-07-29 07:50:55

+0

你能看看我更新的問題嗎? – 2012-07-29 09:05:41