簡體   English   中英

Django + Anymail + Mailgun-電子郵件HTML呈現沒有按鈕和圖像

[英]Django + Anymail + Mailgun - Email HTML renders without button and image

嘗試使用anymail庫通過mailgun發送包含html和圖像的電子郵件時遇到問題。

這是我的代碼:

url_formulario = CLIENT_URL + str(token.key)
email = EmailMultiAlternatives('Confirmación Vacante', to=emails)
cid = attach_inline_image_file(email, '/var/www/static/icons/ba_logo.png')
contexto = {'nombre_contacto': contacto.responsable_nombre, 
            'nombre_alumno': contacto.alumno_nombre, 
            'url_formulario': url_formulario,
            'imagen':cid}
mensaje = render_to_string('email.html', context=contexto)
email.attach_alternative(mensaje, "text/html")
email.track_clicks = True
email.send()

我也嘗試過這樣做:

url_formulario = CLIENT_URL + str(token.key)
contexto = {'nombre_contacto': contacto.responsable_nombre, 
            'nombre_alumno': contacto.alumno_nombre, 
            'url_formulario': url_formulario}
mensaje = render_to_string('email.html', context=contexto)
content = strip_tags(mensaje)
email = EmailMultiAlternatives('Confirmación Vacante', content,to=emails)
email.attach_alternative(mensaje, "text/html")
email.track_clicks = True
email.send()

這是我正在使用的html文件的兩個相應版本:

<html>
<head>
    <title>Ingresa al formulario</title>
        <!-- Required meta tags -->
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">

    <!-- Bootstrap CSS -->
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">

    <!-- Bastrap CSS -->
    <link rel="stylesheet" href="/static/css/bastrap.css">      
    <style>
            .contenedor-general{
                background:#e5e5e5;
                padding-top:3em;
            }
            .contenedor-general img{
                padding-bottom:3em;
            }
            .contenido-mensaje{
                background:white;
                margin-bottom:calc(43px + 6em);
            }
            .contenido-mensaje p{
                font-family:"CHANEWEI", Helvetica, Arial, sans-serif;
                margin:7%;
                color:#717170;
            }
            .contenido-mensaje h1,
            .contenido-mensaje a{
                margin: 0 7% 0 7%;
            }
            .contenido-mensaje h1{
                padding-top:7%;
                color:#717170;
            }
            .contenido-mensaje a{
                color:#333;
            }
            .btn-primary{
                background-color:#fcda59 !important;
                color:#685723 !important;
                box-shadow:none !important;
            }

            .btn-primary:hover{
                background-color:#fdd306 !important;
                border-color:#fdd306 !important;
                color:#685723 !important;
                box-shadow:none !important;
            }
    </style>
</head>
<body>
    <div class="container">
        <div class="contenedor-general col-lg-8 col-lg-offset-2">
            <img src="{{imagen}}" alt="Logo Buenos Aires" class="center-block"/>
            <div class="col-lg-8 col-lg-offset-2 contenido-mensaje">
                <h2>Hola {{nombre_contacto}},</h2>
                <p>Tenemos una vacante escolar pendiente para {{nombre_alumno}}</p>
                <a href='{{url_formulario}}' class="btn btn-lg btn-primary">Confirmar vacante</a>
                <p>Si tenés problemas para ingresar comunicate al XXXX-XXXX (Número de télefono)</p>
                <p>Muchas gracias</p>
            </div>
    </div>
    </body>
</html>

標簽的另一個版本,但未傳遞圖片:

<img src="" alt="Logo Buenos Aires" class="center-block"/>

這是生成的電子郵件:

在此處輸入圖片說明

在將HTML文件呈現為具有指定上下文和圖像的字符串后,是否可以附加html文件?

謝謝。

看來您的模板缺少cid: <img src> 你有:

<img src="{{imagen}}" alt="Logo Buenos Aires" class="center-block"/>

但這需要是:

<img src="cid:{{imagen}}" alt="Logo Buenos Aires" class="center-block"/>

cid:方案是電子郵件客戶端知道如何將{{imagen}}的值視為嵌入式Content-ID的方式。 沒有它,客戶端將不知道應該在哪里尋找該圖像源,因此,您會得到一個損壞的圖像圖標。

Anymail文檔中有更多詳細信息

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM