惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Cloudbric
Cloudbric
E
Exploit-DB.com RSS Feed
SecWiki News
SecWiki News
Forbes - Security
Forbes - Security
N
News | PayPal Newsroom
S
Security @ Cisco Blogs
Schneier on Security
Schneier on Security
V
V2EX - 技术
S
Secure Thoughts
W
WeLiveSecurity
Google DeepMind News
Google DeepMind News
C
CERT Recently Published Vulnerability Notes
NISL@THU
NISL@THU
S
Securelist
S
Security Archives - TechRepublic
Know Your Adversary
Know Your Adversary
V
Vulnerabilities – Threatpost
Security Latest
Security Latest
Recent Commits to openclaw:main
Recent Commits to openclaw:main
G
GRAHAM CLULEY
H
Hacker News: Front Page
Microsoft Azure Blog
Microsoft Azure Blog
I
Intezer
Google Online Security Blog
Google Online Security Blog
美团技术团队
阮一峰的网络日志
阮一峰的网络日志
T
The Exploit Database - CXSecurity.com
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
Webroot Blog
Webroot Blog
Jina AI
Jina AI
Engineering at Meta
Engineering at Meta
P
Proofpoint News Feed
The Cloudflare Blog
I
InfoQ
L
LangChain Blog
U
Unit 42
P
Proofpoint News Feed
S
Schneier on Security
S
Security Affairs
Y
Y Combinator Blog
T
Tenable Blog
N
News and Events Feed by Topic
MyScale Blog
MyScale Blog
量子位
Google DeepMind News
Google DeepMind News
Cyberwarzone
Cyberwarzone
博客园 - 聂微东
D
Darknet – Hacking Tools, Hacker News & Cyber Security
GbyAI
GbyAI
AWS News Blog
AWS News Blog

WishMeLz - NodeJS

Electron 主进程起一个可用的 HTTPS 静态服务器 - WishMeLz 宝塔Node管理器安装node版本提示:文件下载失败,请手动安装! - WishMeLz Minio 之 Nodejs - WishMeLz nuxt项目本地启动,多开标签一直显示加载中 - WishMeLz nvm win10安装 - WishMeLz nodejs 对接邮箱服务 imap - WishMeLz PM2搭配nvm使用不同版本Node启动项目 - WishMeLz EA Racenet API - WishMeLz SSE(Server-Sent Events) - WishMeLz
nodejs 生成网站sitemap.xml - WishMeLz
WishMeLz · 2026-06-01 · via WishMeLz - NodeJS
const mysql = require('mysql2')
const fs = require('fs')
const xml2js = require('xml2js')
const path = require('path') // 引入 path 模块以处理路径

// 配置数据库连接
const dbConfig = {
    host: 'localhost',
    port: '3306',
    user: '',
    password: '',
    database: '',
}

// 创建数据库连接
const pool = mysql.createPool(dbConfig)

// 查询数据库获取数据
function fetchDataFromDB() {
    return new Promise((resolve, reject) => {
        pool.query(
            'SELECT id, created_at, updated_at, title FROM simple_topic ORDER BY id DESC',
            (err, results) => {
                if (err) {
                    return reject(err)
                }
                resolve(results)
            },
        )
    })
}

// 生成sitemap.xml文件
async function generateSitemap(data) {
    const urlset = {
        urlset: {
            $: { xmlns: 'http://www.sitemaps.org/schemas/sitemap/0.9' },
            url: data.map((row) => ({
                loc: [`https://xxxx.com/t/${row.id}.html`],
                lastmod: [
                    new Date(row.updated_at * 1000).toLocaleDateString('en-CA'),
                ], 
                changefreq: ['monthly'],
                priority: ['0.5'],
            })),
        },
    }

    const builder = new xml2js.Builder()
    const xml = builder.buildObject(urlset)

    // 获取脚本文件所在目录的上一级目录
    const outputDir = path.join(__dirname, '..', 'sitemap.xml')

    // 将 XML 写入上一级目录
    fs.writeFileSync(outputDir, xml, 'utf-8')
    console.log('Sitemap generated successfully at:', outputDir)
}

async function start() {
    try {
        const data = await fetchDataFromDB()
        if (data.length) {
            await generateSitemap(data)
        } else {
            console.log('No data found to generate sitemap.')
        }
    } catch (error) {
        console.error('Error fetching data or generating sitemap:', error)
    }
}

start()

console.log(new Date().toLocaleDateString('en-CA'))

console.log('Sitemap generator running...')