测试监听网页最新标题变化发邮件通知的小例子

最近媳妇让我盯着她关心的一个网页公告更新了没有,我就利用爬虫简单做了个监听标题发邮件的问题 

 

implementation 'org.jsoup:jsoup:1.13.1'
implementation group: 'com.sun.mail', name: 'javax.mail', version: '1.6.2'
package com.rex.tjavalibrary.jsoup

import org.jsoup.Jsoup
import java.util.*
import javax.mail.Message
import javax.mail.Session
import javax.mail.internet.InternetAddress
import javax.mail.internet.MimeMessage

// 个人笔记
object TestEmail {
    // #如何获取授权码 https://baijiahao.baidu.com/s?id=1552315463915496&wfr=spider&for=pc
    // 授权码
    const val key = "你的授权码"
    var lastTitle = ""

    @JvmStatic
    fun main(args: Array<String>) {
        // 以qq为例子去邮箱设置查看
        val properties = Properties()
        properties["mail.transport.protocol"] = "smtp"
        properties["mail.smtp.host"] = "smtp.qq.com"
        properties["mail.smtp.port"] = 465
        properties["mail.smtp.auth"] = "true"
        properties["mail.smtp.ssl.enable"] = "true"
        properties["mail.debug"] = "true"
        while (true) {
            try {
                getNews(properties)
                Thread.sleep(10 * 1000)
            } catch (e: InterruptedException) {
                e.printStackTrace()
            }
        }
    }

    val targetUrl = "http://www.10.gov.cn/list-638-1.html"
    private fun getNews(properties: Properties): Boolean {
        try {
            val url = targetUrl
            // 直接连接
            val connect = Jsoup.connect(url)
            val document = connect.get()
            document?.run {
                // 此处需要根据实际网页进行分析 网页打开开发者模式 如下图 我直接搜索标题汉字 发现标签名是 txtlisty和a,属性名字分别是title,href
                val item = document
                    .select(".txtlisty1")
                    .select("a")
                item?.run {
                    val title = attr("title")
                    val href = attr("href")
                    return if (lastTitle != title) {
                        println("发现了新内容")
                        println("标题 = [$title]")
                        println("详细链接 = [$href]")
                        sendEm(properties, url, title, href)
                        lastTitle = title
                        true
                    } else {
                        println("${Date()}  网站没有任何更新仍然是旧内容:$title  ")
                        false
                    }
                }

            }

            return false
        } catch (e: Exception) {
            e.printStackTrace()
        }
        return false
    }

    private fun sendEm(
        properties: Properties, url: String, title: String,
        href: String
    ) {
        // 得到回话对象
        val session = Session.getInstance(properties)
        // 获取邮件对象
        val message: Message = MimeMessage(session)
        // 设置发件人邮箱地址 需要至少两个qq号
        val from = "你的发送邮件"
        val to1 = "你的接收邮箱1"
        val to2 = "你的接收邮箱2"
        message.setFrom(InternetAddress(from))
        // 设置收件人地址
        message.setRecipients(
            MimeMessage.RecipientType.TO, arrayOf(
                InternetAddress(to1), InternetAddress(to2)
            )
        )
        // 设置邮件标题
        message.subject = "提示"
        // 设置邮件内容
        var context = "检测到监听网站已经更新内容了,快去查看吧:${url} $lastTitle \n $href"
        if (lastTitle.isEmpty()) {
            context =
                "首次测试 开启监听 $targetUrl 更新内容后你将会收到 提醒${Date()} " +
                        "\n 当前最后一条内容是:$title"
        }
        message.setText(context)
        // 得到邮差对象
        val transport = session.transport
        // 连接自己的邮箱账户
        // 密码为刚才得到的授权码
        transport.connect(from, key)
        // 发送邮件
        transport.sendMessage(message, message.allRecipients)
    }
}

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
网页开发中,经常需要监听 DOM 元素的大小变化,以便进行动态布局或其他操作。而 JavaScript 提供了一种方便的方法来实现 DOM 元素大小变化监听。 首先,要监听 DOM 元素的大小变化,需要知道 DOM 元素的尺寸。获取 DOM 元素的尺寸可以通过其属性和方法来实现。比如,可以通过元素的 clientWidth 和 clientHeight 属性获取其内容区域的宽度和高度。 然后,要监听 DOM 元素大小的变化,可以使用 MutationObserver API。MutationObserver API 是浏览器提供的一种用于监听 DOM 变化的 API,它可以监听 DOM 元素的属性、子节点等变化,并在这些变化发生时触发回调函数。 使用 MutationObserver API 监听 DOM 元素大小变化的步骤如下: 1. 创建一个 MutationObserver 对象。 2. 使用 MutationObserver.observe 方法监听目标 DOM 元素的变化。 3. 在回调函数中判断 DOM 元素的尺寸是否发生了变化。 4. 如果尺寸发生变化,则进行相应的操作。 例如,以下代码可以实现监听某个元素宽度变化并输出宽度变化的值: ``` const target = document.querySelector('#target'); const observer = new MutationObserver((mutations) => { mutations.forEach((mutation) => { if (mutation.type === 'attributes' && mutation.attributeName === 'style') { const width = target.clientWidth; console.log(`Width changed to ${width}`); } }); }); observer.observe(target, { attributes: true }); ``` 最后,需要注意的是,使用 MutationObserver 监听 DOM 元素大小的变化虽然方便,但也存在一些限制,例如对于表格的大小变化无法捕获等,需要根据实际情况选择合适的方法来实现 DOM 元素大小的监听
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值