1

このdjango-contact-formアプリをインストールしました。連絡先フォームから Gmail アカウントにメールを送信したい場合、エラーは発生せず、 contact_form_sent.htmlにリダイレクトされますが、メールは送信されません。この問題のデバッグを手伝ってくれる人はいますか。私はlocalhostからテストしているので、これはsmtpサーバーの問題ですか?

私の構成は次のとおりです。これは、 Patrick Beeson のものに似ています。

settings.py 他のメール アカウントとその適切なポートを既に確認しました。

DEBUG = True
TEMPLATE_DEBUG = DEBUG

ADMINS = (
      #('***', '***@googlemail.com'),
)

MANAGERS = ADMINS

EMAIL_HOST = 'smtp.gmail.com'   
EMAIL_HOST_PASSWORD = '********'  
EMAIL_HOST_USER = '******@googlemail.com' 
EMAIL_PORT = 587 #465 or 587  
#EMAIL_SUBJECT_PREFIX = 'Django Test mail'  
EMAIL_USE_TLS = True  

urls.py

(r'^contact/', include('contact_form.urls')),

contact_form.html

...
              <form method="POST">
              <ol>
              {{ form.as_p }}
              <li>
          <input type="submit" name="submit" value={% trans "Senden" %} />
                <div class="clr"></div>
              </li>
              </ol>
              </form>
...

contact_form.txt

{{ name }}
{{ email }}
{{ body }}

contact_form_sent.html

{% block content %}
           <h2>{% trans "Your message was sent." %}</h2>
{% endblock %}

contact_form_subject.txt

message from {{ name }}

編集済み

contact_form.htmlに設定action="."して追加すると、送信ボタンをクリックした後、localhost の開発サーバーでこれを取得します。print request.POST

<QueryDict: {u'body': [u'This is my Test message for you !!\r\n\r\nBest Regards\r\nMr. NoOne'], u'name': [u'testname'], u'submit': [u'Send'], u'email': [u'anyone@myemail.
com']}>

編集済み

独自の view.py を作成すると、次のエラーが発生します。

Request Method:     POST
Request URL:    http://127.0.0.1:8000/en/contact/
Exception Type:     error
Exception Value:    

(10065, 'No route to host')

Exception Location:     C:\Python25\lib\smtplib.py in connect, line 310
Python Executable:  C:\Python25\python.exe
Python Version:     2.5.0
Python Path:    ['H:\\webpage', 'C:\\WINDOWS\\system32\\python25.zip', 'C:\\Python25\\DLLs', 'C:\\Python25\\lib', 'C:\\Python25\\lib\\plat-win', 'C:\\Python25\\lib\\lib-tk', 'C:\\Python25', 'C:\\Python25\\lib\\site-packages']

私の新しいviews.pyは次のようになります:

from django.conf import settings
from django.http import HttpResponse
from django.shortcuts import render_to_response
from django.template import RequestContext
from django.core.mail import send_mail

from contact_form.forms import ContactForm


def email_contact(request, form_class=ContactForm, template_name='contact_form/contact_form.html'):
    form = form_class(data=request.POST, files=request.FILES, request=request)
    if request.method == "POST":
        send_mail('Subject here', 'Here is the message.', 'from@example.com', ['to@example.com'], fail_silently=False)
        print request.POST
    return render_to_response(template_name, { 'form': form }, context_instance=RequestContext(request))

ここで何がうまくいかないのですか?

4

2 に答える 2

0

これらのメールを検索するため、settings.pyのADMIN、MANAGERS設定が使用可能であることを確認してください

contact_formのforms.pyで

class BaseEmailFormMixin(object):
    from_email = settings.DEFAULT_FROM_EMAIL
    recipient_list = [email for _, email in settings.MANAGERS]

もう一度、youtsettings.pyでメールポートホスト設定を設定してください

EMAIL_HOST = 'yourmailserver'
EMAIL_PORT = "587"
EMAIL_HOST_USER = ''
EMAIL_HOST_PASSWORD = ''
EMAIL_USE_TLS = True
于 2012-03-07T19:08:04.353 に答える
0

フォームが送信されても​​よろしいですか? debug true でフォームを送信し、フォームに csrf トークンが存在しない場合、Django はエラーを返すはずです。別のアイデア; smtp.gmail.com と話しているが、@googlemail.com アドレスを使用している。それが対応していると確信していますか?

編集

私はこれを別の方法で行いました。既存のアプリを使用する代わりに、新しいアプリを作成します。私のアプリはメール送信以上のことをする必要がありました。ファイルが 2 つしかないので、これで十分です。私もgmailを使用しましたが、もう1つのプラス:)関連するコードを提供しますが、平和を切り取るので、それを見てください;)

settings.py:

from local import localsettings

DEBUG = True
TEMPLATE_DEBUG = DEBUG

ADMINS = (
    ('Jasper Kennis', 'jasper.kennis@companymail.nl'),
)

MANAGERS = ADMINS

DATABASES = {
    'default': {
        'ENGINE': localsettings.db_engine,
        'NAME': localsettings.db_name,
        'USER': '',
        'PASSWORD': '',
        'HOST': '',
        'PORT': '',
    }
}

SITE_ID = 1

# If you set this to False, Django will make some optimizations so as not
# to load the internationalization machinery.
USE_I18N = True

# If you set this to False, Django will not format dates, numbers and
# calendars according to the current locale
USE_L10N = True

# Make this unique, and don't share it with anybody.
SECRET_KEY = '###'

MIDDLEWARE_CLASSES = (
    'django.middleware.common.CommonMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
)


INSTALLED_APPS = (
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.sites',
    'django.contrib.messages',
    'django.contrib.admin',
        'therelevantapp',
)


EMAIL_USE_TLS = True
EMAIL_HOST = 'smtp.gmail.com'
EMAIL_HOST_USER = '###@gmail.com'
EMAIL_HOST_PASSWORD = '###'
EMAIL_PORT = 587

そしてアプリ app/views.py

import os
import os.path
import string
from random import choice

from app.models import *
from TitelGenerator.TitelGenerator import TitelGenerator
from django import forms
from django.conf import settings
from django.http import HttpResponse
from django.shortcuts import render_to_response
from django.template import RequestContext
from django.core.mail import send_mail
from django.core.mail import EmailMultiAlternatives



def klaar(request):
    if request.method == "POST":
        title = 'Je inschrijving is voltooid!'
        message = 'a whole message'
        send_mail( title , message , 'sendermail' , 'receivermail' ,     fail_silently=False)

        return render_to_response('klaar.html' , { 'titel': kind.id, 'request':     request.FILES }, context_instance = RequestContext(request))

フォーム内に {% csrf_token %} が必要であることに注意してください。この場合、自分で作成する必要があるフォーム テンプレートです。これが役に立ったかどうか教えてください。

于 2011-01-06T12:54:28.867 に答える