2024-01-09 如何迁移 Newsletter 到 phplist

参考链接:

phplist:https://github.com/phpList/phplist3

前言

最近突然收到 Tinyletter 发的邮件,说是 Tinyletter 将在 2024 年 2 月 29 日后关闭,这可让我虎躯一震,毕竟前不久(去年)才刚写过一篇博客来推荐 Tinyletter 呢!(详见:2023-09-24 如何通过 Tinyletter 订阅 RSS

于是就问了下万能的 ChatGPT,有没有开源的邮件订阅系统(Newsletter),毕竟我可不想第二次迁移了。

ChatGPT 也是不负众望,给我推荐了几个开源的邮件订阅系统。

经过一番调研,感觉phplist还是蛮不错的,既有开源版本,也可以直接使用他们部署的版本,故特此记录。

img

正文

注册

废话不多说,先注册个账号再说,前往官网注册即可。

第一步是叫你取个名字,这个名字会用来当子域名,随便取即可,自己记得住就行了。

image-20240109221444475

第二步就是填邮箱和密码了,和 Tinyletter 一样,还是推荐用国外的邮箱,比如谷歌邮箱。但国内的邮箱应该也是可以用的,只要不被误认为垃圾邮件就好了。

image-20240109221620758

第三步这里就不截图了,主要是补充信息,可以不填。

完成之后就可以点击确定了,之后在邮箱里点下确认邮件,然后再等待一小会儿,就可以进入你的主页了。

主页

image-20240109221838946

【PS:这里如果你仔细观察的话,就可以注意到当前域名是之前取的名称+hosted.phplist.com,例如xxxx.hosted.phplist.com

主页默认进来是全英文的,虽然有中文选项,但翻译烂的一批,还不如英文版看的舒服。

如果真的像我一样是个英语苦手的话,可以借助翻译工具使用,反正只需要知道各个页面是干什么用的就行了。

到了这里,各位读者最关心的就是 phplist 要怎么实现订阅页面(就像下面的 Tinyletter 这样),下面就来说明这个问题

image-20230924212351552

订阅页面

phplist 有关的内容位于 My account下面的AJAX Integration,参考上面的内容即可做出差不多的效果。

image-20240109222913785

第一步是创建一个订阅页面,在subscribe 页面操作即可。

然后就是记下 id,我这里是 1。

image-20240109224014638
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.5.2/jquery.min.js"></script>
<script type="text/javascript" src="https://s3.amazonaws.com/phplist/phplist-subscribe-0.2.min.js"></script>

<div id="phplistsubscriberesult"></div>
<form action="https://caomeiyouren.hosted.phplist.com/lists/?p=subscribe&id=1" method="post" id="phplistsubscribeform">
<input type="text" name="email" value="" id="emailaddress" />
<button type="submit" id="phplistsubscribe">Subscribe to our newsletters</button>
</form>

image-20240109223702945

然后就可以看到订阅按钮了。

怎么说呢,没加样式的情况下确实简单的有些过分了。

话说如此,你就说不能不用吧!

image-20240109223218737

点开之后就可以开看到订阅页面,呃,怎么说呢,虽然相较于 Tinyletter 确实丑了点,但也不是不能用,现阶段还是能用就行了,美化的事之后再考虑。

到此为止,就已经初步实现了邮件订阅功能,如果只是能用就行的话,可以到此结束了

美化

不过,作为一个多年老前端,对于如此丑陋的前端页面是无法容忍的,所以需要狠狠的美化一下!把以前的代码拿过来抄一下!

美化的部分主要是两个,一个是邮件订阅按钮,毕竟长得那么丑,读者看了就不想订阅了;另一个是邮件订阅页面,长得太丑也很劝退读者!

美化订阅按钮

<!DOCTYPE html>
<html lang="zh-CN">

<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>Document</title>
    <script type="text/javascript" src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.min.js"></script>
    <script type="text/javascript" src="https://s3.amazonaws.com/phplist/phplist-subscribe-0.2.min.js"></script>
    <style>
        /*
邮件订阅样式
*/
        .sub_box {
            display: block;
            box-sizing: border-box;
        }

        #sub-form,
        #phplistsubscribeform {
            border: 0;
            padding: 3px;
            text-align: center;
            display: flex;
            justify-content: center;
        }

        p#subscribe-email,
        p#subscribe-submit {
            margin: 0;
            box-sizing: inherit;
            display: block;
        }

        p#subscribe-email {
            flex-grow: 1;
            max-width: 400px;
        }

        .sub-input {
            font-size: 16px;
            padding: 15px 23px 15px 23px;
            margin: 0px;
            border-radius: 0px;
            border-width: 1px;
            line-height: 1.3;
            box-shadow: none;
        }

        .input-email {
            margin: 0;
            width: 100%;
            color: #666;
            border: 1px solid #ccc;
            max-width: 100%;
        }

        .input-submit {
            margin: 0px;
            margin-left: 10px;
            border-color: transparent;
            border-style: solid;
            background-color: #222;
            color: #fff;
            box-sizing: border-box;
            min-width: auto !important;

        }
    </style>

</head>

<body>

    <div class="pagination">
        <div class="pagination__title">
            <span class="pagination__title-h">📮邮件订阅</span>
            <hr />
        </div>
        <p style="text-align: center;">想我每次发布新东西时都收到电子邮件吗?</p>
        <div class="sub_box">
            <div id="phplistsubscriberesult"></div>
            <!-- 修改此处的 action -->
            <form id="phplistsubscribeform" action="https://caomeiyouren.hosted.phplist.com/lists?p=subscribe&id=1"
                  
                method="post">
                <p id="subscribe-email">
                    <input type="email" name="email" value="" id="emailaddress" placeholder="输入你的邮箱地址..." required
                        class="sub-input input-email" />
                </p>
                <p id="subscribe-submit"> <button type="submit" id="phplistsubscribe"
                        class="sub-input input-submit">订阅</button></p>
            </form>
        </div>
    </div>

</body>

</html>

image-20240109234105414

样式上还是采用了原来的方案,如果要自己用的话请修改 action 字段中的链接!

可以前往本文底部查看效果。

美化邮件订阅页面

该部分暂时还未美化,但填充了一点内容。

image-20240109235423043

总结

本文介绍了如何迁移邮件订阅系统(Newsletter)到 phplist。博客首先提到了 Tinyletter 将在 2024 年 2 月 29 日关闭的消息,引发了作者的关注。作者经过调研后选择了 phplist 作为替代方案,并详细介绍了 phplist 的注册流程和主页界面。博客还提供了如何创建订阅页面的步骤,并附上了相应的代码。最后,博客指出虽然 phplist 的界面相对较简单,但可以通过美化订阅按钮和邮件订阅页面来改善用户体验。整体而言,该博客提供了一个详细的指南,帮助读者了解如何迁移 Newsletter 到 phplist,并提供了一些美化的建议。

【由 Chat LangChain 生成】

本文作者:草梅友仁
本文地址:https://blog.cmyr.ltd/archives/92ad8b7d.html
版权声明:转载请注明出处!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,332评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,508评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,812评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,607评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,728评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,919评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,071评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,802评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,256评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,576评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,712评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,389评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,032评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,026评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,473评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,606评论 2 350

推荐阅读更多精彩内容