当前位置: 首页 > news >正文

可直接运行的 Playwright C# 自动化模板

目录

目录结构

1. appsettings.json(账号、URL、路径配置)

2. Program.cs(启动入口)

3. SchedulerConfig.cs(定时调度)

4. SocialSecurityTask.cs(自动报社保任务)

5. QuerySocialDataTask.cs(查询导出任务)

6. PublishCsdnTask.cs(发布 CSDN 文章)

7. 后续可加功能


可直接运行的 Playwright C# 自动化模板,里面包含:

  • 报社保任务(模拟登录 → 上传 Excel)
  • 查询导出任务(模拟登录 → 查询 → 下载 Excel)
  • 发布文章任务(自动登录 → 填写标题与内容 → 发布)
  • Quartz.NET 定时调度(可配置执行周期)
  • 配置文件管理(账号、密码、URL、文件路径)
  • 日志记录 & 截图保存
  • 验证码识别预留接口(可以后续接 Python OCR)

目录结构

AutoTasks/├── AutoTasks.csproj├── appsettings.json         // 配置账号密码├── Program.cs               // 启动调度器├── SchedulerConfig.cs       // Quartz 调度配置├── Tasks/│    ├── SocialSecurityTask.cs // 报社保任务│    ├── QuerySocialDataTask.cs // 查询导出任务│    ├── PublishCsdnTask.cs    // 发布任务├── Services/│    ├── OcrService.cs         // 验证码识别接口(可接Python)│    ├── ExcelService.cs       // Excel处理│    ├── AiContentService.cs   // AI生成文章└── Logs/└── ...                   // 自动化运行截图 & 日志

1. appsettings.json(账号、URL、路径配置)

{"SocialSecurity": {"LoginUrl": "https://example.com/social/login","Username": "your_username","Password": "your_password","UploadFilePath": "C:\\报表\\社保.xls"},"Csdn": {"LoginUrl": "https://**.net/creation/editor","Username": "your_username","Password": "your_password"},"Paths": {"DownloadFolder": "C:\\数据导出","ScreenshotFolder": "Logs"}
}

2. Program.cs(启动入口)

using System.Threading.Tasks;class Program
{public static async Task Main(){await SchedulerConfig.Start();Console.WriteLine("任务调度已启动,按 Ctrl+C 停止。");await Task.Delay(-1);}
}

3. SchedulerConfig.cs(定时调度)

using Quartz;
using Quartz.Impl;public class SchedulerConfig
{public static async Task Start(){StdSchedulerFactory factory = new StdSchedulerFactory();var scheduler = await factory.GetScheduler();await scheduler.Start();// 每月5号 10:00 报社保var socialJob = JobBuilder.Create<SocialSecurityTask>().Build();var socialTrigger = TriggerBuilder.Create().WithCronSchedule("0 0 10 5 * ?").Build();await scheduler.ScheduleJob(socialJob, socialTrigger);// 每周一 09:00 查询社保数据var queryJob = JobBuilder.Create<QuerySocialDataTask>().Build();var queryTrigger = TriggerBuilder.Create().WithCronSchedule("0 0 9 ? * MON").Build();await scheduler.ScheduleJob(queryJob, queryTrigger);// 每周二 09:30 发布文章var csdnJob = JobBuilder.Create<PublishCsdnTask>().Build();var csdnTrigger = TriggerBuilder.Create().WithCronSchedule("0 30 9 ? * TUE").Build();await scheduler.ScheduleJob(csdnJob, csdnTrigger);}
}

4. SocialSecurityTask.cs(自动报社保任务)

using Quartz;
using Microsoft.Playwright;
using Microsoft.Extensions.Configuration;public class SocialSecurityTask : IJob
{public async Task Execute(IJobExecutionContext context){var config = new ConfigurationBuilder().AddJsonFile("appsettings.json").Build();var url = config["SocialSecurity:LoginUrl"];var username = config["SocialSecurity:Username"];var password = config["SocialSecurity:Password"];var filePath = config["SocialSecurity:UploadFilePath"];var screenshotFolder = config["Paths:ScreenshotFolder"];using var playwright = await Playwright.CreateAsync();var browser = await playwright.Chromium.LaunchAsync(new BrowserTypeLaunchOptions { Headless = false });var page = await browser.NewPageAsync();try{await page.GotoAsync(url);await page.FillAsync("#username", username);await page.FillAsync("#password", password);// TODO: 验证码处理 - 调用 OcrService// var captchaText = await OcrService.RecognizeAsync(page);// await page.FillAsync("#captcha", captchaText);await page.ClickAsync("#loginBtn");await page.SetInputFilesAsync("input[type='file']", filePath);await page.ClickAsync("#submitBtn");await page.ScreenshotAsync(new PageScreenshotOptions{Path = $"{screenshotFolder}\\SocialSecurity_{DateTime.Now:yyyyMMddHHmmss}.png"});}catch (Exception ex){Console.WriteLine($"报社保任务失败: {ex.Message}");}finally{await browser.CloseAsync();}}
}

5. QuerySocialDataTask.cs(查询导出任务)

using Quartz;
using Microsoft.Playwright;public class QuerySocialDataTask : IJob
{public async Task Execute(IJobExecutionContext context){Console.WriteLine("执行社保数据查询并导出...");// 和 SocialSecurityTask 类似,登录后执行查询与下载}
}

6. PublishCsdnTask.cs(发布 CSDN 文章)

using Quartz;
using Microsoft.Playwright;public class PublishCsdnTask : IJob
{public async Task Execute(IJobExecutionContext context){Console.WriteLine("执行发布文章任务...");// 登录,填写标题和内容,点击发布}
}

7. 后续可加功能

  • 验证码自动识别:OcrService 接入 Python 脚本或打码平台
  • Excel 数据处理:ExcelService 用 EPPlus 读取、写入 Excel
  • 文章 AI 生成:AiContentService 调用 GPT API 生成内容
  • 任务失败重试:Quartz 支持失败任务重试策略
  • 打包成 EXEdotnet publish -r win-x64

http://www.dtcms.com/a/322517.html

相关文章:

  • day22|学习前端ts语言
  • 我想做自动化报社保,用哪种技术更好一点呢?
  • 7_基于深度学习的安全帽检测识别系统(yolo11、yolov8、yolov5+UI界面+Python项目源码+模型+标注好的数据集)
  • 微信原生小程序 Timeline 组件实现
  • 论文阅读-ZeroDCE和ZeroDCE++
  • 力扣-34.在排序数组中查找元素的第一个和最后一个位置
  • 【排序算法】③直接选择排序
  • 深入解析 Apache APISIX 在微服务网关中的性能优化实践指南
  • C语言(10)——结构体、联合体、枚举
  • ARM体系结构
  • cross-env dotenv
  • 【QuPath 】QuPath 批量提取 SVS 文件元数据脚本
  • NLP:Transformer输出部分
  • DigitalProductId解密算法php调试版piddebug.php
  • Day02 员工管理,分类管理
  • 【线性代数】其他
  • 【Redis7.x】docker配置主从+sentinel监控遇到的问题与解决
  • 【LeetCode 热题 100】(六)矩阵
  • 解决本地连接服务器ollama的错误
  • 网站站长如何借助php推送示例提交网站内容加速百度收录?
  • 【26】C#实战篇—— 多个线程函数对同一个 Excel 文件进行写操作引起的文件冲突问题,解决方法
  • 代码随想录day60图论10
  • 使用 Ansys Discovery 进行动态设计和分析
  • Mac屏幕取色不准?探究原理和换算规则
  • Linux文件系统基石:透彻理解inode及其核心作用
  • LeetCode111~130题解
  • ABP VNext + Akka.NET:高并发处理与分布式计算
  • 【AGI】GPT-5:博士级AI助手的全面进化与协作智能时代的黎明
  • 如何输出一篇高质量的版本测试策略
  • WebGIS视角下基孔肯雅热流行风险地区分类实战解析