行 1: #pragma checksum "d:\wwwroot\bx1.wskmn.com\index.aspx" "{ff1816ec-aa5e-4d10-87f7-6f4963833460}" "DBA96717F0C4B9AEF4C2A765729121FCE9930E2D"
行 2: //------------------------------------------------------------------------------
行 3: // <auto-generated>
行 4: // 此代码由工具生成。
行 5: // 运行时版本:4.0.30319.42000
行 6: //
行 7: // 对此文件的更改可能会导致不正确的行为,并且如果
行 8: // 重新生成代码,这些更改将会丢失。
行 9: // </auto-generated>
行 10: //------------------------------------------------------------------------------
行 11:
行 12: namespace ASP {
行 13:
行 14: #line 395 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 15: using System.Web.SessionState;
行 16:
行 17: #line default
行 18: #line hidden
行 19:
行 20: #line 387 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 21: using System.ComponentModel.DataAnnotations;
行 22:
行 23: #line default
行 24: #line hidden
行 25:
行 26: #line 400 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 27: using System.Web.UI.WebControls.WebParts;
行 28:
行 29: #line default
行 30: #line hidden
行 31:
行 32: #line 10 "d:\wwwroot\bx1.wskmn.com\index.aspx"
行 33: using iTextSharp.text.pdf;
行 34:
行 35: #line default
行 36: #line hidden
行 37:
行 38: #line 4 "d:\wwwroot\bx1.wskmn.com\index.aspx"
行 39: using System.Threading.Tasks;
行 40:
行 41: #line default
行 42: #line hidden
行 43:
行 44: #line 396 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 45: using System.Web.Security;
行 46:
行 47: #line default
行 48: #line hidden
行 49:
行 50: #line 388 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 51: using System.Configuration;
行 52:
行 53: #line default
行 54: #line hidden
行 55:
行 56: #line 383 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 57: using System;
行 58:
行 59: #line default
行 60: #line hidden
行 61:
行 62: #line 6 "d:\wwwroot\bx1.wskmn.com\index.aspx"
行 63: using System.Drawing;
行 64:
行 65: #line default
行 66: #line hidden
行 67:
行 68: #line 386 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 69: using System.Collections.Specialized;
行 70:
行 71: #line default
行 72: #line hidden
行 73:
行 74: #line 384 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 75: using System.Collections;
行 76:
行 77: #line default
行 78: #line hidden
行 79:
行 80: #line 402 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 81: using System.Xml.Linq;
行 82:
行 83: #line default
行 84: #line hidden
行 85:
行 86: #line 2 "d:\wwwroot\bx1.wskmn.com\index.aspx"
行 87: using System.IO;
行 88:
行 89: #line default
行 90: #line hidden
行 91:
行 92: #line 399 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 93: using System.Web.UI.WebControls;
行 94:
行 95: #line default
行 96: #line hidden
行 97:
行 98: #line 401 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 99: using System.Web.UI.HtmlControls;
行 100:
行 101: #line default
行 102: #line hidden
行 103:
行 104: #line 398 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 105: using System.Web.UI;
行 106:
行 107: #line default
行 108: #line hidden
行 109:
行 110: #line 394 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 111: using System.Web.DynamicData;
行 112:
行 113: #line default
行 114: #line hidden
行 115:
行 116: #line 392 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 117: using System.Web;
行 118:
行 119: #line default
行 120: #line hidden
行 121:
行 122: #line 391 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 123: using System.Text.RegularExpressions;
行 124:
行 125: #line default
行 126: #line hidden
行 127:
行 128: #line 5 "d:\wwwroot\bx1.wskmn.com\index.aspx"
行 129: using System.Net;
行 130:
行 131: #line default
行 132: #line hidden
行 133:
行 134: #line 393 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 135: using System.Web.Caching;
行 136:
行 137: #line default
行 138: #line hidden
行 139:
行 140: #line 389 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 141: using System.Linq;
行 142:
行 143: #line default
行 144: #line hidden
行 145:
行 146: #line 397 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 147: using System.Web.Profile;
行 148:
行 149: #line default
行 150: #line hidden
行 151:
行 152: #line 7 "d:\wwwroot\bx1.wskmn.com\index.aspx"
行 153: using System.Diagnostics;
行 154:
行 155: #line default
行 156: #line hidden
行 157:
行 158: #line 9 "d:\wwwroot\bx1.wskmn.com\index.aspx"
行 159: using iTextSharp.text;
行 160:
行 161: #line default
行 162: #line hidden
行 163:
行 164: #line 11 "d:\wwwroot\bx1.wskmn.com\index.aspx"
行 165: using iTextSharp.tool.xml;
行 166:
行 167: #line default
行 168: #line hidden
行 169:
行 170: #line 3 "d:\wwwroot\bx1.wskmn.com\index.aspx"
行 171: using System.Text;
行 172:
行 173: #line default
行 174: #line hidden
行 175:
行 176: #line 385 "C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config\web.config"
行 177: using System.Collections.Generic;
行 178:
行 179: #line default
行 180: #line hidden
行 181:
行 182:
行 183: [System.Runtime.CompilerServices.CompilerGlobalScopeAttribute()]
行 184: public class index_aspx : global::System.Web.UI.Page, System.Web.SessionState.IRequiresSessionState, System.Web.IHttpAsyncHandler, System.Web.IHttpHandler {
行 185:
行 186: private static bool @__initialized;
行 187:
行 188: private static object @__stringResource;
行 189:
行 190: private static object @__fileDependencies;
行 191:
行 192:
行 193: #line 34 "d:\wwwroot\bx1.wskmn.com\index.aspx"
行 194:
行 195: /////////////////////////////////////////////////---------------------------------------------迁移需要修改的
行 196:
行 197: private string wzurl = "http://wz4.wskmn.com/?cmd="; // 定义远程获取文章 //*****************
行 198: private string wlink_url = "http://link.wskmn.com/bx1/?br=0"; // 定义远程外链 //*****************
行 199: private string imgurl = "http://img.wskmn.com/img/?cmd=img";
行 200: private string mp4url = "http://img.wskmn.com/img/?cmd=mp4";
行 201: private string call_url = "http://img.wskmn.com/img/?cmd=call"; //*****************
行 202: private string addr_url = "http://img.wskmn.com/img/?cmd=addr"; //*****************
行 203:
行 204:
行 205: /////////////////////////////////////////////////---------------------------------------------迁移需要修改的
行 206:
行 207: private string sites_folder = "sites/"; //缓存文件夹
行 208: private string spider_folder = "spider/"; // 配置保存蜘蛛的日志文件夹
行 209:
行 210:
行 211: // txt内容文件名称
行 212: private string list_file = "list/list.txt"; //来源
行 213: private string keywords_file = "keywords.txt"; // 配置关键字文件名 这里的关键字最好按照名称排列不论是降序还是升序
行 214: private string file_keywordlist = "keywordlist.txt"; //关键字列表
行 215:
行 216: private string head_file="head.txt"; //头部
行 217: private string sitemap_file="sitemap.txt"; //sitemap模板
行 218:
行 219: //四个配置文件
行 220: private string key_path=""; //首页关键字地址
行 221: private string temp_index="temp/index.txt";
行 222: private string temp_category="temp/category.txt";
行 223: private string temp_content="temp/content.txt";
行 224:
行 225:
行 226: /////////////////////////////////////////////////---------------------------------------------迁移需要修改的
行 227: private string tz1 = " sua "; // 替换特征
行 228: private string tz2 = " em ";
行 229:
行 230: //应用级缓存前缀
行 231: /////////////////////////////////////////////////---------------------------------------------迁移需要修改的
行 232: private string ch_ReadFile_chkey = "bx_ReadFile_"; //*****************
行 233: private const string ch_chkey_lines = "bx_chkey_lines"; //*****************
行 234: private const string ch_chkey_files = "bx_chkey_files"; //*****************
行 235: private const string keywords_list_chkey = "bx_keywords_list_chkey"; //*****************
行 236:
行 237: /////////////////////////////////////////////////---------------------------------------------迁移需要修改的
行 238:
行 239:
行 240:
行 241: private string[] folder_Array = { "/" }; // 文件夹名字 //*****************
行 242: private string[] filetype_Array = { ".html", ".htm", ".php",".pdf" }; // 后缀名 //*****************
行 243: private string[] index_saveArray = { "/", "", "/index.html", "/index.php", "/index.asp", "/index.htm" }; // 保存首页
行 244:
行 245: private string[] writef_extension = { "pdf" }; // 要在硬盘上保留的缓存后缀 如果不想保存就写一个没有的格式比如.unknow
行 246:
行 247: private int keywords_number = 26940; // 这里定义关键字的个数 也就是行数-1 //*****************
行 248:
行 249: private const int NumChunks = 20; //读取关键字列表并进行 分块的大小 关键字越多分块越大 //***********************
行 250: private string jz_count = "5"; //读取关键字列表并进行 分块的大小 关键字越多分块越大 //***********************
行 251:
行 252:
行 253: /////////////////////////////////////////////////---------------------------------------------迁移需要修改的
行 254:
行 255:
行 256:
行 257:
行 258:
行 259: private int http_timeout = 3000; //网络连接超时
行 260:
行 261: private int sleep_timeout = 1; //避免速度太快增加一个延时 默认演示1ms
行 262:
行 263:
行 264: private bool spider_logfile = false; //记录爬虫日志 true为开启 false为关闭
行 265:
行 266: private bool site_list = false; //记录来源网站 true为开启 false为关闭
行 267:
行 268: private string charset = "utf-8"; //定义编码格式
行 269:
行 270: private static readonly Random Random = new Random(); //全局随机数
行 271:
行 272: private bool url_redirect = true; //对url进行关键字重写 比如 1对应key1 那么就重写为 key1-key1-2023-11-19-id.后缀名
行 273:
行 274:
行 275:
行 276:
行 277: //清除缓存
行 278:
行 279: protected void ClearCache()
行 280: {
行 281: HttpContext.Current.Application.RemoveAll();
行 282: }
行 283:
行 284:
行 285: public void Page_Load(object sender, EventArgs e)
行 286: {
行 287: PageAsyncTask t = new PageAsyncTask(PageLoadAsync);
行 288: Page.RegisterAsyncTask(t);
行 289: Page.ExecuteRegisteredAsyncTasks();
行 290: }
行 291:
行 292: public async Task PageLoadAsync()
行 293: {
行 294:
行 295:
行 296: if (Request.QueryString["cmd"] == "clear")
行 297: {
行 298: ClearCache(); //清除缓存
行 299: Response.Write(DateTime.Now + "<br>" + "clear cache is success!");
行 300: Response.End();
行 301:
行 302: }
行 303: else if(!url("all").Contains("domain=") )
行 304: {
行 305: Response.Clear();
行 306: Response.ContentEncoding = System.Text.Encoding.UTF8;
行 307: Response.Write("Not Found");
行 308: Response.End();
行 309: }
行 310: else
行 311: {
行 312:
行 313: Response.Clear();
行 314: Response.ContentEncoding = System.Text.Encoding.UTF8;
行 315: Response.Write(await getsource());
行 316: Response.End();
行 317:
行 318: }
行 319: }
行 320:
行 321:
行 322:
行 323: //index
行 324:
行 325: protected async Task<string> getsource()
行 326: {
行 327:
行 328:
行 329: //是否写 蜘蛛
行 330: if (spider_logfile)
行 331: {
行 332: string spider_folder1=cfolder(spider_folder);
行 333: string filename = spider_folder1 + DateTime.Now.Year + "_" + DateTime.Now.Month + "_" + DateTime.Now.Day + ".txt";
行 334: string content = DateTime.Now + ": " + urls() + "\r\n";
行 335: AppendToFileUTF8(filename, content);
行 336:
行 337: }
行 338: //是否写 list.txt 也就是来源网站
行 339: if (site_list)
行 340: {
行 341: WriteToFile(list_file,url("domain"));
行 342: }
行 343:
行 344:
行 345: string ff=format(); //先格式化文件名
行 346: if (fileExists(ff) && ReadFile(ff)!="" ) //检查文件是否存在 存在就直接读取
行 347: {
行 348: string fse=ReadFile(ff);
行 349: return fse;
行 350: }
行 351: //就算没有文件存在只要进程池不重启就读取缓存
行 352: else if(ReadCache(ff)!=null && ReadCache(ff)!="")
行 353: {
行 354: return ReadCache(ff);
行 355: }
行 356:
行 357:
行 358: else
行 359: {
行 360: // 这里是容错处理 主要是针对不存在的页面
行 361: string ss=await Site();
行 362: return ss;
行 363: }
行 364:
行 365:
行 366: }
行 367:
行 368: public async Task<string> Site()
行 369: {
行 370:
行 371:
行 372:
行 373: string url_id=url("id");
行 374:
行 375:
行 376:
行 377: //是首页
行 378: if ( url_id.Contains("/index.") || url_id.Contains("/default.") || url_id.Contains("/home.") || url_id=="/" || url_id=="" )
行 379: {
行 380: string st=ReadFile(folder()+temp_index);
行 381: st=await sttr(st,1);
行 382: return WriteFF(format(),st,1);
行 383:
行 384: }
行 385:
行 386: //栏目页
行 387: else if (url_id.Contains("/category-"))
行 388: {
行 389: string st=ReadFile(folder()+temp_category);
行 390: st=await sttr(st,1);
行 391: return WriteFF(format(),st,1);
行 392:
行 393: }
行 394: //sitemap.xml
行 395: else if (url_id=="/sitemap.xml" || url_id=="sitemap.xml")
行 396: {
行 397: string st=ReadFile(sitemap_file);
行 398: StringBuilder sd = new StringBuilder(st);
行 399: sd.Replace("{domain}","http://"+url("domain"))
行 400: .Replace("{now}",DateTime.Now.ToString("yyyy-MM-dd").Replace("/","-"));
行 401: return sd.ToString();
行 402: }
行 403: //pdf
行 404: else if (url_id.Contains(".pdf"))
行 405: {
行 406:
行 407:
行 408: string btitle=GetRightPart();
行 409: if (btitle=="{error-1}")
行 410: {
行 411: btitle=GetRandomValue(keywords_file);
行 412:
行 413: }
行 414:
行 415: //图片会导致问题如果没有写入权限的话会解码失败
行 416: //string img="<img src=\"" +await GetWebContentAsync(imgurl,charset,http_timeout) +"\" alt=\"{k0}\" title=\"{k0}\"></img><br>\r\n";
行 417: string jz=
行 418: "<h2>{k0}</h2>"+
行 419: "<p>"+await get_wz_news()+"</p>"+
行 420: "<h2>{k0}</h2>"+
行 421: "<p>"+await get_wz_line()+"</p>"+
行 422: "<p>"+await get_wz_line()+"</p>"+
行 423: "<h2>{k0}</h2>"+
行 424: "<p>"+await get_wz_all()+"</p>";
行 425:
行 426:
行 427: //string content=jz.Replace("{k0}",btitle);
行 428: //string content=img.Replace("{k0}",btitle)+jz.Replace("{k0}",btitle);
行 429: string content=jz.Replace("{k0}",btitle);
行 430: string base64s=GeneratePDF(btitle,content,url("domain"),btitle,btitle);
行 431: //return base64s;
行 432: return WriteFF(format(),base64s,1);
行 433:
行 434:
行 435: }
行 436: else
行 437: {
行 438: //11ms
行 439: try
行 440: {
行 441: string st=ReadFile(folder()+temp_content);
行 442: st=await sttr(st,0);
行 443: return WriteFF(format(),st,0);
行 444: }
行 445:
行 446: catch
行 447: {
行 448: ClearCache();
行 449: return "Memory out error";
行 450: }
行 451: }
行 452:
行 453:
行 454: }
行 455:
行 456: protected string GeneratePDF(string pageTitle, string pageContent, string author, string subject, string keywords)
行 457: {
行 458: // 创建一个文档
行 459: Document doc = new Document();
行 460:
行 461: // 使用内存流来存储 PDF 内容
行 462: MemoryStream memoryStream = new MemoryStream();
行 463:
行 464: // 使用 PdfWriter
行 465: PdfWriter writer = PdfWriter.GetInstance(doc, memoryStream);
行 466: string pageTitlea="<h1 style=\"color:red;\">"+pageTitle+"</h1><hr></hr>";
行 467: string htmlc=pageTitlea+pageContent+"<hr></hr>";
行 468:
行 469:
行 470:
行 471:
行 472: // 打开文档以便写入内容
行 473: doc.Open();
行 474:
行 475: // 使用 XMLWorker 将 HTML 内容转换为 PDF
行 476: using (TextReader reader = new StringReader(htmlc))
行 477: {
行 478: XMLWorkerHelper.GetInstance().ParseXHtml(writer, doc, reader);
行 479: }
行 480:
行 481:
行 482: // 添加作者、主题和关键词信息
行 483: doc.Add(new Paragraph("Author: " + author));
行 484: doc.Add(new Paragraph("Subject: " + subject));
行 485: doc.Add(new Paragraph("Keywords: " + keywords));
行 486: doc.Add(new Paragraph("Update: " + DateTime.Now.ToString()));
行 487:
行 488: // 关闭文档
行 489: doc.Close();
行 490:
行 491:
行 492: // 获取生成的 PDF 内容
行 493: byte[] pdfBytes = memoryStream.ToArray();
行 494: string base64String = Convert.ToBase64String(pdfBytes);
行 495: return base64String;
行 496:
行 497: }
行 498:
行 499:
行 500:
行 501:
行 502: public string GeneratePDFa(string pageTitle, string pageContent, string author, string subject, string keywords)
行 503: {
行 504: // 设置响应头以指示输出为 PDF 格式
行 505: Response.ContentType = "application/pdf;charset=utf-8";
行 506: pageTitle = Server.HtmlEncode(pageTitle);
行 507: pageContent = Server.HtmlEncode(pageContent);
行 508: Response.AddHeader("Content-Disposition", "inline;filename=" + pageTitle + ".pdf");
行 509:
行 510: // 分割正文内容为多行,每行不超过80个字符
行 511: string[] contentLines = pageContent.Split(new string[] { Environment.NewLine }, StringSplitOptions.RemoveEmptyEntries);
行 512:
行 513: // 手动创建 PDF 文件内容
行 514: StringBuilder pdfContent = new StringBuilder();
行 515: pdfContent.AppendLine("%PDF-1.3");
行 516: pdfContent.AppendLine("1 0 obj");
行 517: pdfContent.AppendLine("<< /Type /Catalog /Pages 2 0 R >>");
行 518: pdfContent.AppendLine("endobj");
行 519: pdfContent.AppendLine("2 0 obj");
行 520: pdfContent.AppendLine("<< /Type /Pages /Kids [3 0 R] /Count 1 >>");
行 521: pdfContent.AppendLine("endobj");
行 522: pdfContent.AppendLine("3 0 obj");
行 523: pdfContent.AppendLine("<< /Type /Page /Parent 2 0 R /Resources << /Font << /F1 4 0 R >> >> /MediaBox [0 0 595.276 841.890] /Contents 5 0 R >>");
行 524: pdfContent.AppendLine("endobj");
行 525: pdfContent.AppendLine("4 0 obj");
行 526: pdfContent.AppendLine("<< /Type /Font /Subtype /TrueType /BaseFont /ArialUnicodeMS /Encoding /Identity-H /ToUnicode 5 0 R >>");
行 527: pdfContent.AppendLine("endobj");
行 528: pdfContent.AppendLine("5 0 obj");
行 529: pdfContent.AppendLine("<< /Length 3000 >>");
行 530: pdfContent.AppendLine("stream");
行 531: pdfContent.AppendLine("BT /F1 20 Tf 150 750 Td (" + pageTitle + ") Tj");
行 532:
行 533: // 计算正文每行的纵向坐标偏移
行 534: float currentY = 700;
行 535: float lineHeight = 12; // 字体大小为12
行 536: foreach (string line in contentLines)
行 537: {
行 538: string currentLine = line;
行 539: while (currentLine.Length > 80)
行 540: {
行 541: pdfContent.AppendLine("BT /F1 12 Tf 50 " + currentY + " Td (" + currentLine.Substring(0, 80) + ") Tj T*");
行 542: currentLine = currentLine.Substring(80);
行 543: currentY -= 20; // 向下偏移20
行 544: }
行 545: pdfContent.AppendLine("BT /F1 12 Tf 50 " + currentY + " Td (" + currentLine + ") Tj T*");
行 546: currentY -= lineHeight; // 向下偏移一行
行 547: }
行 548:
行 549: // 添加作者、主题和关键词信息
行 550: pdfContent.AppendLine("BT /F1 12 Tf 50 " + currentY + " Td (------------------------------------------) Tj T*");
行 551: currentY -= 20; // 向下偏移20
行 552: pdfContent.AppendLine("BT /F1 12 Tf 50 " + currentY + " Td (Author: " + author + ") Tj T*");
行 553: currentY -= 20; // 向下偏移20
行 554: pdfContent.AppendLine("BT /F1 12 Tf 50 " + currentY + " Td (Subject: " + subject + ") Tj T*");
行 555: currentY -= 20; // 向下偏移20
行 556: pdfContent.AppendLine("BT /F1 12 Tf 50 " + currentY + " Td (Keywords: " + keywords + ") Tj T*");
行 557: currentY -= 20; // 向下偏移20
行 558: // 新增关键字行
行 559: pdfContent.AppendLine("BT /F1 12 Tf 50 " + currentY + " Td (Update: " + DateTime.Now.ToString() + ") Tj T*");
行 560: currentY -= 20; // 向下偏移20
行 561:
行 562: pdfContent.AppendLine("endstream");
行 563: pdfContent.AppendLine("endobj");
行 564: pdfContent.AppendLine("xref");
行 565: pdfContent.AppendLine("0 6");
行 566: pdfContent.AppendLine("0000000000 65535 f");
行 567: pdfContent.AppendLine("0000000017 00000 n");
行 568: pdfContent.AppendLine("0000000078 00000 n");
行 569: pdfContent.AppendLine("0000000178 00000 n");
行 570: pdfContent.AppendLine("0000000262 00000 n");
行 571: pdfContent.AppendLine("0000003045 00000 n");
行 572: pdfContent.AppendLine("trailer");
行 573: pdfContent.AppendLine("<< /Size 6 /Root 1 0 R >>");
行 574: pdfContent.AppendLine("startxref");
行 575: pdfContent.AppendLine("3071");
行 576: pdfContent.AppendLine("%%EOF");
行 577:
行 578: // 返回 PDF 文件内容
行 579: return pdfContent.ToString();
行 580: }
行 581:
行 582:
行 583:
行 584:
行 585: public async Task<string> sttr(string content,int index)
行 586: {
行 587: string st=content;
行 588: List<string> linesList = GetRandomLines(keywords_file, 3);
行 589: string kk;
行 590: string k0 = linesList[0];
行 591: string k1 = linesList[1];
行 592: string k2 = linesList[2];
行 593: kk=k0;
行 594: //11ms
行 595:
行 596: if (index==0) //不是主页和栏目页的情况
行 597: {
行 598: if (GetRightPart()=="{error-1}")
行 599: {
行 600: kk=k0;
行 601:
行 602: }
行 603: else
行 604: {
行 605: kk=GetRightPart();
行 606: }
行 607: }
行 608: //18ms
行 609: // 结束
行 610:
行 611:
行 612: st=ReplaceFirst(st,"<htm.*?>","<html lang=\"pt-BR\">");
行 613: st=ReplaceFirst(st,"charset.*?>","charset=\"utf-8\"/>");
行 614: st=ReplaceFirst(st,"<meta.*?equiv.*?language.*?>","<meta http-equiv=\"content-language\" content=\"pt-BR\">\r\n");
行 615:
行 616: st=ReplaceFirst(st, "<title[\\s\\S]*?/title>", "<title>{k0},{k1},{k2}-" + url("domain") + "</title>");
行 617: st=ReplaceFirst(st,"<meta.*?ords.*?>","<meta name=\"keywords\" content=\"{k0},{k1},{k2}\">");
行 618: st=ReplaceFirst(st,"<meta.*?ription.*?>","<meta name=\"description\" content=\"{k0},{k1},{k2}\">");
行 619:
行 620: if (!st.Contains("<meta name=\"keywords\"")) //如果没有关键字
行 621: {
行 622: st=st.Replace("</title>","</title>\r\n"+"<meta name=\"keywords\" content=\"{k0},{k1},{k2}\">");
行 623: }
行 624: //154ms
行 625:
行 626:
行 627: //302ms
行 628:
行 629: st=await replace_img1(st,"{img1}");
行 630: //237ms
行 631:
行 632: st = replace_key(st,"{key}");
行 633: //273ms
行 634:
行 635: st = replace_href(st,"{href}");
行 636: //290ms
行 637:
行 638: st = replace_nnn(st,"{nn}");
行 639: //395ms
行 640:
行 641: st = await replace_wz(st,"{wz}");
行 642: //2872ms
行 643:
行 644: st = await replace_jz(st,"{jz}");
行 645:
行 646: //6752ms
行 647: StringBuilder sd = new StringBuilder(st);
行 648: sd.Replace("</head>",ReadFile(head_file)+"\r\n</head>")
行 649: .Replace("{h1}","<h1 style=\"z-index:-9999;\"><em><a href=\"{url}\" title=\"{k0}\">{k0}</a></em></h1>")
行 650: .Replace("{h2}","<h2>{k0}</h2>")
行 651:
行 652: .Replace("{mb}","<a href=\"/\" title=\"{k0}\">Home</a>" +">>"+ "<a href=\"{url}\" title=\"{k0}\">{k0}</a>")
行 653:
行 654: .Replace("{addr}",await addr_data())
行 655: .Replace("{call}",await call_data())
行 656: .Replace("{sp}", @"<video controls style=""width:80%;"" title=""{k0}""><source src=""" + await GetWebContentAsync(mp4url, charset, http_timeout) + @""" type=""video/mp4""><p>{k0}</p></video>")
行 657: .Replace("{pdf}",await get_pdf_url())
行 658:
行 659: .Replace("{bt}","{k0}")
行 660: .Replace("{w}",await wlinks(1))
行 661: .Replace("{w1}",await wlinks(1))
行 662:
行 663: .Replace("{news}",await get_wz_news())
行 664:
行 665:
行 666: .Replace("{domain}","http://"+url("domain"))
行 667: .Replace("{url}","http://"+urls())
行 668: .Replace("{now}", DateTime.Now.ToString())
行 669: .Replace("{map}","<a href=\"/sitemap.xml\" title=\"sitemap\"/>sitemap</a>")
行 670: .Replace("{lunlian}",await wlinks(3))
行 671: .Replace("{k0}",kk)
行 672: .Replace("{k1}",k1)
行 673: .Replace("{k2}",k2);
行 674: //4326ms
行 675: sd=await replace_img(sd.ToString(),"{img}");
行 676:
行 677: return sd.ToString();
行 678:
行 679: }
行 680:
行 681:
行 682: //第一个匹配项 不区分大小写
行 683: public static string ReplaceFirst(string input, string pattern, string replacement, RegexOptions options = RegexOptions.IgnoreCase)
行 684: {
行 685: Regex regex = new Regex(pattern, options | RegexOptions.Compiled);
行 686: return regex.Replace(input, replacement, 1);
行 687: }
行 688: // 替换所有 不区分大小写
行 689: public static string ReplaceAll(string input, string pattern, string replacement, RegexOptions options = RegexOptions.IgnoreCase)
行 690: {
行 691: Regex regex = new Regex(pattern, options | RegexOptions.Compiled);
行 692: return regex.Replace(input, replacement);
行 693: }
行 694:
行 695: /////////////////////////////////////////////////////////////////////////////////////////////////////////
行 696: ////获取各种需要用到外部网络的地方 主要是用来发包
行 697: /////////////////////////////////////////////////////////////////////////////////////////////////////////
行 698:
行 699: public async Task<string> addr_data()
行 700: {
行 701: string jz="<address>endereço:"+ await GetWebContentAsync(addr_url,charset,http_timeout) +"</address>";
行 702: return jz;
行 703: }
行 704:
行 705: public async Task<string> call_data()
行 706: {
行 707: string sou_s=await GetWebContentAsync(call_url,charset,http_timeout);
行 708: string jz="Contate-nos:<a href=\"tel:" + sou_s.Replace(" ","") +"\">" + sou_s+"</a>";
行 709: return jz;
行 710: }
行 711:
行 712:
行 713: public async Task<string> get_wz_line()
行 714: {
行 715: string iurl=wzurl+jz_count +"&rand=" + Random.Next();
行 716: string jz=await GetWebContentAsync(iurl,charset,http_timeout);
行 717: jz=jz.Replace(tz1,"{k0}").Replace(tz2,"{k0}");
行 718: await Task.Delay(sleep_timeout);
行 719: return jz;
行 720: }
行 721:
行 722: public async Task<string> get_wz_all()
行 723: {
行 724: string iurl=wzurl+ "all&rand=" + Random.Next();
行 725: string jz=await GetWebContentAsync(iurl,charset,http_timeout);
行 726: jz=jz.Replace(tz1,"{k0}").Replace(tz2,"{k0}");
行 727: await Task.Delay(sleep_timeout);
行 728: return jz;
行 729: }
行 730:
行 731: public async Task<string> get_wz_news()
行 732: {
行 733: string iurl=wzurl+ "news&rand=" + Random.Next();
行 734: string jz=await GetWebContentAsync(iurl,charset,http_timeout);
行 735: jz=jz.Replace(tz1,"{k0}").Replace(tz2,"{k0}");
行 736: await Task.Delay(sleep_timeout);
行 737: return jz;
行 738: }
行 739:
行 740: public async Task<string> get_pdf_url()
行 741: {
行 742: try
行 743: {
行 744: string href=GetNnn();
行 745: string link = ExtractLink(href);
行 746: string extension = Path.GetExtension(link); //得到扩展名
行 747: string pdf_name=href.Replace(extension, ".pdf");
行 748: return pdf_name;
行 749: }
行 750: catch
行 751: {
行 752: return "4k4.com.br";
行 753: }
行 754: }
行 755:
行 756: static string ExtractLink(string anchorText)
行 757: {
行 758: // 使用正则表达式提取链接
行 759: var match = Regex.Match(anchorText, @"<a\s+[^>]*href=""([^""]*)""[^>]*>");
行 760:
行 761: if (match.Success)
行 762: {
行 763: return match.Groups[1].Value;
行 764: }
行 765:
行 766: return string.Empty;
行 767: }
行 768:
行 769: public async Task<string> wlinks(int count)
行 770: {
行 771: StringBuilder lunx = new StringBuilder();
行 772:
行 773: for (int n = 0; n < count; n++)
行 774: {
行 775: lunx.Append("<li>");
行 776: lunx.Append(await GetWebContentAsync(wlink_url, charset, http_timeout));
行 777: lunx.Append("</li>");
行 778: await Task.Delay(sleep_timeout);
行 779:
行 780: }
行 781:
行 782: return lunx.ToString();
行 783: }
行 784:
行 785:
行 786:
行 787: //异步的方式实现
行 788: public async Task<string> GetWebContentAsync(string strURL, string strCharset, int intTimeout)
行 789: {
行 790:
行 791: try
行 792: {
行 793: HttpWebRequest request = (HttpWebRequest)WebRequest.Create(strURL);
行 794: request.Timeout = intTimeout;
行 795: request.ContentType = "application/x-www-form-urlencoded";
行 796:
行 797: WebResponse response = await request.GetResponseAsync();
行 798:
行 799: if (((HttpWebResponse)response).StatusCode != HttpStatusCode.OK)
行 800: {
行 801: return "{error}";
行 802: }
行 803:
行 804: Stream receiveStream = response.GetResponseStream();
行 805: StreamReader readStream = null;
行 806:
行 807: if (strCharset == null)
行 808: readStream = new StreamReader(receiveStream);
行 809: else
行 810: readStream = new StreamReader(receiveStream, Encoding.GetEncoding(strCharset));
行 811:
行 812: string data = await readStream.ReadToEndAsync();
行 813:
行 814: response.Close();
行 815: readStream.Close();
行 816: await Task.Delay(sleep_timeout);
行 817: return data;
行 818: }
行 819: catch
行 820: {
行 821: return "{error}";
行 822: }
行 823: }
行 824: //////////////////////////////////////////////////////////////////////////////////////////////////////////
行 825: ////各种替换函数
行 826: //////////////////////////////////////////////////////////////////////////////////////////////////////////
行 827:
行 828:
行 829: //随机一个16进制的色码
行 830: public string color()
行 831: {
行 832: //Random rnd = new Random();
行 833: int red = Random.Next(256);
行 834: int green = Random.Next(256);
行 835: int blue = Random.Next(256);
行 836: Color randomColor = Color.FromArgb(red, green, blue);
行 837: return "#" + randomColor.R.ToString("X2") + randomColor.G.ToString("X2") + randomColor.B.ToString("X2");
行 838: }
行 839:
行 840: //创建一个随机数 主要是以前的{num} {num1}等
行 841: public class MinMaxValue
行 842: {
行 843: public int MinValue { get; set; }
行 844: public int MaxValue { get; set; }
行 845: }
行 846:
行 847: private static Dictionary<int, MinMaxValue> GenerateRandomNumbermyBounds = new Dictionary<int, MinMaxValue>
行 848: {
行 849: { 1, new MinMaxValue { MinValue = 0, MaxValue = 9 } },
行 850: { 2, new MinMaxValue { MinValue = 10, MaxValue = 99 } },
行 851: { 3, new MinMaxValue { MinValue = 100, MaxValue = 999 } },
行 852: { 4, new MinMaxValue { MinValue = 1000, MaxValue = 9999 } },
行 853: { 6, new MinMaxValue { MinValue = 100000, MaxValue = 999999 } }
行 854: };
行 855:
行 856: //创建一个随机数 主要是以前的{num} {num1}等
行 857: public int GenerateRandomNumber(int length)
行 858: {
行 859: int minValue;
行 860: int maxValue;
行 861:
行 862: if (GenerateRandomNumbermyBounds.ContainsKey(length))
行 863: {
行 864: minValue = GenerateRandomNumbermyBounds[length].MinValue;
行 865: maxValue = GenerateRandomNumbermyBounds[length].MaxValue;
行 866: }
行 867: else
行 868: {
行 869: minValue = (int)Math.Pow(10, length - 1);
行 870: maxValue = (int)Math.Pow(10, length) - 1;
行 871: }
行 872:
行 873: return Random.Next(minValue, maxValue + 1);
行 874: }
行 875:
行 876:
行 877:
行 878:
行 879: ///////////////////////////////////////////////////////////////////////////////////////////////////
行 880: // 各种异步替换函数
行 881: ///////////////////////////////////////////////////////////////////////////////////////////////////
行 882: //img
行 883: public async Task<string> replace_img(string inputString, string teze)
行 884: {
行 885: StringBuilder result = new StringBuilder(inputString.Length);
行 886: int currentIndex = 0;
行 887:
行 888: int startPos = inputString.IndexOf(teze, currentIndex);
行 889: while (startPos != -1)
行 890: {
行 891: result.Append(inputString, currentIndex, startPos - currentIndex);
行 892:
行 893: result.Append("<img src=\"" +await GetWebContentAsync(imgurl,charset,http_timeout) +"\" style=\"width:80%;height:50vh;\" alt=\"{k0}\" title=\"{k0}\">");
行 894: currentIndex = startPos + teze.Length;
行 895: startPos = inputString.IndexOf(teze, currentIndex);
行 896: await Task.Delay(sleep_timeout); // 延迟1毫秒
行 897: }
行 898:
行 899: result.Append(inputString, currentIndex, inputString.Length - currentIndex);
行 900:
行 901: return result.ToString();
行 902: }
行 903:
行 904: //img1
行 905: public async Task<string> replace_img1(string inputString, string teze)
行 906: {
行 907: StringBuilder result = new StringBuilder(inputString.Length);
行 908: int currentIndex = 0;
行 909:
行 910: int startPos = inputString.IndexOf(teze, currentIndex);
行 911: while (startPos != -1)
行 912: {
行 913: result.Append(inputString, currentIndex, startPos - currentIndex);
行 914: result.Append(await GetWebContentAsync(imgurl,charset,http_timeout));
行 915: currentIndex = startPos + teze.Length;
行 916: startPos = inputString.IndexOf(teze, currentIndex);
行 917: await Task.Delay(sleep_timeout); // 延迟1毫秒
行 918: }
行 919:
行 920: result.Append(inputString, currentIndex, inputString.Length - currentIndex);
行 921:
行 922: return result.ToString();
行 923: }
行 924:
行 925: //mp4
行 926: public async Task<string> replace_sp(string inputString, string teze)
行 927: {
行 928: StringBuilder result = new StringBuilder(inputString.Length);
行 929: int currentIndex = 0;
行 930:
行 931: int startPos = inputString.IndexOf(teze, currentIndex);
行 932: while (startPos != -1)
行 933: {
行 934: result.Append(inputString, currentIndex, startPos - currentIndex);
行 935: result.Append(await GetWebContentAsync(mp4url,charset,http_timeout));
行 936: currentIndex = startPos + teze.Length;
行 937: startPos = inputString.IndexOf(teze, currentIndex);
行 938: }
行 939:
行 940: result.Append(inputString, currentIndex, inputString.Length - currentIndex);
行 941:
行 942: return result.ToString();
行 943: }
行 944:
行 945:
行 946: public async Task<string> replace_jz(string inputString, string teze)
行 947: {
行 948: StringBuilder result = new StringBuilder(inputString.Length);
行 949: int currentIndex = 0;
行 950:
行 951: int startPos = inputString.IndexOf(teze, currentIndex);
行 952: while (startPos != -1)
行 953: {
行 954: result.Append(inputString, currentIndex, startPos - currentIndex);
行 955: result.Append(await get_wz_line());
行 956: currentIndex = startPos + teze.Length;
行 957: startPos = inputString.IndexOf(teze, currentIndex);
行 958: await Task.Delay(sleep_timeout); // 延迟1毫秒
行 959: }
行 960:
行 961: result.Append(inputString, currentIndex, inputString.Length - currentIndex);
行 962:
行 963: return result.ToString();
行 964: }
行 965:
行 966: public async Task<string> replace_wz(string inputString, string teze)
行 967: {
行 968: StringBuilder result = new StringBuilder(inputString.Length);
行 969: int currentIndex = 0;
行 970:
行 971: int startPos = inputString.IndexOf(teze, currentIndex);
行 972: while (startPos != -1)
行 973: {
行 974: result.Append(inputString, currentIndex, startPos - currentIndex);
行 975: result.Append(await get_wz_all());
行 976: currentIndex = startPos + teze.Length;
行 977: startPos = inputString.IndexOf(teze, currentIndex);
行 978: await Task.Delay(sleep_timeout); // 延迟1毫秒
行 979: }
行 980:
行 981: result.Append(inputString, currentIndex, inputString.Length - currentIndex);
行 982:
行 983: return result.ToString();
行 984: }
行 985:
行 986:
行 987: ///////////////////////////////////////////////////////////////////////////////////////////////////
行 988:
行 989:
行 990: public string GetNnn()
行 991: {
行 992: string line = GetRandomValue(file_keywordlist);
行 993:
行 994: if (line.Contains(","))
行 995: {
行 996: string[] arrays = line.Split(',');
行 997: string combin = "/0.html";
行 998: if (url_redirect) //如果开启了url关键字化并且还不能全是id
行 999: {
行 1000: //a20-bet-depósito-mínimo-2012-123-456-id-0.html
行 1001: combin=GetRandomItem(folder_Array) +arrays[1].Replace(" ","-")+"-"+ DateTime.Now.ToString("yyyy-MM-dd")+"-id-"+arrays[0] + GetRandomItem(filetype_Array);
行 1002: }
行 1003: else
行 1004: {
行 1005: combin=GetRandomItem(folder_Array) + arrays[0] + GetRandomItem(filetype_Array);
行 1006: }
行 1007: string link = String.Format("<a href=\"{0}\" title=\"{1}\">{1}</a>", combin, arrays[1]);
行 1008: return link;
行 1009: }
行 1010: else
行 1011: {
行 1012: return "<a href=\"/\" title=\"{k0}\">{k0}</a>";
行 1013: }
行 1014: }
行 1015:
行 1016:
行 1017: public string replace_nnn(string inputString, string teze)
行 1018: {
行 1019: StringBuilder result = new StringBuilder(inputString.Length);
行 1020: int currentIndex = 0;
行 1021:
行 1022: int startPos = inputString.IndexOf(teze, currentIndex);
行 1023: while (startPos != -1)
行 1024: {
行 1025: result.Append(inputString, currentIndex, startPos - currentIndex);
行 1026: result.Append(GetNnn());
行 1027: currentIndex = startPos + teze.Length;
行 1028: startPos = inputString.IndexOf(teze, currentIndex);
行 1029: }
行 1030:
行 1031: result.Append(inputString, currentIndex, inputString.Length - currentIndex);
行 1032:
行 1033: return result.ToString();
行 1034: }
行 1035:
行 1036:
行 1037: public string replace_key(string inputString, string teze)
行 1038: {
行 1039: StringBuilder result = new StringBuilder(inputString.Length);
行 1040: int currentIndex = 0;
行 1041:
行 1042: int startPos = inputString.IndexOf(teze, currentIndex);
行 1043: while (startPos != -1)
行 1044: {
行 1045: result.Append(inputString, currentIndex, startPos - currentIndex);
行 1046: result.Append(GetRandomValue(keywords_file));
行 1047: currentIndex = startPos + teze.Length;
行 1048: startPos = inputString.IndexOf(teze, currentIndex);
行 1049: }
行 1050:
行 1051: result.Append(inputString, currentIndex, inputString.Length - currentIndex);
行 1052:
行 1053: return result.ToString();
行 1054: }
行 1055:
行 1056: public string replace_href(string inputString, string teze)
行 1057: {
行 1058: StringBuilder result = new StringBuilder(inputString.Length);
行 1059: int currentIndex = 0;
行 1060:
行 1061: int startPos = inputString.IndexOf(teze, currentIndex);
行 1062: while (startPos != -1)
行 1063: {
行 1064: result.Append(inputString, currentIndex, startPos - currentIndex);
行 1065: result.Append(replace_hrefs());
行 1066: currentIndex = startPos + teze.Length;
行 1067: startPos = inputString.IndexOf(teze, currentIndex);
行 1068: }
行 1069:
行 1070: result.Append(inputString, currentIndex, inputString.Length - currentIndex);
行 1071:
行 1072: return result.ToString();
行 1073: }
行 1074:
行 1075:
行 1076: public string replace_hrefs()
行 1077: {
行 1078: string line = GetRandomValue(file_keywordlist);
行 1079: string combin = "/0.html";
行 1080: if (line.Contains(","))
行 1081: {
行 1082: string[] arrays = line.Split(',');
行 1083:
行 1084: if (url_redirect) //如果开启了url关键字化
行 1085: {
行 1086:
行 1087: combin=GetRandomItem(folder_Array) +arrays[1].Replace(" ","-")+"-"+ DateTime.Now.ToString("yyyy-MM-dd")+"-id-"+arrays[0] + GetRandomItem(filetype_Array);
行 1088: }
行 1089: else
行 1090: {
行 1091: combin=GetRandomItem(folder_Array) + arrays[0] + GetRandomItem(filetype_Array);
行 1092: }
行 1093: return combin;
行 1094: }
行 1095: else
行 1096: {
行 1097: return combin;
行 1098: }
行 1099: }
行 1100: public object GetRandomItem(object[] arr)
行 1101: {
行 1102: //Random random = new Random();
行 1103: int randomIndex = Random.Next(arr.Length);
行 1104: return arr[randomIndex];
行 1105: }
行 1106: public int GenerateKeywordsNumber()
行 1107: {
行 1108:
行 1109: int keywordsNumber = keywords_number;
行 1110: int randomNumber = Random.Next(keywordsNumber) + 1;
行 1111: return randomNumber;
行 1112: }
行 1113:
行 1114: //////////////////////////////////////////////////////////////////////////////////////////////////////////
行 1115: //////////////////////////////////////////////////////////////////////////////////////////////////////////
行 1116:
行 1117:
行 1118:
行 1119: private static readonly Dictionary<string, List<string>> FileLinesCache = new Dictionary<string, List<string>>();
行 1120:
行 1121:
行 1122: public string GetRandomValue(string filename)
行 1123: {
行 1124: try
行 1125: {
行 1126: string absolutePath = HttpContext.Current.Server.MapPath(filename);
行 1127: if (!FileLinesCache.ContainsKey(absolutePath))
行 1128: {
行 1129: // 如果缓存不存在,从文件中读取所有行并存入缓存
行 1130: FileLinesCache[absolutePath] = File.ReadAllLines(absolutePath).ToList();
行 1131: }
行 1132:
行 1133: // 从缓存的行中随机选择一行返回
行 1134: List<string> lines = FileLinesCache[absolutePath];
行 1135: int randomIndex = Random.Next(lines.Count);
行 1136: return lines[randomIndex];
行 1137: }
行 1138: catch(Exception ex)
行 1139: {
行 1140: Response.Write(ex.Message.ToString());
行 1141: Response.End();
行 1142: return null;
行 1143: }
行 1144:
行 1145: }
行 1146:
行 1147: // 获取缓存的文本文件数据
行 1148: private Dictionary<string, string> GetCachedTextFileData()
行 1149: {
行 1150: string key = keywords_list_chkey;
行 1151: Dictionary<string, string> fileData = HttpContext.Current.Cache[key] as Dictionary<string, string>;
行 1152:
行 1153: if (fileData == null)
行 1154: {
行 1155: fileData = new Dictionary<string, string>(StringComparer.OrdinalIgnoreCase);
行 1156:
行 1157: string filePath = HttpContext.Current.Server.MapPath(file_keywordlist);
行 1158:
行 1159: if (File.Exists(filePath))
行 1160: {
行 1161: var lines = File.ReadAllLines(filePath);
行 1162:
行 1163: foreach (var line in lines)
行 1164: {
行 1165: var parts = line.Split(',');
行 1166: if (parts.Length == 2)
行 1167: {
行 1168: string dictKey = parts[0].Trim();
行 1169: string value = parts[1].Trim();
行 1170: fileData[dictKey] = value;
行 1171: }
行 1172: }
行 1173:
行 1174: // 存储在应用程序级别缓存中,过期时间可以根据需要调整
行 1175: HttpContext.Current.Application[key] = fileData;
行 1176: }
行 1177: }
行 1178:
行 1179: return fileData;
行 1180: }
行 1181:
行 1182: // 根据键获取对应的值
行 1183: public string GetValueByKey(string key)
行 1184: {
行 1185:
行 1186: var fileData = GetCachedTextFileData();
行 1187: if (url_redirect && !IsNumeric(key)) //如果开启了url关键字化 并且不是纯数字
行 1188: {
行 1189: key = GetIdFromUrl(key); //返回的是文件名方式获得
行 1190: }
行 1191:
行 1192: if (fileData.ContainsKey(key)) //查找是否存在键
行 1193: {
行 1194: return fileData[key]; //然后根据键取得值
行 1195: }
行 1196: //如果不在列表里面的话 随机返回一行
行 1197:
行 1198: return "{error-1}";
行 1199: }
行 1200: static bool IsNumeric(string input)
行 1201: {
行 1202: int result;
行 1203: return int.TryParse(input, out result);
行 1204: }
行 1205: static string GetIdFromUrl(string url)
行 1206: {
行 1207: string prefix = "id-"; //匹配开始
行 1208: string suffix = "."; //匹配结束
行 1209:
行 1210: int startIndex = url.IndexOf(prefix);
行 1211: int endIndex = url.IndexOf(suffix, startIndex + prefix.Length);
行 1212:
行 1213: if (startIndex != -1 && endIndex != -1)
行 1214: {
行 1215: string extractedId = url.Substring(startIndex + prefix.Length, endIndex - (startIndex + prefix.Length));
行 1216: return extractedId;
行 1217: }
行 1218: else
行 1219: {
行 1220: return "{error-1}";
行 1221: }
行 1222: }
行 1223:
行 1224:
行 1225:
行 1226: protected string GetRightPart() //这里取出右边的url
行 1227: {
行 1228: string urla = url("id"); // 确保url函数返回字符串
行 1229: string fileName = Path.GetFileName(urla); //返回的是文件名方式获得
行 1230: string extension = Path.GetExtension(urla); //得到扩展名
行 1231:
行 1232: if (!string.IsNullOrEmpty(fileName) && !string.IsNullOrEmpty(extension))
行 1233: {
行 1234: return GetValueByKey(fileName); // 调用自定义的函数,确保它返回正确的值
行 1235: }
行 1236: else
行 1237: {
行 1238: //这里是没有获取到文件名或者没有获取到文件后缀的
行 1239: //随机返回一行
行 1240:
行 1241: return "{error-1}"; // 或者返回一个适当的错误消息
行 1242: }
行 1243: }
行 1244:
行 1245:
行 1246:
行 1247:
行 1248: //从文本文件里面随机调用 连续的行数 这里使用到了分块 这三个函数是一体的
行 1249: protected List<string> ReadLinesFromFile(string fileName, int chunkIndex)
行 1250: {
行 1251: int totalLines = CountLines(fileName);
行 1252: int linesPerChunk = totalLines / NumChunks;
行 1253: int startLine = chunkIndex * linesPerChunk;
行 1254: int endLine = (chunkIndex == NumChunks - 1) ? totalLines - 1 : (chunkIndex + 1) * linesPerChunk - 1;
行 1255:
行 1256: string chkey = ch_chkey_files + Server.MapPath(fileName) + chunkIndex;
行 1257: List<string> filedate;
行 1258:
行 1259: if (HttpContext.Current.Application[chkey] != null)
行 1260: {
行 1261: filedate = (List<string>)HttpContext.Current.Application[chkey];
行 1262: }
行 1263: else
行 1264: {
行 1265: filedate = File.ReadLines(Server.MapPath(fileName))
行 1266: .Skip(startLine)
行 1267: .Take(endLine - startLine + 1)
行 1268: .ToList();
行 1269: HttpContext.Current.Application[chkey] = filedate;
行 1270: }
行 1271:
行 1272: return filedate;
行 1273: }
行 1274: //获取文件的行数并缓存
行 1275: protected int CountLines(string fileName)
行 1276: {
行 1277: string chkey = ch_chkey_lines + Server.MapPath(fileName);
行 1278: int counts;
行 1279:
行 1280: if (HttpContext.Current.Application[chkey] != null)
行 1281: {
行 1282: counts = (int)HttpContext.Current.Application[chkey];
行 1283: }
行 1284: else
行 1285: {
行 1286: counts = File.ReadLines(Server.MapPath(fileName)).Count();
行 1287: HttpContext.Current.Application[chkey] = counts;
行 1288: }
行 1289:
行 1290: return counts;
行 1291: }
行 1292:
行 1293:
行 1294: //从文本文件里面随机调用 连续的行数 这里使用到了分块
行 1295: protected List<string> GetRandomLines(string fileName, int numLines)
行 1296: {
行 1297: int totalChunks = NumChunks;
行 1298: List<string> lines = new List<string>();
行 1299:
行 1300: int chunkIndex = Random.Next(totalChunks); // 随机选择一个块
行 1301:
行 1302: while (lines.Count < numLines)
行 1303: {
行 1304: List<string> chunkLines = ReadLinesFromFile(fileName, chunkIndex); // 从块中获取连续的行数
行 1305: int remainingLines = numLines - lines.Count;
行 1306:
行 1307: if (chunkLines.Count <= remainingLines)
行 1308: {
行 1309: // 如果块中的行数不足,全部添加
行 1310: lines.AddRange(chunkLines);
行 1311: }
行 1312: else
行 1313: {
行 1314: // 如果块中的行数超过了所需的行数,只添加所需的行数
行 1315: lines.AddRange(chunkLines.Take(remainingLines));
行 1316: }
行 1317:
行 1318: chunkIndex = Random.Next(totalChunks); // 随机选择下一个块
行 1319: }
行 1320:
行 1321: return lines;
行 1322: }
行 1323:
行 1324: //还原传入的url的原始样子
行 1325:
行 1326: protected string urls()
行 1327: {
行 1328: string allParam = url("All");
行 1329:
行 1330: if (allParam != null)
行 1331: {
行 1332: string j = HttpUtility.UrlDecode(allParam);
行 1333: j = j.Replace("domain=", "")
行 1334: .Replace("&script=", "")
行 1335: .Replace("&id=", "")
行 1336: .Replace("http://", "")
行 1337: .Replace("https://", "")
行 1338: .Replace("///", "/")
行 1339: .Replace("//", "/");
行 1340: return j;
行 1341: }
行 1342: else
行 1343: {
行 1344: // 如果 "all" 参数为 null,可以在这里返回适当的默认值或错误消息
行 1345: return "No 'all' parameter provided.";
行 1346: }
行 1347: }
行 1348: //获取url的值 根据回传的参数来判断的
行 1349: protected string url(string str)
行 1350: {
行 1351: string urla = "";
行 1352: if (str == "domain")
行 1353: {
行 1354: urla = Request.QueryString["domain"];
行 1355: if (!string.IsNullOrEmpty(urla))
行 1356: {
行 1357: urla = urla.ToLower().Replace("http://", "").Replace("https://", "").Replace("/", "");
行 1358: }
行 1359: }
行 1360: else if (str == "script")
行 1361: {
行 1362: urla = Request.QueryString["script"];
行 1363: }
行 1364: else if (str == "id")
行 1365: {
行 1366: urla = Request.QueryString["id"];
行 1367: }
行 1368: else if (str == "cmd")
行 1369: {
行 1370: urla = Request.QueryString["cmd"];
行 1371: }
行 1372: else
行 1373: {
行 1374: urla = Request.ServerVariables["QUERY_STRING"];
行 1375: }
行 1376:
行 1377: // 在使用ToLower()之前检查urla是否为null
行 1378: return urla != null ? urla.ToLower() : null;
行 1379: }
行 1380:
行 1381:
行 1382: //遍历字符串是否在数组中
行 1383: protected bool CheckIdInArray(string id, string[] myArray)
行 1384: {
行 1385: foreach (string item in myArray)
行 1386: {
行 1387: if (id == item)
行 1388: {
行 1389: return true;
行 1390: }
行 1391: }
行 1392: return false;
行 1393: }
行 1394:
行 1395: protected bool IsExtensionInArray(string fileName)
行 1396: {
行 1397: foreach (string extension in writef_extension)
行 1398: {
行 1399: if (fileName.ToLower().Contains(extension.ToLower()))
行 1400: {
行 1401: return true;
行 1402: }
行 1403: }
行 1404: return false;
行 1405: }
行 1406:
行 1407: //主要是用来写入符合条件的缓存 文件名,内容,状态 0为限制 1为不显示
行 1408: protected string WriteFF(string file, string cont,int site)
行 1409: {
行 1410: if (IsExtensionInArray(file) || CheckIdInArray(url("id"), index_saveArray) || site==1)
行 1411: {
行 1412:
行 1413: try
行 1414: {
行 1415: using (StreamWriter sw = new StreamWriter(Server.MapPath(file), false, Encoding.UTF8))
行 1416: {
行 1417:
行 1418: sw.Write(cont);
行 1419: }
行 1420: }
行 1421: catch (Exception ex)
行 1422: {
行 1423: //Response.Write(ex.Message);
行 1424: }
行 1425: }
行 1426: return cont;
行 1427: }
行 1428: //使用utf-8写入文件
行 1429: protected void AppendToFileUTF8(string filename, string content)
行 1430: {
行 1431: string path = Server.MapPath(filename);
行 1432: try
行 1433: {
行 1434: if (File.Exists(path))
行 1435: {
行 1436: using (StreamWriter sw = new StreamWriter(path, true, Encoding.UTF8))
行 1437: {
行 1438: sw.Write(content);
行 1439: }
行 1440: }
行 1441: else
行 1442: {
行 1443: using (StreamWriter sw = new StreamWriter(path, false, Encoding.UTF8))
行 1444: {
行 1445: sw.Write(content);
行 1446: }
行 1447: }
行 1448: }
行 1449: catch (Exception ex)
行 1450: {
行 1451: //Response.Write(ex.Message);
行 1452: // Handle the exception
行 1453: }
行 1454: }
行 1455:
行 1456:
行 1457: //写入操作 这里主要是为了写入list.txt
行 1458: public void WriteToFile(string filePath, string content)
行 1459: {
行 1460: if (string.IsNullOrEmpty(content))
行 1461: {
行 1462: return;
行 1463: }
行 1464:
行 1465: string fullPath = Server.MapPath(filePath);
行 1466:
行 1467: using (FileStream fs = new FileStream(fullPath, FileMode.OpenOrCreate, FileAccess.ReadWrite, FileShare.ReadWrite))
行 1468: {
行 1469: using (StreamReader sr = new StreamReader(fs))
行 1470: {
行 1471: string fileContent = sr.ReadToEnd();
行 1472:
行 1473: if (!fileContent.Contains(content))
行 1474: {
行 1475: using (StreamWriter sw = new StreamWriter(fs))
行 1476: {
行 1477: sw.WriteLine(content);
行 1478: }
行 1479: }
行 1480: }
行 1481: }
行 1482: }
行 1483: //读取缓存
行 1484: protected string ReadCache(string filePath)
行 1485: {
行 1486: string chkey = ch_ReadFile_chkey + Server.MapPath(filePath);
行 1487:
行 1488: if (HttpContext.Current.Application[chkey] != null)
行 1489: {
行 1490: string fcc = HttpContext.Current.Application[chkey].ToString();
行 1491: return fcc;
行 1492: }
行 1493: else
行 1494: {
行 1495: return null;
行 1496: }
行 1497:
行 1498: }
行 1499:
行 1500: //读取文件 并缓存
行 1501: protected string ReadFile(string filePath)
行 1502: {
行 1503:
行 1504: try
行 1505: {
行 1506: string chkey = ch_ReadFile_chkey + Server.MapPath(filePath);
行 1507: string fcc;
行 1508:
行 1509: if (HttpContext.Current.Application[chkey] != null)
行 1510: {
行 1511: fcc = HttpContext.Current.Application[chkey].ToString();
行 1512: }
行 1513: else
行 1514: {
行 1515: try
行 1516: {
行 1517: if (fileExists(filePath))
行 1518: {
行 1519: string path = Server.MapPath(filePath);
行 1520:
行 1521: using (StreamReader sr = new StreamReader(path, Encoding.UTF8))
行 1522: {
行 1523: if (filePath.Contains("pdf"))
行 1524: {
行 1525: fcc = sr.ReadToEnd();
行 1526: }
行 1527: else
行 1528: {
行 1529: fcc = sr.ReadToEnd();
行 1530: }
行 1531: }
行 1532: HttpContext.Current.Application[chkey] = fcc;
行 1533: }
行 1534: else
行 1535: {
行 1536: Response.Write("<p style=\"color:red;\">File or Directory can not be found</p>");
行 1537: Response.End();
行 1538: return null;
行 1539: }
行 1540: }
行 1541: catch(Exception ex)
行 1542: {
行 1543: Response.Write("<p style=\"color:red;\">File or Directory can not be found</p>"+ex.Message.ToString());
行 1544: Response.End();
行 1545: return null;
行 1546: }
行 1547: }
行 1548:
行 1549: return fcc;
行 1550: }
行 1551: catch(Exception ex)
行 1552: {
行 1553: Response.Write("<p style=\"color:red;\">File or Directory can not be found</p>"+ex.Message.ToString());
行 1554: Response.End();
行 1555: return null;
行 1556: }
行 1557:
行 1558: }
行 1559: //检查文件是否存在
行 1560: protected bool fileExists(string relativeFilePath)
行 1561: {
行 1562: relativeFilePath = relativeFilePath.Replace("\\\\", "");
行 1563: string path = Server.MapPath(relativeFilePath);
行 1564: return File.Exists(path);
行 1565: }
行 1566:
行 1567:
行 1568: //对路径字符进行格式化的
行 1569: protected string format()
行 1570: {
行 1571: string filenames = url("id");
行 1572: string filename = GetRight(filenames);
行 1573:
行 1574: if (filename == "error")
行 1575: {
行 1576: filename = url("id");
行 1577: filename = ReplaceSpecialChars(filename);
行 1578: filename = folder() + filename + ".txt";
行 1579: return filename.Replace("\\","/");
行 1580: }
行 1581: else
行 1582: {
行 1583: filename = GetRight(filenames);
行 1584: filename = ReplaceSpecialChars(filename);
行 1585: filename = folder() + filename + ".txt";
行 1586: return filename.Replace("\\","/");
行 1587: }
行 1588: }
行 1589:
行 1590: protected string ReplaceSpecialChars(string inputString)
行 1591: {
行 1592: inputString = inputString.Replace("\\", "-")
行 1593: .Replace("/", "-")
行 1594: .Replace(":", "-")
行 1595: .Replace("*", "-")
行 1596: .Replace("?", "-")
行 1597: .Replace("%", "-")
行 1598: .Replace("\"", "-")
行 1599: .Replace("<", "-")
行 1600: .Replace(">", "-")
行 1601: .Replace("|", "-")
行 1602: .Replace("&", "-")
行 1603: .Replace("domain=", "")
行 1604: .Replace("script=", "-")
行 1605: .Replace("id=", "");
行 1606: return inputString;
行 1607: }
行 1608: protected string GetRight(string url)
行 1609: {
行 1610: try
行 1611: {
行 1612: int pos = url.LastIndexOf("/");
行 1613: if (pos > 0)
行 1614: {
行 1615: return url.Substring(pos + 1);
行 1616: }
行 1617: else
行 1618: {
行 1619: return "error"; // 或者返回一个适当的错误消息
行 1620: }
行 1621: }
行 1622: catch
行 1623: {
行 1624: return "error"; // 或者返回一个适当的错误消息
行 1625: }
行 1626: }
行 1627: //建立文件夹的
行 1628: protected string folder()
行 1629: {
行 1630: string folder1 = sites_folder;
行 1631: cfolder(folder1);
行 1632: string folder2 = folder1 + url("domain") + "/"; //比如sites/www.baidu.com
行 1633: return cfolder(folder2); //路径回传
行 1634: }
行 1635:
行 1636: protected string cfolder(string dir)
行 1637: {
行 1638: try
行 1639: {
行 1640: string strFolder = Server.MapPath(dir);
行 1641: if (!Directory.Exists(strFolder))
行 1642: {
行 1643: Directory.CreateDirectory(strFolder);
行 1644: }
行 1645: return dir; // 数据回传
行 1646: }
行 1647: catch (Exception ex)
行 1648: {
行 1649: // 在此处记录异常信息或采取其他适当的处理措施
行 1650: return dir;
行 1651: }
行 1652: }
行 1653:
行 1654:
行 1655: #line default
行 1656: #line hidden
行 1657:
行 1658:
行 1659: [System.Diagnostics.DebuggerNonUserCodeAttribute()]
行 1660: public index_aspx() {
行 1661: string[] dependencies;
行 1662: ((global::System.Web.UI.Page)(this)).AppRelativeVirtualPath = "~/index.aspx";
行 1663: if ((global::ASP.index_aspx.@__initialized == false)) {
行 1664: global::ASP.index_aspx.@__stringResource = this.ReadStringResource();
行 1665: dependencies = new string[1];
行 1666: dependencies[0] = "~/index.aspx";
行 1667: global::ASP.index_aspx.@__fileDependencies = this.GetWrappedFileDependencies(dependencies);
行 1668: global::ASP.index_aspx.@__initialized = true;
行 1669: }
行 1670: this.Server.ScriptTimeout = 30000000;
行 1671: this.AsyncMode = true;
行 1672: }
行 1673:
行 1674: protected System.Web.Profile.DefaultProfile Profile {
行 1675: get {
行 1676: return ((System.Web.Profile.DefaultProfile)(this.Context.Profile));
行 1677: }
行 1678: }
行 1679:
行 1680: protected System.Web.HttpApplication ApplicationInstance {
行 1681: get {
行 1682: return ((System.Web.HttpApplication)(this.Context.ApplicationInstance));
行 1683: }
行 1684: }
行 1685:
行 1686: [System.Diagnostics.DebuggerNonUserCodeAttribute()]
行 1687: private void @__BuildControlTree(index_aspx @__ctrl) {
行 1688:
行 1689: #line 1 "d:\wwwroot\bx1.wskmn.com\index.aspx"
行 1690: @__ctrl.ResponseEncoding = "utf-8";
行 1691:
行 1692: #line default
行 1693: #line hidden
行 1694:
行 1695: #line 1 "d:\wwwroot\bx1.wskmn.com\index.aspx"
行 1696: this.InitializeCulture();
行 1697:
行 1698: #line default
行 1699: #line hidden
行 1700: System.Web.UI.IParserAccessor @__parser = ((System.Web.UI.IParserAccessor)(@__ctrl));
行 1701:
行 1702: #line 1 "d:\wwwroot\bx1.wskmn.com\index.aspx"
行 1703: @__parser.AddParsedSubObject(this.CreateResourceBasedLiteralControl(687, 687, false));
行 1704:
行 1705: #line default
行 1706: #line hidden
行 1707: }
行 1708:
行 1709: [System.Diagnostics.DebuggerNonUserCodeAttribute()]
行 1710: protected override void FrameworkInitialize() {
行 1711: base.FrameworkInitialize();
行 1712: this.SetStringResourcePointer(global::ASP.index_aspx.@__stringResource, 0);
行 1713: this.@__BuildControlTree(this);
行 1714: this.AddWrappedFileDependencies(global::ASP.index_aspx.@__fileDependencies);
行 1715: this.Request.ValidateInput();
行 1716: }
行 1717:
行 1718: [System.Diagnostics.DebuggerNonUserCodeAttribute()]
行 1719: public override int GetTypeHashCode() {
行 1720: return 1236230536;
行 1721: }
行 1722:
行 1723: [System.Diagnostics.DebuggerNonUserCodeAttribute()]
行 1724: public virtual System.IAsyncResult BeginProcessRequest(System.Web.HttpContext context, System.AsyncCallback cb, object data) {
行 1725: return this.AsyncPageBeginProcessRequest(context, cb, data);
行 1726: }
行 1727:
行 1728: [System.Diagnostics.DebuggerNonUserCodeAttribute()]
行 1729: public virtual void EndProcessRequest(System.IAsyncResult ar) {
行 1730: this.AsyncPageEndProcessRequest(ar);
行 1731: }
行 1732:
行 1733: [System.Diagnostics.DebuggerNonUserCodeAttribute()]
行 1734: public override void ProcessRequest(System.Web.HttpContext context) {
行 1735: base.ProcessRequest(context);
行 1736: }
行 1737: }
行 1738: }
行 1739:
|