/** * SEO模板生成器 * 根据 useSEO.js 的页面配置自动生成静态 HTML 模板,供爬虫访问时返回 * 配置与 src/composables/useSEO.js 保持一致 * * 多站点:通过环境变量 SEO_BASE_URL 指定 canonical/og:url 域名后生成 * 例:SEO_BASE_URL=https://www.tianyuandb.com node generate-seo-templates.cjs */ const fs = require('fs') const path = require('path') const BASE_URL = process.env.SEO_BASE_URL || 'https://www.tianyuancha.cn' // 页面 SEO 配置(与 src/composables/useSEO.js 的 routeConfigs 保持一致) const pageSEOConfigs = { 'index.html': { title: '天远查官网_企业与婚姻关联风险核验_综合履约背景核验', description: '天远查官网(TianYuanCha)聚合官方公示数据,专注于商业安全与资产背调。提供企业工商画像、婚姻状态关联风险、司法涉诉筛查及配偶债务核验。数据实时同步,助您精准规避投资、交易及家庭结合中的经济与法律风险。', keywords: '天远查,婚姻状态风险, 配偶背景核验,企业信用查询,司法诉讼记录,资产风险评估', url: BASE_URL }, 'inquire-category-lawsuit.html': { title: '司法涉诉核验_个人及企业法律诉讼记录_履约风险评估_天远查', description: '天远查司法风险检测中心,聚合全国法院公开公示数据。一键筛查开庭公告、裁判文书、立案信息及执行记录。帮助用户快速识别法律纠纷隐患,全方位扫除合作盲区。', keywords: '司法案件核验,法律诉讼记录,个人涉诉详情,法院公告查询,案件执行状态', url: `${BASE_URL}/inquire/category/lawsuit` }, 'inquire-marriage.html': { title: '婚前背景核验_婚姻关联司法风险筛查_情感综合保障_天远查', description: '天远查婚恋风险报告为您提供深度的背景核实服务。基于合法公开数据,排查对象的重婚司法记录、家庭暴力涉诉历史、潜在债务风险及不良嗜好风险。拒绝盲目信任,用数据守护您的情感与财产安全。', keywords: '婚前背景核实,婚恋对象评估,婚姻司法风险,个人情感风险,婚前背调工具', url: `${BASE_URL}/inquire/marriage` }, 'inquire-category-vehicle.html': { title: '车辆档案报告_二手车车况与产权风险检测_机动车报告_天远查', description: '天远查车辆数据中心,让车辆交易更透明。支持通过车牌号或VIN码,核验车辆的初次登记信息、抵押查封状态、事故维修记录及产权属性。数据同步权威行业系统,精准识别问题车。', keywords: '车辆维修记录,二手车出险报告,车辆抵押报告,车况报告,机动车档案', url: `${BASE_URL}/inquire/category/vehicle` }, 'inquire-category-marriageStatus.html': { title: '个人婚姻关联风险核验_家庭背景合规报告_天远查', description: '天远查提供基于大数据的婚姻关联风险评估。通过分析司法文书及公开社会关系,辅助判断目标的真实家庭状况与情感履历。合法合规,保障知情权。', keywords: '婚史风险排查,家庭背景核实,婚姻诚信评估,情感状态评估,涉婚法律记录', url: `${BASE_URL}/inquire/category/marriageStatus` }, 'agent.html': { title: '天远查代理 - 免费开通代理权限 | 大数据风险报告代理', description: '天远查代理平台,免费开通代理权限,享受大数据风险报告查询服务代理收益。专业的大数据风险报告、婚姻查询、个人信用评估等服务的代理合作。', keywords: '天远查代理, 免费代理, 大数据风险报告代理, 代理权限, 代理收益', url: `${BASE_URL}/agent` }, 'help.html': { title: '帮助中心 - 天远查使用指南 | 常见问题解答', description: '天远查帮助中心,提供详细的使用指南、常见问题解答、操作教程等,帮助用户更好地使用大数据风险报告查询服务。', keywords: '天远查帮助, 使用指南, 常见问题, 操作教程, 客服支持', url: `${BASE_URL}/help` }, 'help-guide.html': { title: '使用指南 - 天远查操作教程 | 功能说明', description: '天远查详细使用指南,包含各功能模块的操作教程、功能说明、注意事项等,让用户快速上手使用。', keywords: '使用指南, 操作教程, 功能说明, 快速上手, 天远查教程', url: `${BASE_URL}/help/guide` }, 'example.html': { title: '示例报告 - 天远查报告展示 | 大数据风险报告样例', description: '天远查示例报告展示,包含大数据风险报告、婚姻状况查询、个人信用评估等服务的报告样例,让用户了解报告内容和格式。', keywords: '示例报告, 报告展示, 报告样例, 大数据风险报告, 婚姻查询报告', url: `${BASE_URL}/example` }, 'service.html': { title: '客服中心 - 天远查在线客服 | 技术支持', description: '天远查客服中心,提供在线客服支持、技术咨询、问题反馈等服务,确保用户获得及时有效的帮助。', keywords: '客服中心, 在线客服, 技术支持, 问题反馈, 天远查客服', url: `${BASE_URL}/service` }, 'inquire.html': { title: '核验工具多场景数据核验服务天远查', description: '提供车辆、企业、个人等多场景核验,包括状态、信用、身份等查询,权威高效,保护隐私。', keywords: '核验工具,数据核验服务,车辆核验,企业核验,天远查', url: `${BASE_URL}/inquire` } } /** * 规范化文案:统一为中文标点,避免乱码 */ function normalizeText(str) { if (typeof str !== 'string') return str return str .replace(/\uFFFD/g, '') .replace(/。/g, '。') .replace(/、/g, '、') } /** * 转义 HTML 属性值 */ function escapeAttr(str) { if (typeof str !== 'string') return '' return str .replace(/&/g, '&') .replace(/"/g, '"') .replace(//g, '>') } /** * 生成单页 HTML 模板 */ function generateHTMLTemplate(config) { const title = normalizeText(config.title) const description = normalizeText(config.description) const keywords = normalizeText(config.keywords) const structuredData = { '@context': 'https://schema.org', '@type': 'WebPage', name: title, description: description, url: config.url, mainEntity: { '@type': 'Organization', name: '天远查', url: 'https://www.tianyuancha.cn/', description: '专业大数据风险报告查询与代理平台,支持个人和企业多场景风控应用' } } return ` ${escapeAttr(title)}

${escapeAttr(title)}

正在跳转到完整版网站...

如果浏览器没有自动跳转,请 点击这里

${escapeAttr(description)}

关于天远查

天远查官网(TianYuanCha)聚合官方公示数据,专注于商业安全与资产背调。提供企业工商画像、婚姻状态关联风险、司法涉诉筛查及配偶债务核验。

核心服务

` } function main() { const outputDir = path.join(__dirname, '../public/seo-templates') if (!fs.existsSync(outputDir)) { fs.mkdirSync(outputDir, { recursive: true }) console.log(`✓ 创建模板目录: ${outputDir}`) } let successCount = 0 Object.entries(pageSEOConfigs).forEach(([filename, config]) => { const htmlContent = generateHTMLTemplate(config) const filePath = path.join(outputDir, filename) fs.writeFileSync(filePath, htmlContent, 'utf-8') console.log(`✓ 生成模板: ${filename}`) successCount++ }) console.log(`\n✓ 成功生成 ${successCount} 个 SEO 模板文件`) console.log(`📁 模板目录: ${outputDir}`) console.log(`💡 配置与 useSEO.js 一致,当前域名: ${BASE_URL}`) } main()