我在Action Mailer中有一个非常罕见的行为,我已经实施了一个像5个月前一样的邮件行动并且它正在运行,但是昨天,由于一些奇怪的原因,它崩溃了。
我有一个邮件布局,为了在我的所有电子邮件中使用它,我在其中渲染之前由过滤器附加的图像
布局= app/views/layouts/email.html.erb
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Visionamos</title>
<link rel="stylesheet" type="text/css" href=<%="/assets/email.css" %>>
</head>
<body>
<table>
<tr>
<td id="head">
<table>
<tr class="image">
<td><%= image_tag(attachments['visionamos.png'].url) %></td>
...
..
.
用户邮件程序= app/mailers/users.rb
class UsuariosMailer < ActionMailer::Base
include AbstractController::Callbacks # include controller callbacks
default :from => "monitoreo@visionamos.com"
layout "mail" #Set email layout
before_filter :add_inline_attachments! # Add image header for all actions
def otp_password(user, otp_key)
@usuario = user
@code = otp_key
email_with_name = "#{@usuario.nombre} <#{@usuario.email}>"
mail(:to => email_with_name, :subject => "One time password, Plataforma Visionamos")
end
private
def add_inline_attachments!
attachments.inline['visionamos.png'] = File.read("#{Rails.root}/app/assets/images/visionamos.png")
end
end
现在,当我尝试发送电子邮件时,我收到此错误
NoMethodError - undefined method `match' for nil:NilClass:
mail (2.5.4) lib/mail/utilities.rb:112:in `unbracket'
mail (2.5.4) lib/mail/part.rb:29:in `cid'
mail (2.5.4) lib/mail/part.rb:33:in `url'
app/views/layouts/mail.html.erb:13:in `_app_views_layouts_mail_html_erb__573848672563180413_70191451095440'
<td><%= image_tag(attachments['visionamos.png'].url) %></td>
但图片已附在电子邮件
上>> attachments['visionamos.png']
=> #<Mail::Part:70191451538040, Multipart: false, Headers: <Content-Type: image/png; filename="visionamos.png">, <Content-Transfer-Encoding: binary>, <Content-Disposition: inline; filename="visionamos.png">, <content-id: >>
Mac with Maverics Ruby 2.0 + Rails 3.2.16
我已经尝试过@Gene解决方案,但即使发送了电子邮件,图像也是正常的附件,没有内联,所以看起来很深,我发现了这个
>> attachments.inline['visionamos.png'].header
=> #<Mail::Header:0x00000106cf6870 @errors=[], @charset=nil, @raw_source="", @fields=[#<Mail::Field:0x00000106cf60c8 @field=#<Mail::ContentTypeField:0x00000106cf5fd8 @charset=nil, @main_type="image", @sub_type="png", @parameters={"filename"=>"visionamos.png"}, @name="Content-Type", @length=nil, @tree=nil, @element=#<Mail::ContentTypeElement:0x00000106cf5d30 @main_type="image", @sub_type="png", @parameters=[{"filename"=>"visionamos.png"}]>, @value="image/png; filename=\"visionamos.png\"", @filename="visionamos.png">, @field_order_id=23>, #<Mail::Field:0x00000106d17390 @field=#<Mail::ContentTransferEncodingField:0x00000106d172a0 @charset=nil, @name="Content-Transfer-Encoding", @length=nil, @tree=nil, @element=#<Mail::ContentTransferEncodingElement:0x00000106d16ff8 @encoding="binary">, @value="binary">, @field_order_id=24>, #<Mail::Field:0x00000106d14a78 @field=#<Mail::ContentDispositionField:0x00000106d14960 @charset=nil, @name="Content-Disposition", @length=nil, @tree=nil, @element=#<Mail::ContentDispositionElement:0x00000106d145c8 @disposition_type="inline", @parameters=[{"filename"=>"visionamos.png"}]>, @value="inline; filename=\"visionamos.png\"", @parameters={"filename"=>"visionamos.png"}, @filename="visionamos.png">, @field_order_id=26>, #<Mail::Field:0x00000106d3e8f0 @field=#<Mail::UnstructuredField:0x00000106d5ef60 @errors=[["content-id", nil, #<Mail::Field::ParseError: Mail::MessageIdsElement can not parse |<52fe636fae8a6_686085098c087130@MacBook Pro de Ruben.mail>|
原因是:预期的一个!,#,$,%,&amp;,',*,+, - ,/,=,?,^,_,`,{,|,},〜,@, &lt; 52fe636fae8a6_686085098c087130 @ MacBook&gt;]],@ charset =#,@ name =“content-id”,@ length = nil,@ tree = nil,第1行第40列(字节40) @ element = nil,@ value =“”&gt;,@ field_order_id = 100&gt;]&gt;
有趣的部分是
#<Mail::Field::ParseError: Mail::MessageIdsElement can not parse |<52fe636fae8a6_686085098c087130@MacBook Pro de Ruben.mail>|
Reason was: Expected one of !, #, $, %, &, ', *, +, -, /, =, ?, ^, _, `, {, |, }, ~, @, ., ", > at line 1, column 40 (byte 40) after <52fe636fae8a6_686085098c087130@MacBook>]],
答案 0 :(得分:3)
我查看了mail
来源。
只有在内容ID字段为nil时才会出现此错误。但是,调用.url
应该将内容id设置为空字符串,除非has_content_id?
返回true,这意味着multipart标头中已经有一个内容id字段。
这种情况不会发生,所以我们必须遇到一个奇怪的情况,即标头对象报告has_content_id?
为真但返回content_id
nil
。
尝试在设置图形后明确设置内容ID字段。
attachments['visionamos.png'].header['content-id'] = 'logo.graphic'
如果这样可行,那么仍然存在为什么必要的难题。您是否对邮件程序配置或代码进行了任何其他更改?你升级了任何宝石吗?
添加回复问题编辑
标头解析器似乎失败了,因为标识...@MacBook Pro de Ruben.mail
中有空格。尝试重新命名计算机,没有空格!我想这构成mail
中的错误。空间应该被省略或替换为合法的特征。
我的猜测是,这也将解决原始问题,您不需要再手动设置content-id
。因此,另一个猜测:您更改了计算机名称或将开发移至新计算机。那就是虫子出现的时候!
答案 1 :(得分:1)
sudo scutil --set HostName 'mymachine'
为我解决了这个问题。
scutil --get HostName
正在返回(未设置)