首页 > 编程语言 >01_nodejs_phantomjs_nodemailer

01_nodejs_phantomjs_nodemailer

时间:2024-10-08 20:34:50浏览次数:7  
标签:function 截图 01 phantomjs nodemailer js var com

代码块

nodejs-phantomjs-nodemailer

功能

每天定时截图,并把截到的图片自动通过邮件发送。

说明

代码注释已经非常详细,就不多做说明,需要的朋友自己查看代码即可,主文件Mail.js,截图文件capturePart1.js,capturePart2.js,capturePart3.js,这里只展示了capturePart1.js其他两个类似。值得注意的是有登录权限的网站一定要设置Cookie,需要截取高质量图片的话截取时间一定设置长一些。

Mail.js

    *                                     定时发送邮件功能说明:
    *       node.js必备安装模块:node_modules-->phantomjs,nodemailer,node-schedule,moment
    *       涉及JS文件:route-->mail.js,public-->js-->capturePart1.js,capturePart2.js,capturePart3.js
    *       截图保存地址:public-->images-->mainPage.jpeg(1600*4200)
    *       截图url:http://www.***********.com
    *       程序主要思路:
    *           (1)phantomjs截图-->参照http://phantomjs.org/
    *           (2)nodemailer发送邮件-->参照https://www.npmjs.com/package/nodemailer
    *           (3)node-schedule定时-->参照https://www.npmjs.com/package/node-schedule
    *       注意:
    *           改变发件服务器请修改SMTP
    *           改变收件人请修改变量receiver
    *           改变邮件内容请修改变量html
    *           改变邮件附加图片和附件请修改attachments
    *           改变截图功能请修改public-->js-->server.js
    *           改变定时功能请修改变量rule
    *                                                           ------Sweety
//组件引入开始
var schedule = require("node-schedule");
var path = require('path');
var childProcess = require('child_process');
var phantomjs = require('phantomjs');
var nodemailer = require("nodemailer");
var moment = require("moment");
//组件引入结束
/*--------------------------------------------------------------------------------------------------------------------------------------------*/
//变量定义开始
var today;              //今天开始时间
var binPath = phantomjs.path;      //获取phantomjs.exe路径
var jsPath = process.cwd()+"/public/js/";   //获取server.js所在目录
var childArgs;
//capturePart3();
//capturePart1();
//变量定义结束
/*--------------------------------------------------------------------------------------------------------------------------------------------*/
//主程序开始
var rule = new schedule.RecurrenceRule();         //schedule定时器
rule.hour = 11;
rule.minute = 0;
rule.second = 0;              //定时器规则设定(每天11点触发事件)
var j = schedule.scheduleJob(rule, function(){
    var now = moment();
    today = now.clone().add(-1, 'days').format('YYYY-MM-DD');
    capturePart1();  //触发截图事件(邮件发送功能包含在截图事件里边)
});
//主程序结束
/*---------------------------------------------------------------------------------------------------------------------------------------------*/
//phantomjs截图开始(第一张)
function capturePart1(){
    childArgs = [
        path.join(jsPath, 'serverPart1.js'),          //server.js
        ' https://www.hao123.com '   //要截图的url
    ];
    childProcess.execFile(binPath, childArgs, function(err, stdout, stderr) {
        if(err)
        {
            console.log(err);                //打印错误信息
        }else{
            console.log("Captured Part1 Successful !!"); //打印正确信息
            capturePart2();
        }
    });
}
//phantomjs截图结束(第一张)
//phantomjs截图开始(第二张)
function capturePart2(){
    childArgs = [
        path.join(jsPath, 'serverPart2.js'),        //server.js路径
        'https://www.hao123.com '   //要截图的url
    ];
    childProcess.execFile(binPath, childArgs, function(err, stdout, stderr) {
        if(err)
        {
            console.log(err);                 //打印错误信息
        }else{
            console.log("Captured Part2 Successful !!"); //打印正确信息
            capturePart3();
        }
    });
}
//phantomjs截图结束(第二张)
//phantomjs截图开始(第三张)
function capturePart3(){
    childArgs = [
        path.join(jsPath, 'serverPart3.js'),                     //server.js路径
        ' https://www.hao123.com '   //要截图的url
    ];
    childProcess.execFile(binPath, childArgs, function(err, stdout, stderr) {
        if(err)
        {
            console.log(err);           //打印错误信息
        }else{
            console.log("Captured Part3 Successful !!"); //打印正确信息
            sent();                // 触发发送邮件事件
        }
    });
}
//phantomjs截图结束(第三张)
/*-------------------------------------------------------------------------------------------------------------------------------------------------*/
//nodemailer发送邮件开始
function sent(){
    var imgPart1 = fs.readFileSync(process.cwd()+"/public/images/mainPagePart1.jpeg"); //图片来源
    var imgPart2 = fs.readFileSync(process.cwd()+"/public/images/mainPagePart2.jpeg"); //图片来源
    var imgPart3 = fs.readFileSync(process.cwd()+"/public/images/mainPagePart3.jpeg"); //图片来源
    var smtpTransport = nodemailer.createTransport("SMTP",{                  //邮件SMTP设定(发送邮箱服务器必须开启SMTP)
        host: "smtp.xxxxx.com",                      // 主机
        secureConnection: false,                        // 不使用 SSL
        port: 587,                                      // SMTP 端口
        auth: {
            user: "[email protected]",            //用户名
            pass: "xxxxxx"                          //密码
        }
    });
    var html =  '<meta http-equiv="Content-Type" content="text/html; charset=utf-8">' +
                'XX好:</br>'+
                '&nbsp;&nbsp;下面为【XXXX】日报汇报('+today+')的内容,请参考</br>' +
                '&nbsp;&nbsp;(日报详细信息请点击<a href="#" onclick="changeData();">此处登陆</a>查看)'+
                '</br>' +
                '<img src="cid:img1" id="img1">'+
                '<img src="cid:img2" id="img2">'+
                '<img src="cid:img3" id="img3">';//邮件内容(html代码),img唯一指定地址对应cid(见mailOptions设定)
    var receiver = "[email protected]";//收件人列表
    var cc = "[email protected],[email protected],[email protected]";    //抄送人列表
    var bcc = "[email protected],[email protected]"; //密抄送人列表
    var mailOptions = {                   //邮件内容选项设定
        from: "<[email protected]>",           //发件地址
        //to: "[email protected]",
        to: receiver,                     //收件人
        cc:cc,                           //抄送人
        bcc:bcc,                         //密抄送人
        subject:"【XXXX】日报汇报("+today+")", //邮件主题
        text: "【XXXX】日报汇报("+today+")",  // plaintext body
        html:html,                         //html内容
        attachments: [
            {
            filename: 'mainPagePart1.jpeg',     //图片名称
            contents: imgPart1,              //图片来源
            cid: 'img1'                      //插入图片标识
            },{
                filename: 'mainPagePart2.jpeg',    //图片名称
                contents: imgPart2,                   //图片来源
                cid: 'img2'                       //插入图片标识
            },{
                filename: 'mainPagePart3.jpeg',      //图片名称
                contents: imgPart3,                  //图片来源
                cid: 'img3'                //插入图片标识
            }
        ]
    };
    smtpTransport.sendMail(mailOptions, function(error, response){//发送邮件
        if(error){
            console.log(error);        //打印错误信息
        }else{
            console.log("Sent Successful !!");   //打印正确信息
        }
    });
}
//nodemailer发送邮件结束
function changeData(){
}
/*---------------------------------------------------------------------------------------------------------------------------------------------*/

capturePart1.js

//phantomjs截图
var page = require('webpage').create(),
    system = require('system'),
    address;
page.viewportSize = { width:1920, height: 1080};
page.clipRect = { top: 200, left: 210, width: 1680, height: 1530 };
page.customHeaders={"Cookie":"koa:sess=e*******=;koa:sess.sig=pjadZtLAVtiO6-Haw1vnZZWrRm8"};
if (system.args.length === 1) {
    phantom.exit(1);
} else {
    address = system.args[1];
    page.open(address, function (status) {
    });
}
setTimeout(function() {
    console.log("");
    console.log("### STEP 5: Close page and shutdown (with a delay)");
    page.render('./public/images/mainPagePart1.jpeg', {format: 'jpeg', quality: '100'});
    page.close();
    setTimeout(function(){
        phantom.exit();
    }, 3000);
}, 19000);

标签:function,截图,01,phantomjs,nodemailer,js,var,com
From: https://www.cnblogs.com/honghaitao/p/18452485

相关文章

  • 2018_11_02_05
    JavaScript事件流定义申明:本文仅限私人学习之用----原文;下图展示了完整的js事件流捕获阶段:Document>ElementHtml>ElementBody==>ElementDiv冒泡阶段:ElementDiv>ElementBody>ElementHtml==>Document分析捕获阶段:document对象首先接收到click事件,然后事件沿DO......
  • 2019_07_16_01
    this、apply、call、bindthisthis永远指向最后调用它的那个对象apply、call的区别对于apply、call二者而言,作用完全一样,只是接受参数的方式不太一样。例如,有一个函数定义如下:varfunc=function(arg1,arg2){};就可以通过如下方式来调用:使用场景参数明确使用call......
  • 2018_11_02_04
    instanceof运算符原文语法objectinstanceofconstructor参数object要检测的对象.constructor某个构造函数描述instanceof运算符用来检测constructor.prototype是否存在于参数object的原型链上。//定义构造函数functionC(){}functionD(){}varo=......
  • 2020_01_28
    mac休眠之后wifi无法连接解决方案:删除与网络配置有关的plist文件第一步进入网络配置目录打开终端,输入cd/Library/Preferences/SystemConfiguration/备份原来的配置文件sudozipbackup.zip\com.apple.airport.preferences.plist\com.apple.......
  • 2018_10_21_03
    box-flex使用说明1.box-flex属性box-flex主要让子容器针对父容器的宽度按一定规则进行划分<acticle><section>01</section><section>02</section><section>03</section></acticle>acticle{display:box;display:-moz-box;display......
  • 2018_10_21_02
    border-style属性定义及使用说明border-style属性设置一个元素的四个边框的样式。此属性可以有一到四个值。border-style:dottedsoliddoubledashed;值描述dotted上边框是点状solid右边框是实线double下边框是双线dashed左边框是虚线border-style......
  • 2018_10_21_01
    1px边框问题7种方法解决移动端Retina屏幕1px边框问题在retina屏中实现1pxborder效果下文出自7种方法解决移动端Retina屏幕1px边框问题造成边框变粗的原因其实这个原因很简单,因为css中的1px并不等于移动设备的1px,这些由于不同的手机有不同的像素密度。在......
  • 2018_11_02_02
    原理数据类型window.onload=()=>{vartest1='abcdef';vartest2=123;vartest3=true;vartest4={};vartest5=[];vartest6;vartest7={abcdef:123};vartest8=['abcdef',123];functiontest9(){r......
  • 2018_11_02_03
    匿名函数和闭包在计算机科学中,闭包是函数的非局部变量(自由变量)的引用环境。包含自由变量的函数与为所有这些自由变量提供了变量绑定的环境一起,被称为闭包。以下内容为学习笔记,来自李炎恢老师的课堂纪要。1.匿名函数普通函数functionbox(){//函数名是boxreturn'Lee......
  • 2018_11_02_01
    战舰游戏展示基于vue开发,具体代码请看vue写法<js-2018_11_02_01-index/>原生js代码<divclass="continuar"><tablecellpadding="0"cellspacing="0"id='tab'>tr*7>td*7</table><divclass="e......