问题出现的原因是 Heroku 每次部署会重新构建整个应用,因此上传的文件也会被重建。解决此问题的方法是将上传的文件存储到云服务中,例如 Amazon S3 或 Google Cloud Storage,并使用相关插件或模块来实现这种存储方式。
以下是使用 Amazon S3 存储上传文件的示例代码:
首先在 config/production.js 中添加以下配置:
module.exports = { // ... modules: { 'apostrophe-s3-upload': { accessKeyId: 'YOUR_ACCESS_KEY_ID', secretAccessKey: 'YOUR_SECRET_ACCESS_KEY', region: 'YOUR_S3_REGION', bucket: 'YOUR_S3_BUCKET' } } };
然后将相应的 npm 模块安装到项目中:
npm install --save aws-sdk apostrophe-s3-upload
最后,在您希望实现上传功能的页面或区域中使用以下模板代码:
{% extends "apostrophe/modules/apostrophe-files/views/upload.html" %}
{% block options %} {{ super() }}
{{ apos.s3Upload.options({ title: "Upload a file", bucket: "YOUR_S3_BUCKET", awsConfig: { accessKeyId: "YOUR_ACCESS_KEY_ID", secretAccessKey: "YOUR_SECRET_ACCESS_KEY", region: "YOUR_S3_REGION" } }) }} {% endblock %}
在这个例子中,我们使用了 apostrophe-s3-upload 模块,该模块允许我们使用 Amazon S3 存储上传的文件。此外,我们还传递了 AWS 认证信息和 S3 存储桶的名称。在界面上,我们使用了上传文件模板并调用了 apos.s3Upload.options 函数以配置 S3 存储选项。
这样,上传的文件将直接存储到 Amazon S3,不会受到 Heroku 应用重建的影