Rails HTML избегает текстовых писем - PullRequest
3 голосов
/ 01 ноября 2011

Итак, у Rails есть замечательная возможность отправлять обычные электронные письма вместе с электронными письмами в формате HTML.

Вы просто добавили .text.erb рядом с вашим .html.erb. Я подал заявку на этот счет здесь: https://github.com/cairo140/rails-email-test. Просто скачайте и запустите. Посетите домашнюю страницу и проверьте журналы.

Вот вывод:

Sent mail to test@test.com (19ms)
Date: Tue, 01 Nov 2011 14:48:59 -0400
From: test@test.com
To: test@test.com
Message-ID: <4eb03f1b7403b_178858111fcc060bd@Steven-Xus-Macbook-Pro.local.mail>
Subject: test
Mime-Version: 1.0
Content-Type: multipart/alternative;
 boundary="--==_mimepart_4eb03f1b708ce_178858111fcc057a4";
 charset=UTF-8
Content-Transfer-Encoding: 7bit



----==_mimepart_4eb03f1b708ce_178858111fcc057a4
Date: Tue, 01 Nov 2011 14:48:59 -0400
Mime-Version: 1.0
Content-Type: text/plain;
 charset=UTF-8
Content-Transfer-Encoding: 7bit
Content-ID: <4eb03f1b72b72_178858111fcc058ce@Steven-Xus-Macbook-Pro.local.mail>

Unescaped: &

Escaped: &amp;

ERB: &amp;


----==_mimepart_4eb03f1b708ce_178858111fcc057a4
Date: Tue, 01 Nov 2011 14:48:59 -0400
Mime-Version: 1.0
Content-Type: text/html;
 charset=UTF-8
Content-Transfer-Encoding: 7bit
Content-ID: <4eb03f1b73784_178858111fcc05933@Steven-Xus-Macbook-Pro.local.mail>

<!doctype html>
<html>
  <head>
    <title>test</title>
  </head>
  <body>
    <ul>
      <li>Unescaped: &</li>
      <li>Escaped: &amp;</li>
      <li>ERB: &amp;</li>
    </ul>
  </body>
</html>


----==_mimepart_4eb03f1b708ce_178858111fcc057a4--

Теперь это текстовое представление (app/views/application_mailer/index.text.erb):

$ cat app/views/application_mailer/index.text.erb 
Unescaped: &

Escaped: &amp;

ERB: <%= "&" %>

Как видите, полученное текстовое электронное письмо переоценивается.

Есть ли способ предотвратить это?


Дополнительные уточнения:

Если вы нажмете на электронную почту HTML и просто отправите текст, вы получите это в почтовом клиенте (я использую Gmail):

email body

Как видите, третья строка переэкспонирована.

Очевидно, что вы можете вызывать html_safe для каждой строки или raw для каждого тега ERB, но, безусловно, должен быть способ заставить Rails / Erubis распознать тот факт, что он находится в текстовом электронном письме, и соответственно экранировать .

1 Ответ

5 голосов
/ 04 ноября 2011

В маяке рельсов есть нить , обсуждающая проблему, и патч обезьяны , который тоже пытается ее исправить.Попробуйте добавить это в инициализаторы и попробовать.

# fix_erubis_non_escape_sequence.rb
module ActiveSupport
  class SafeBuffer < String
    alias safe_append= safe_concat
  end
end

module ActionView
  class Template
    module Handlers
      class Erubis < ::Erubis::Eruby
        def add_expr_escaped(src, code)
          if code =~ BLOCK_EXPR
            src << "@output_buffer.safe_append= " << code
          else
            src << "@output_buffer.safe_concat((" << code << ").to_s);"
          end
        end
      end
    end
  end
end
...