Есть хорошие рецепты "свяжитесь с нами" для Cherrypy? - PullRequest
3 голосов
/ 23 октября 2008

Я пытаюсь реализовать форму "Свяжитесь с нами" с Cherrypy и мне было интересно: есть ли хороший рецепт (или лицензионный набор кода BSD), который я мог бы использовать вместо того, чтобы изобретать велосипед?

В идеале это будет совместимо с Cherrpy 3.1.

Ответы [ 2 ]

3 голосов
/ 15 декабря 2012

Я понимаю, что этому вопросу четыре года, но для тех, кто все еще ищет:

Я рекомендую использовать библиотеку python Marrow Mailer . Он абстрагирует весь smtp от sendmail и т. Д., А также обеспечивает отличную проверку на стороне сервера. Код находится под лицензией MIT (которая совместима с BSD-esque и GPL), что вы и искали. В файле readme на github приведены примеры использования. Библиотека совместима с Python 2.6+ и 3.1+.

Marrow Mailer в сочетании с ответом torial предоставляет простую форму «свяжитесь с нами» для CherryPy / python. Я обнаружил, что Voluptuous очень простой валидатор (который вы можете использовать для стороны сервера форм; лицензия BSD) или WIP Validator . Есть также несколько плагинов Javascript / jQuery для проверки клиентской стороны (например, http://docs.jquery.com/Plugins/Validation).

3 голосов
/ 24 октября 2008

Ну, мне пришлось искать решение. Это работает (безобразно и без проверки Javascript) - используя библиотеку smtplib. Кроме того, обратите внимание, что я украл капчу Джеффа для этого примера. Любой, кто использует это, должен будет изменить это.

РЕДАКТИРОВАТЬ: Я добавил проверки.

#!/usr/local/bin/python2.4 
import smtplib 
import cherrypy

class InputExample:
   @cherrypy.expose
   def index(self):
       return "<html><head></head><body><a href="contactus">Contact Us</a></body></html>"


        @cherrypy.expose
        def contactus(self,message=''):
                return """
<html>
<head><title>Contact Us</title>
<script type="text/javascript">

   function isNotEmpty(elem)
   {
      var str = elem.value;
      var re = /.+/;
      if (!str.match(re))
      {
         elem.focus();
         return false;
      }
      else
      {
         return true;
      }

   }

   function isEMailAddr(elem)
   {
      var str = elem.value;
      var re = /^[\w-]+(\.[\w-]+)*@([\w-]+\.)+[a-zA-Z]{2,7}$/;
      if (!str.match(re))
      {
         return false;
      }
      else
      {
         return true;
      }
   }

   function validateForm(form)
   {
      if (isNotEmpty(form.firstName) && isNotEmpty(form.lastName))
      {
         if (isNotEmpty(form.email))
         {
         if (isEMailAddr(form.email))
         {
            if (isNotEmpty(form.captcha))
            {
               if ( form.captcha.value=='egnaro'.split("").reverse().join(""))
               {
                   if (isNotEmpty(form.subject))
                     {
                        alert("All required fields are found.  We will respond shortly.");
                        return true;
                     }
               }
               else
               {
                   alert("Please enter the word as displayed in the image.");
                   return false;
               }
            }//captcha empty
            }
         else
         {
            alert("Please enter a valid email address.");
            return false;
         } //email
         } //email
      } //first and last name
      alert("Please fill in all required fields.");
      return false;
   }

</script>
</head>
<body>
<p>%(message)s</p>
<form method='POST' action='contactUsSubmitted' onsubmit='return validateForm(this)'>
   <label for="firstName">First Name: </label>
   <input type="text" id="firstName" name="firstName" /> (required)<br/>
   <label for="lastName">Last Name: </label>
   <input type="text" id="lastName" name="lastName" /> (required)<br/>
   <label for="email">E-mail address: </label>
   <input type="text" id="email" name="email" /> (required)<br/>
  <label for="phone">Phone number: </label>
   <input type="text" id="phone" name="phone" /> <br/><br/>

   <!--THIS NEEDS TO BE CHANGED TO MATCH YOUR OWN CAPTCHA SCHEME!! -->
   <label for="captcha">Enter the word<br /><img alt="rhymes with.." src="http://www.codinghorror.com/blog/images/word.png" width="99" height="26" border="0" /></label><br />
(<a href="http://www.codinghorror.com/blog/sounds/captcha-word-spoken.mp3">hear it spoken</a>)<br />
   <input tabindex="3" id="captcha" name="captcha" /><br /><br />

   <label for="subject">Subject: </label>
   <input type="text" id="subject" name="subject" /> (required)<br/>
   <label for="body">Details: </label>
   <textarea id="body" name="body"></textarea><br/>

<input type='submit' value='Contact Us' />
</form>
</body>
</html>
"""%{'message':message}


        @cherrypy.expose
        def contactUsSubmitted(self, firstName, lastName, email, phone, captcha, subject, body ):
                if captcha[::-1] != 'egnaro':
                        return self.contactus("Please reenter the word you see in the image." )
                self.sendEmail('mail2.example.com','mailbox_account','mailbox_pwd','me@example.com',email,
                     'Website Contact: '+subject, 'Sender Email: ' + email + '\r\n'
                     'Name: ' + firstName + ' ' + lastName + '\r\n' + 'Phone: ' + phone + '\r\n' + body)
                return self.index()

        def sendEmail(self,smtpServer, mailboxName, mailboxPassword, contactEmail,senderEmail,subject,body):
                server = smtplib.SMTP(smtpServer) #'smtp1.example.com')
                server.login(mailboxName, mailboxPassword)

                msg = "To: %(contactEmail)s\r\nFrom: %(senderEmail)s\r\nSubject: %(subject)s\r\nContent-type: text/plain\r\n\r\n%(body)s"
                msg = msg%{'contactEmail':contactEmail,'senderEmail':mailboxName + '@example.com','subject':subject,'body':body}

                server.sendmail(contactEmail, contactEmail, msg) #This is to send it from an internal account to another internal account.
                server.quit()


cherrypy.root = InputExample()
cherrypy.config.update ( file = 'development.conf' )
cherrypy.server.start()
...