/**
* 静态页面生成器
* 基于路由和SEO配置自动生成静态HTML页面
*/
import fs from 'fs';
import path from 'path';
import { fileURLToPath } from 'url';
import { generateStaticHTML, generateContentByRoute } from './pageTemplates.js';
// 获取当前文件的目录
const __filename = fileURLToPath(import.meta.url);
const __dirname = path.dirname(__filename);
// SEO配置 - 直接从useSEO.js复制过来
const seoConfigs = {
'/': {
title: '天远查官网_企业与婚姻关联风险核验_综合履约背景核验',
description: '天远查官网(TianYuanCha)聚合官方公示数据,专注于商业安全与资产背调。提供企业工商画像、婚姻状态关联风险、司法涉诉筛查及配偶债务核验。数据实时同步,助您精准规避投资、交易及家庭结合中的经济与法律风险。',
keywords: '天远查,婚姻状态风险, 配偶背景核验,企业信用查询,司法诉讼记录,资产风险评估'
},
'/inquire/category/lawsuit': {
title: '司法涉诉核验_个人及企业法律诉讼记录_履约风险评估_天远查',
description: '天远查司法风险检测中心,聚合全国法院公开公示数据。一键筛查开庭公告、裁判文书、立案信息及执行记录。帮助用户快速识别法律纠纷隐患,全方位扫除合作盲区。',
keywords: '司法案件核验,法律诉讼记录,个人涉诉详情,法院公告查询,案件执行状态'
},
'/inquire/marriage': {
title: '婚前背景核验_婚姻关联司法风险筛查_情感综合保障_天远查',
description: '天远查婚恋风险报告为您提供深度的背景核实服务。基于合法公开数据,排查对象的重婚司法记录、家庭暴力涉诉历史、潜在债务风险及不良嗜好风险。拒绝盲目信任,用数据守护您的情感与财产安全。',
keywords: '婚前背景核实,婚恋对象评估,婚姻司法风险,个人情感风险,婚前背调工具'
},
'/inquire/category/vehicle': {
title: '车辆档案报告_二手车车况与产权风险检测_机动车报告_天远查',
description: '天远查车辆数据中心,让车辆交易更透明。支持通过车牌号或VIN码,核验车辆的初次登记信息、抵押查封状态、事故维修记录及产权属性。数据同步权威行业系统,精准识别问题车。',
keywords: '车辆维修记录,二手车出险报告,车辆抵押报告,车况报告,机动车档案'
},
'/inquire/category/marriageStatus': {
title: '个人婚姻关联风险核验_家庭背景合规报告_天远查',
description: '天远查提供基于大数据的婚姻关联风险评估。通过分析司法文书及公开社会关系,辅助判断目标的真实家庭状况与情感履历。合法合规,保障知情权。',
keywords: '婚史风险排查,家庭背景核实,婚姻诚信评估,情感状态评估,涉婚法律记录'
},
'/agent': {
title: '天远查代理 - 免费开通代理权限 | 大数据风险报告代理',
description: '天远查代理平台,免费开通代理权限,享受大数据风险报告查询服务代理收益。专业的大数据风险报告、婚姻查询、个人信用评估等服务的代理合作。',
keywords: '天远查代理, 免费代理, 大数据风险报告代理, 代理权限, 代理收益'
},
'/help': {
title: '帮助中心 - 天远查使用指南 | 常见问题解答',
description: '天远查帮助中心,提供详细的使用指南、常见问题解答、操作教程等,帮助用户更好地使用大数据风险报告查询服务。',
keywords: '天远查帮助, 使用指南, 常见问题, 操作教程, 客服支持'
},
'/help/guide': {
title: '使用指南 - 天远查操作教程 | 功能说明',
description: '天远查详细使用指南,包含各功能模块的操作教程、功能说明、注意事项等,让用户快速上手使用。',
keywords: '使用指南, 操作教程, 功能说明, 快速上手, 天远查教程'
},
'/example': {
title: '示例报告 - 天远查报告展示 | 大数据风险报告样例',
description: '天远查示例报告展示,包含大数据风险报告、婚姻状况查询、个人信用评估等服务的报告样例,让用户了解报告内容和格式。',
keywords: '示例报告, 报告展示, 报告样例, 大数据风险报告, 婚姻查询报告'
},
'/service': {
title: '客服中心 - 天远查在线客服 | 技术支持',
description: '天远查客服中心,提供在线客服支持、技术咨询、问题反馈等服务,确保用户获得及时有效的帮助。',
keywords: '客服中心, 在线客服, 技术支持, 问题反馈, 天远查客服'
},
'/inquire': {
title: '核验工具多场景数据核验服务天远查',
description: '提供车辆、企业、个人等多场景核验,包括状态、信用、身份等查询,权威高效,保护隐私。',
keywords: '核验工具,数据核验服务,车辆核验,企业核验,天远查'
},
};
// 额外的路由配置(从router.js提取)
const additionalRoutes = [
{ path: '/historyQuery', title: '历史报告' },
{ path: '/withdraw', title: '提现' },
{ path: '/complaint', title: '投诉' },
{ path: '/report', title: '报告结果' },
{ path: '/agent/promote', title: '代理推广' },
{ path: '/me', title: '个人中心' },
];
// 输出目录配置
const OUTPUT_DIR = path.resolve(__dirname, 'static-pages');
// 确保输出目录存在
function ensureOutputDir() {
try {
if (!fs.existsSync(OUTPUT_DIR)) {
fs.mkdirSync(OUTPUT_DIR, { recursive: true });
console.log(`📁 创建输出目录: ${OUTPUT_DIR}`);
}
console.log(`📂 输出目录已存在: ${OUTPUT_DIR}`);
} catch (error) {
console.error(`❌ 创建目录失败: ${error.message}`);
throw error;
}
}
// 将路径转换为文件名
function pathToFilename(routePath) {
// 替换特殊字符
let filename = routePath
.replace(/^\//, '') // 移除开头的 /
.replace(/\/+/g, '-') // 将 / 替换为 -
.replace(/:/g, '-') // 将 : 替换为 -
// 如果是根路径,使用 index
if (!filename) {
filename = 'index';
}
return `${filename}.html`;
}
// 生成静态页面
function generatePage(routePath, seoConfig) {
const filename = pathToFilename(routePath);
const filepath = path.join(OUTPUT_DIR, filename);
// 生成页面内容
const content = generateContentByRoute(routePath, seoConfig);
// 生成完整的HTML
const html = generateStaticHTML(seoConfig, {
path: routePath,
content: content,
canonical: 'https://www.tianyuancha.cn'
});
// 写入文件
fs.writeFileSync(filepath, html, 'utf-8');
process.stdout.write(`✅ 生成成功: ${filename}\n`);
return filepath;
}
// 生成所有静态页面
function generateAllPages() {
console.log('🚀 开始生成静态页面...\n');
ensureOutputDir();
// 生成主要路由的页面
console.log('📝 生成主要路由页面:');
let count = 0;
for (const [routePath, seoConfig] of Object.entries(seoConfigs)) {
try {
generatePage(routePath, seoConfig);
count++;
} catch (error) {
console.error(`❌ 生成失败 [${routePath}]:`, error.message);
}
}
// 生成额外路由的页面
console.log('\n📝 生成额外路由页面:');
for (const route of additionalRoutes) {
try {
const seoConfig = {
title: `${route.title} - 天远查`,
description: `天远查${route.title}页面,提供专业的大数据风险管控服务。`,
keywords: `天远查,${route.title}`
};
generatePage(route.path, seoConfig);
count++;
} catch (error) {
console.error(`❌ 生成失败 [${route.path}]:`, error.message);
}
}
// 生成sitemap
generateSitemap();
console.log(`\n✨ 完成!共生成 ${count} 个静态页面`);
console.log(`📁 输出目录: ${OUTPUT_DIR}`);
}
// 生成sitemap.xml
function generateSitemap() {
const sitemapPath = path.join(OUTPUT_DIR, 'sitemap.xml');
const baseUrl = 'https://www.tianyuancha.cn';
const currentDate = new Date().toISOString().split('T')[0];
let sitemap = `
`;
// 添加主要路由
for (const [routePath] of Object.entries(seoConfigs)) {
const priority = routePath === '/' ? '1.0' : '0.8';
sitemap += `
${baseUrl}${routePath}
${currentDate}
weekly
${priority}
`;
}
// 添加额外路由
for (const route of additionalRoutes) {
sitemap += `
${baseUrl}${route.path}
${currentDate}
weekly
0.6
`;
}
sitemap += ``;
fs.writeFileSync(sitemapPath, sitemap, 'utf-8');
console.log(`✅ 生成成功: ${sitemapPath}`);
}
// 生成robots.txt
function generateRobots() {
const robotsPath = path.join(OUTPUT_DIR, 'robots.txt');
const robotsContent = `User-agent: *
Allow: /
# 禁止爬取后台管理页面
Disallow: /admin
Disallow: /api
# Sitemap
Sitemap: https://www.tianyuancha.cn/sitemap.xml
`;
fs.writeFileSync(robotsPath, robotsContent, 'utf-8');
console.log(`✅ 生成成功: ${robotsPath}`);
}
// 主函数
function main() {
console.log('='.repeat(60));
console.log(' 天远查 - 静态页面生成器');
console.log('='.repeat(60));
console.log();
try {
generateAllPages();
generateRobots();
console.log('\n🎉 所有文件生成完成!');
} catch (error) {
console.error('\n❌ 生成失败:', error);
process.exit(1);
}
}
// 如果直接运行此脚本
if (import.meta.url === `file://${process.argv[1]}`) {
main();
}
export { generateAllPages, generatePage };