B2B网络软件

标题: AIWROK软件脚本GET下载文件并检测0KB工具 [打印本页]

作者: YYPOST群发软件    时间: 2 小时前
标题: AIWROK软件脚本GET下载文件并检测0KB工具

AIWROK软件脚本GET下载文件并检测0KB工具
AIWROK软件脚本GET下载文件并检测0KB工具 B2B网络软件

  1. // ============================================================================
  2. // GET下载文件并检测0KB工具
  3. // AIWROK官方群: 711841924,苹果群,528816639
  4. // ============================================================================
  5. // 功能说明:
  6. // 1. downloadFile() - GET请求下载图片文件,自动检测Content-Type和0KB空文件
  7. // 2. uploadFile() - POST multipart/form-data方式上传文件到服务器
  8. // 3. downloadWithResume() - 支持断点续传的下载功能,可从中断处继续下载
  9. // 4. batchDownload() - 批量下载管理器,统计成功/失败数量和总文件大小
  10. //
  11. // 使用场景:
  12. // - 图片资源批量下载和验证
  13. // - 大文件断点续传下载
  14. // - 文件上传到远程服务器
  15. // - 自动化测试中的文件操作验证
  16. // ============================================================================

  17. /**
  18. * 检测是否为有效的图片Content-Type
  19. * @param {String} contentType - HTTP响应的Content-Type头部值
  20. * @returns {Boolean} 是否为有效的图片类型(png/jpeg/jpg/gif/webp)
  21. */
  22. function isValidImageContentType(contentType) {
  23.     if (!contentType) return false;
  24.     contentType = contentType.toLowerCase();
  25.     return contentType.indexOf("image/png") !== -1 ||
  26.            contentType.indexOf("image/jpeg") !== -1 ||
  27.            contentType.indexOf("image/jpg") !== -1 ||
  28.            contentType.indexOf("image/gif") !== -1 ||
  29.            contentType.indexOf("image/webp") !== -1;
  30. }

  31. /**
  32. * GET请求下载文件并检测0KB和是否为有效图片
  33. *
  34. * 工作流程:
  35. * 1. 发起GET请求获取文件内容
  36. * 2. 检查Content-Type是否为有效图片格式
  37. * 3. 将响应数据写入本地文件
  38. * 4. 验证文件大小,拒绝0KB空文件
  39. *
  40. * @param {String} url - 下载地址(必须是有效的图片URL)
  41. * @param {String} savePath - 本地保存路径(如/sdcard/Download/test.png)
  42. * @returns {Boolean} 是否成功下载且文件有效(true=成功,false=失败)
  43. *
  44. * 示例:
  45. * var result = downloadFile("https://example.com/image.png", "/sdcard/test.png");
  46. * if (result) {
  47. *     printl("下载成功!");
  48. * }
  49. */
  50. function downloadFile(url, savePath) {
  51.     var http = new okHttp();
  52.     var response = http.get(url);
  53.    
  54.     var contentType = http.getResponseHeaders();
  55.     printl("Content-Type: " + contentType);
  56.    
  57.     if (!isValidImageContentType(contentType)) {
  58.         printl("⚠️ 不是有效的图片类型: " + contentType);
  59.         return false;
  60.     }
  61.    
  62.     var file = new java.io.File(savePath);
  63.     var fos = new java.io.FileOutputStream(file);
  64.     fos.write(response.getBytes());
  65.     fos.close();
  66.    
  67.     var fileSize = file.length();
  68.     printl("文件大小: " + fileSize + " 字节");
  69.    
  70.     if (fileSize === 0) {
  71.         printl("⚠️ 0KB文件: " + savePath);
  72.         return false;
  73.     }
  74.    
  75.     printl("✅ 文件有效: " + (fileSize / 1024).toFixed(2) + " KB");
  76.     return true;
  77. }

  78. // 单独测试0KB检测 - 创建一个0KB的空文件
  79. printl("=== 测试0KB检测 ===");
  80. var emptyFile = new java.io.File("/sdcard/Download/test_0kb.png");
  81. var fos = new java.io.FileOutputStream(emptyFile);
  82. fos.write(new java.lang.String("").getBytes());
  83. fos.close();
  84. printl("创建了0KB空文件: " + emptyFile.getPath());
  85. printl("空文件大小: " + emptyFile.length() + " 字节");

  86. if (emptyFile.length() === 0) {
  87.     printl("✅ 0KB检测正常!文件确实是0字节");
  88. } else {
  89.     printl("❌ 0KB检测异常!文件不是0字节");
  90. }

  91. printl("");

  92. // 使用示例 - 测试不存在的链接
  93. var url1 = "https://www.baidu.com/img/PCfb_5bf088c07f842ccde3f97245555553ea.png";
  94. var savePath1 = "/sdcard/Download/test_not_exist.png";

  95. printl("=== 测试不存在的链接 ===");
  96. printl("URL: " + url1);
  97. var result1 = downloadFile(url1, savePath1);
  98. printl("结果: " + (result1 ? "成功" : "失败"));

  99. printl("");

  100. // 使用示例 - 测试存在的链接
  101. var url2 = "https://www.baidu.com/img/PCfb_5bf082d29588c07f842ccde3f97243ea.png";
  102. var savePath2 = "/sdcard/Download/test_exist.png";

  103. printl("=== 测试存在的链接 ===");
  104. printl("URL: " + url2);
  105. var result2 = downloadFile(url2, savePath2);
  106. printl("结果: " + (result2 ? "成功" : "失败"));

  107. /**
  108. * POST请求上传文件并验证响应
  109. *
  110. * 工作流程:
  111. * 1. 检查本地文件是否存在
  112. * 2. 构建multipart/form-data格式的HTTP请求体
  113. * 3. 读取文件内容并附加到请求中
  114. * 4. 发送POST请求到服务器
  115. * 5. 根据HTTP状态码判断上传是否成功(2xx为成功)
  116. *
  117. * @param {String} uploadUrl - 上传接口地址(如http://example.com/upload)
  118. * @param {String} filePath - 要上传的本地文件完整路径
  119. * @param {String} fieldName - 表单字段名称(服务端接收文件的字段名)
  120. * @returns {Boolean} 是否成功上传(true=成功,false=失败)
  121. *
  122. * 示例:
  123. * var success = uploadFile(
  124. *     "http://api.example.com/upload",
  125. *     "/sdcard/photo.jpg",
  126. *     "file"
  127. * );
  128. */
  129. function uploadFile(uploadUrl, filePath, fieldName) {
  130.     var http = new okHttp();
  131.     var file = new java.io.File(filePath);
  132.    
  133.     if (!file.exists()) {
  134.         printl("❌ 文件不存在: " + filePath);
  135.         return false;
  136.     }
  137.    
  138.     var fileSize = file.length();
  139.     printl("文件大小: " + (fileSize / 1024).toFixed(2) + " KB");
  140.    
  141.     // 构建multipart请求
  142.     var boundary = "----WebKitFormBoundary7MA4YWxkTrZu0gW";
  143.     var requestBody = "--" + boundary + "\r\n" +
  144.                      "Content-Disposition: form-data; name=\"" + fieldName + "\"; filename=\"" + file.getName() + "\"\r\n" +
  145.                      "Content-Type: application/octet-stream\r\n\r\n";
  146.    
  147.     // 读取文件内容
  148.     var fis = new java.io.FileInputStream(file);
  149.     var buffer = new byte[1024];
  150.     var bytesRead;
  151.     while ((bytesRead = fis.read(buffer)) !== -1) {
  152.         requestBody += new java.lang.String(buffer, 0, bytesRead);
  153.     }
  154.     fis.close();
  155.    
  156.     requestBody += "\r\n--" + boundary + "--\r\n";
  157.    
  158.     // 设置请求头
  159.     http.setHeader("Content-Type", "multipart/form-data; boundary=" + boundary);
  160.    
  161.     var response = http.post(uploadUrl, requestBody);
  162.     var statusCode = http.getStatusCode();
  163.    
  164.     printl("HTTP状态码: " + statusCode);
  165.     printl("响应内容: " + response.substring(0, Math.min(response.length(), 200)));
  166.    
  167.     return statusCode >= 200 && statusCode < 300;
  168. }

  169. /**
  170. * 断点续传下载功能
  171. *
  172. * 工作流程:
  173. * 1. 检查目标文件是否已存在(之前下载的部分)
  174. * 2. 如果存在,获取已下载的大小并设置Range请求头
  175. * 3. 发起带Range头的GET请求(HTTP 206 Partial Content)
  176. * 4. 以追加模式写入文件(保留已有内容)
  177. * 5. 验证最终文件大小
  178. *
  179. * 优势:
  180. * - 网络中断后可从断点继续,无需重新下载
  181. * - 节省流量和时间,特别适合大文件
  182. * - 自动检测和处理部分下载的文件
  183. *
  184. * @param {String} url - 下载地址(服务器需支持Range请求)
  185. * @param {String} savePath - 本地保存路径
  186. * @returns {Boolean} 是否成功下载(true=成功,false=失败)
  187. *
  188. * 示例:
  189. * // 第一次下载中断后,再次调用会继续下载
  190. * downloadWithResume("http://example.com/largefile.zip", "/sdcard/file.zip");
  191. */
  192. function downloadWithResume(url, savePath) {
  193.     var http = new okHttp();
  194.     var file = new java.io.File(savePath);
  195.     var existingSize = 0;
  196.    
  197.     // 检查是否有已下载的部分文件
  198.     if (file.exists()) {
  199.         existingSize = file.length();
  200.         printl("发现已下载部分: " + (existingSize / 1024).toFixed(2) + " KB");
  201.         http.setHeader("Range", "bytes=" + existingSize + "-");
  202.     }
  203.    
  204.     var response = http.get(url);
  205.     var statusCode = http.getStatusCode();
  206.    
  207.     if (statusCode === 206 || (statusCode === 200 && existingSize === 0)) {
  208.         var fos;
  209.         if (existingSize > 0) {
  210.             fos = new java.io.FileOutputStream(file, true); // 追加模式
  211.         } else {
  212.             fos = new java.io.FileOutputStream(file);
  213.         }
  214.         
  215.         fos.write(response.getBytes());
  216.         fos.close();
  217.         
  218.         var finalSize = file.length();
  219.         printl("✅ 下载完成,总大小: " + (finalSize / 1024).toFixed(2) + " KB");
  220.         return true;
  221.     } else {
  222.         printl("❌ 下载失败,状态码: " + statusCode);
  223.         return false;
  224.     }
  225. }

  226. /**
  227. * 批量下载文件并统计结果
  228. *
  229. * 工作流程:
  230. * 1. 遍历下载任务列表
  231. * 2. 对每个任务调用downloadFile()进行下载
  232. * 3. 记录成功/失败数量和累计文件大小
  233. * 4. 输出详细的下载进度和统计信息
  234. * 5. 返回统计结果对象
  235. *
  236. * 特点:
  237. * - 自动统计下载成功率
  238. * - 计算总下载文件大小
  239. * - 提供详细的日志输出
  240. * - 单个文件失败不影响其他文件下载
  241. *
  242. * @param {Array} downloadList - 下载任务数组,每项包含:
  243. *   - url: String - 文件下载地址
  244. *   - path: String - 本地保存路径
  245. * @returns {Object} 统计结果对象:
  246. *   - success: Number - 成功下载的文件数量
  247. *   - failed: Number - 失败的文件数量
  248. *   - totalSize: Number - 所有成功文件的总字节数
  249. *
  250. * 示例:
  251. * var tasks = [
  252. *     {url: "http://example.com/img1.png", path: "/sdcard/img1.png"},
  253. *     {url: "http://example.com/img2.png", path: "/sdcard/img2.png"}
  254. * ];
  255. * var result = batchDownload(tasks);
  256. * printl("成功率: " + (result.success / (result.success + result.failed) * 100) + "%");
  257. */
  258. function batchDownload(downloadList) {
  259.     var successCount = 0;
  260.     var failCount = 0;
  261.     var totalSize = 0;
  262.    
  263.     printl("=== 开始批量下载 ===");
  264.     printl("总共需要下载: " + downloadList.length + " 个文件");
  265.    
  266.     for (var i = 0; i < downloadList.length; i++) {
  267.         var item = downloadList[i];
  268.         printl("\n--- 下载第 " + (i + 1) + " 个文件 ---");
  269.         printl("URL: " + item.url);
  270.         printl("保存路径: " + item.path);
  271.         
  272.         var result = downloadFile(item.url, item.path);
  273.         if (result) {
  274.             successCount++;
  275.             var fileSize = new java.io.File(item.path).length();
  276.             totalSize += fileSize;
  277.         } else {
  278.             failCount++;
  279.         }
  280.     }
  281.    
  282.     printl("\n=== 批量下载完成 ===");
  283.     printl("成功: " + successCount + " 个");
  284.     printl("失败: " + failCount + " 个");
  285.     printl("总大小: " + (totalSize / 1024 / 1024).toFixed(2) + " MB");
  286.    
  287.     return {
  288.         success: successCount,
  289.         failed: failCount,
  290.         totalSize: totalSize
  291.     };
  292. }

  293. // 使用示例 - 批量下载测试
  294. printl("\n=== 批量下载示例 ===");
  295. var downloadTasks = [
  296.     {
  297.         url: "https://www.baidu.com/img/PCfb_5bf082d29588c07f842ccde3f97243ea.png",
  298.         path: "/sdcard/Download/batch_test_1.png"
  299.     },
  300.     {
  301.         url: "https://httpbin.org/image/png",
  302.         path: "/sdcard/Download/batch_test_2.png"
  303.     }
  304. ];

  305. var batchResult = batchDownload(downloadTasks);
  306. printl("批量下载统计: " + JSON.stringify(batchResult));
复制代码







欢迎光临 B2B网络软件 (http://bbs.niubt.cn/) Powered by Discuz! X3.2