在哪里生成Firebase数据库PDF的数据 - 移动应用程序或Firebase托管Web应用程序

use*_*948 1 pdf android firebase firebase-hosting firebase-realtime-database

我有一个Android应用程序和一个Web应用程序(托管在Firebase Hosting上).Android应用会生成数据并将其保存到Firebase实时数据库.Android应用和网络应用都可以查看数据.

从Firebase数据库生成PDF数据的最佳位置在哪里 - Android应用程序或Web应用程序(通过JavaScript,例如jsPDF)?它将保存在Firebase存储中.

我认为Android应用程序可以调用后端生成PDF,并且PDF的链接将被发送回Android应用程序.但Firebase是一种无服务器架构,因此最好的解决方案是在Android应用上创建PDF,然后将其上传到Firebase存储......?

Dav*_*veM 11

由于存在Firebase功能(Firebase简介),您可以使用NodeJS创建PDfs,例如使用pdfkit(PDFKit).以下示例描述了一种在AccountCreation(Event)上生成PDF的方法,将其保存到存储中并通过邮件发送给用户.所有这些都发生在Firebase服务器上.对于所有使用过的Librarys,不要忘记npm安装它们并将它们包含在package.json中.一个棘手的部分是将Firebase Admin SDK添加到您的服务器.此外,也有很大帮助.说实话,这花了我几个小时.所以不要犹豫要求细节!

const functions = require('firebase-functions');
const admin = require("firebase-admin");

const nodemailer = require('nodemailer');
const pdfkit = require('pdfkit');

const gmailEmail = 'yourmail@stackoverflow.com'
const gmailPassword = 'test123.ThisisNoTSave'
const mailTransport = nodemailer.createTransport( `smtps://${gmailEmail}:${gmailPassword}@smtp.gmail.com`);

const serviceAccount = require("./youradminsdk.json");
//Save this file to your functions Project

// Your company name to include in the emails
const APP_NAME = 'My App';
const PROJECT_ID = "google-testproject";

admin.initializeApp({
    credential: admin.credential.cert(serviceAccount),
    databaseURL: `https://${PROJECT_ID}.firebaseio.com`,
    storageBucket: `${PROJECT_ID}.appspot.com`
});

var config = {
    projectId: `${PROJECT_ID}`,
    keyFilename: './youradminsdk.json'
};

const storage = require('@google-cloud/storage')( config);
const datastore= require('@google-cloud/datastore')(config);

// [START onCreateTrigger]
exports.sendPDFMail = functions.auth.user().onCreate(event => {
// [END onCreateTrigger]

       // [START eventAttributes]
       const doc = new pdfkit;
       const user = event.data; // The Firebase user.
       const email = user.email; // The email of the user.
       const displayName = user.displayName; // The display name of the user.
       // [END eventAttributes]

       const bucket = storage.bucket(`${PROJECT_ID}.appspot.com`); 
       console.log(bucket);
       const filename =  Date.now() + 'output.pdf';                       
       const file = bucket.file(filename);
       const stream = file.createWriteStream({resumable: false});

      // Pipe its output to the bucket
       doc.pipe(stream);              
       doc.fontSize(25).text('Some text with an embedded font!', 100, 100);           
       doc.end();        
       stream.on('finish', function () {                   
             return sendPDFMail(email, displayName, doc);
       });

       stream.on('error', function(err) {
            console.log(err);
       });        
      })
    ;
    // [END sendPDFMail]


    // Sends a welcome email to the given user.
    function sendPDFMail(email, displayName, doc) {
        const mailOptions = {
            from: '"MyCompany" <noreply@firebase.com>',
            to: email,        
        };

        mailOptions.subject = `Welcome to ${APP_NAME}!`;
        mailOptions.text = `Hey ${displayName}!, Welcome to ${APP_NAME}. I hope you will enjoy our service.`;
        mailOptions.attachments =  [{filename: 'meinPdf.pdf', content: doc, contentType: 'application/pdf'  }];        

        return mailTransport.sendMail(mailOptions).then(() => {
            console.log('New welcome email sent to:', email);
        });
    }
Run Code Online (Sandbox Code Playgroud)