微信公衆平臺:前端批量下載語音並重命名文件

1、需求的產生

   由於公衆號須要根據用戶發來的語音信息以用戶爲單位作一些統計,而暫時未接入本身的服務器,因而花了點時間想辦法從前端解決重命名文件和批量下載的問題。javascript

 

2、難點和解決方案

   最早本人準備直接獲取下載按鈕,而後一個簡單的循環click,就能夠批量下載了,可是微信消息管理頁面的下載文件的文件名是一個隨機生成的消息id,並無可讀性,不能和用戶關聯,而前端又不能重命名服務器給出的文件。本想換用按鍵精靈實現,但忽然看到對於音頻文件,還有一個保存爲素材按鈕,而保存爲素材按鈕能夠在前端傳入文件名參數,因而解決方法出現。html

   注:全部腳本只需在chrome的console中到對應頁面執行便可前端

   腳本1:遍歷dom節點,執行點擊保存,輸入文件名,選擇類型等操做。java

   使用:對消息管理頁面,每一頁運行一次,就能夠在素材管理的語音中找到對應文件,文件名爲發消息者微信ID。chrome

 

var start = new Date().getTime();
var len =$(".save_gray").length;
var len3 = $(".remark_name").length;
var userName = '';
var len2 =$('.jsTypeInput').length;
var idx =0;

var  clickChecked = function(len2){
	for (var j = len2-1; j >= 0; j--) {
				console.log(j+":j");
				if ($($('.jsTypeInput')[j]).attr('data-value') == '20') {
					$($('.jsTypeInput')[j]).attr("checked",true);
					$(".js_btn").click();
					$(".closed ").click()
					console.log("break closed");
					break;
					};
				
				
				};
}
var clickBTN = function(idx){
	for (var n = len3-1; n >= 0; n--) {
		console.log(n+":file");
		console.log(idx);
		if ($($(".remark_name")[n]).attr("data-id")==idx) {
			userName = $($(".remark_name")[n]).html();
			console.log(userName);
			$(".jsSaveInput").val(userName);
			len2 =$('.jsTypeInput').length;
			clickChecked(len2);
			console.log("break");
			//break;
			};
		
		
		};
};
for (var i = 0; i < len; i++) {
	idx =$($(".save_gray")[i]).attr('idx');
	$(".save_gray")[i].click();
	clickBTN(idx);
  $('.page_next').click()
};
var end = new Date().getTime();
console.log(end-start);

  

  腳本2:批量下載,由於打開下載窗口會卡,因此作了一點延遲處理。服務器

  使用:進入素材管理界面,每一頁運行腳本,其中 setInterval("dlfn(20)",1500);的21,爲下載的文件個數。由於下載一頁有21個文件,這裏填入21。微信

var m = 0;
var dlfn = function(num){
	if (m==num) {
		window.clearInterval(dl);
		console.log("ok:"+m);
		return;
	};
	console.log("file:"+m);
	$(".download_gray")[m].click();
	m++;
	
	console.log("num:"+num);
	
}
var dl =setInterval("dlfn(21)",1500);

  腳本3:刪除做爲中轉的素材文件(也能夠不刪除)dom

  使用:進入素材管理界面,每一頁運行腳本,其中var dele =setInterval("test(20)",1000);的21爲每一頁刪除的個數。spa

//delete

 	var i = 1;
	var test = function(num){
	 	
	 	if (i==num) {
		window.clearInterval(dele);
		console.log("i:"+i);
		};
		console.log("delete:"+i+",The Operations are an irrevocable");
		i++;
	 	$(".del_gray")[0].click();
		// setTimeout(dlfn(i),1000)
		$(".btn_primary")[1].click();
	 	
	 	
	}
	 

	var dele =setInterval("test(20)",1000);
相關文章
相關標籤/搜索