ASP:Wizard ControlとSMTPClientを使用したASP.net 3.5 Webサイトが電子メールを送信しない
-
07-07-2019 - |
質問
Framework 3.5を実行しているサイトにasp:Wizardコントロールがあります。 Webホストから設定を取得し、Web設定ユーティリティに入力しました。コードビハインドファイルは次のとおりです。
Protected Sub Wizard1_FinishButtonClick(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.WizardNavigationEventArgs) Handles Wizard1.FinishButtonClick
Dim mySMTPClient As New SmtpClient()
Dim sb As New StringBuilder
Dim myMail As New MailMessage("webmaster@mydomain.com", "user@mydomain.com")
Dim myFrom As New MailAddress("webmaster@mydomain.com")
Dim myTo As New MailAddress("user@anotherdomain.com")
myMail.BodyEncoding = System.Text.Encoding.UTF8
myMail.IsBodyHtml = False
myMail.To.Add(myTo)
myMail.Subject = "Request for Information"
sb.Append("Contact Name: ")
sb.Append(txtcontactname.Text)
sb.Append("<br/>Phone Number: ")
sb.Append(txtcontactphone.Text)
sb.Append("<br/>Employer Name: ")
sb.Append(txtemployername.Text)
sb.Append("<br/>City: ")
sb.Append(txtcity.Text)
sb.Append("<br/>State: ")
sb.Append(cmbstate.Text)
sb.Append("<br/>Zip: ")
sb.Append(txtzip.Text)
sb.Append("<br/>Other Location: ")
sb.Append(txtotherloc.Text)
sb.Append("<br/>Nature of Business: ")
sb.Append(txtbusnat.Text)
sb.Append("<br/>Eligible Employees: ")
sb.Append(txteligemps.Text)
sb.Append("<br/>Average Employee Turnover Per Year: ")
sb.Append(txtempturnover.Text)
sb.Append("<br/>Broker Name: ")
sb.Append(txtbrokername.Text)
sb.Append("<br/>Broker Email: ")
sb.Append(txtbrokeremail.Text)
sb.Append("<br/>Proposed Effective Date: ")
sb.Append(txteffdate.SelectedDate)
sb.Append("<br/>Limited Benefit Medical Plans: ")
For Each item As ListItem In chkmedplans.Items
If (item.Selected) Then
sb.Append(item.Text)
sb.Append(" ")
End If
Next
sb.Append("<br/>Voluntary Products/Services: ")
For Each item As ListItem In chkvolserv.Items
If (item.Selected) Then
sb.Append(item.Text)
sb.Append(" ")
End If
Next
sb.Append("<br/>Employer Paid Products/Services: ")
For Each item As ListItem In chkempserv.Items
If (item.Selected) Then
sb.Append(item.Text)
sb.Append(" ")
End If
Next
sb.Append("<br/>Preferred Benefit Enrollment Program(s): ")
For Each item As ListItem In chkenrolprog.Items
If (item.Selected) Then
sb.Append(item.Text)
sb.Append(" ")
End If
Next
sb.Append("<br/>Comments: ")
sb.Append(txtcomments.Text)
myMail.Body = sb.ToString()
Try
mySMTPClient.Send(myMail)
Catch ex As Exception
Dim ex2 As Exception = ex
Dim errorMessage As String = String.Empty
While Not (ex2 Is Nothing)
errorMessage += ex2.ToString()
ex2 = ex2.InnerException
End While
Response.Write(errorMessage)
End Try
End Sub
終了クラス
コードはエラーなしで準拠しています。共有ホスティングアカウントに読み込まれると、ページが読み込まれ、コードによりユーザーはウィザードに情報を入力できます。ただし、[完了]ボタンは最終ステップを起動しません。最後のウィザード手順のコードは次のとおりです。
<asp:WizardStep ID="WizardStep4" runat="server" StepType="Complete" Title="Complete">
Thank you for your inquiry. A member of our staff will contact you regarding your request.</asp:WizardStep>
この問題の原因を特定できません。誰かが原因を教えてくれますか?
ありがとう、 シド
解決
コード内にブレークポイントを設定して、メールを送信するコードに実際に到達しているかどうかを確認しましたか?たとえば、少なくとも次の場所にブレークポイントを設定することをお勧めします。
FinishButtonClickイベントが発生していることを確認するには
Dim mySMTPClient As New SmtpClient()
Sendmailコードがヒットしていることを確認するには。
mySMTPClient.Send(myMail)
例外が発生しているかどうかを確認します。
Dim ex2 As Exception = ex
また、他にも注意すべき点が少なくとも2つあります。
-
SMTPサーバーが構成されていないか、適切に構成されていない可能性があります。
-
SMTPサーバーが適切に構成されている場合でも、ファイアウォール(またはISP)がSMTPメールの送信をブロックしていないことを確認する必要があります。
所属していません StackOverflow