AC-CSDN自动展开-CSDN自动评论-去广告

自动展开CSDN博客的内容,无需点击展开 && 自动评论,返还下载积分

  1. // ==UserScript==
  2. // @name AC-CSDN自动展开-CSDN自动评论-去广告
  3. // @author AC 原作:King.Sollyu
  4. // @namespace Sollyu
  5. // @description 自动展开CSDN博客的内容,无需点击展开 && 自动评论,返还下载积分
  6. // @version 3.8
  7. // @require https://code.jquery.com/jquery-1.9.0.min.js
  8. // @include https://download.csdn.net/*
  9. // @include /https?://blog.csdn.net/[^/]+/article/details/.*/
  10. // @include /https?://lib.csdn.net/article/.*/
  11. // @note 2018-08-28 V3.8 新增部分广告的拦截
  12. // @note 2018-05-17 V3.7 再次修复csdn更新导致的问题
  13. // @note 2018-04-30 V3.6 修复csdn网页更新导致的兼容失败问题
  14. // @note 2018-04-06 V3.5 新增支持lib.csdn.net
  15. // @note 2018-03-29 V3.4 深夜修复无法评论的bug,http-->https的问题
  16. // @note 2018-03-25 V3.3 修改名字
  17. // @note 2018-03-24 V3.2 同步-修复https下的链接问题
  18. // @note 2017-12-06 V3.1 与CSDN自动展开一起合并
  19. // @note 2017-09-14 V3.0 修复模式,适配新版的CSDN
  20. // @note 2015-05-20 V2.1 修改弹出位置,修改脚本生效位置,提供简易跳转
  21. // @note 2015-05-20 V2.1 在Chrome中可用
  22. // @note 2013-01-25 V1.0 CSDN自动评论
  23. // @icon https://coding.net/u/zb227/p/zbImg/git/raw/master/img0/icon.jpg
  24. // @run-at document-body
  25. // ==/UserScript==
  26. /*
  27. 需要先跳转到http://download.csdn.net/my/downloads
  28. */
  29. function addStyle(css) { //添加CSS的代码--copy的
  30. var pi = document.createProcessingInstruction(
  31. 'xml-stylesheet',
  32. 'type="text/css" href="data:text/css;utf-8,' + encodeURIComponent(css) + '"'
  33. );
  34. return document.insertBefore(pi, document.documentElement);
  35. }
  36. if(location.host == "download.csdn.net"){
  37. setTimeout(function(){
  38. //多少时间评论一次,单位:秒
  39. var tTime=65;
  40. // 预定义的评论内容,可按照格式自行添加,注意最后一行后面没有逗号
  41. var contentPL=new Array(
  42. "很全面,很好用,谢谢分享.",
  43. "挺不错的资料,谢谢分享.",
  44. "很全,什么都有了,感谢.",
  45. "比相关书籍介绍的详细,顶一个.",
  46. "还行,适合于初级入门的学习.",
  47. "很好的资料,很齐全,谢谢.",
  48. "还可以,就是感觉有点乱.",
  49. "感謝LZ收集,用起來挺方便.",
  50. "感觉还行,只是感觉用着不是特别顺手.",
  51. "很有学习价值的文档,感谢.",
  52. "内容很丰富,最可贵的是资源不需要很多积分.",
  53. "这个真的非常好,借鉴意义蛮大.",
  54. "有不少例子可以参考,目前正需要.",
  55. "下载后不能正常使用.",
  56. "例子简单实用,很有参考价值."
  57. );
  58.  
  59. var queueList = {};
  60.  
  61. // css
  62. var csdnHelperCss=document.createElement('style');
  63. csdnHelperCss.type='text/css';
  64. $(csdnHelperCss).html('.popWindow{position:fixed;z-index:10000;top:100px;right:650px;}.popWindow>span{display:block;text-align:left;color:cyan;text-shadow:0 0 2px white;background-color:#555;box-shadow:-1px -1px 4px gray;margin:5px 0 0 0;padding:00 6px 0 6px;cursor:pointer;font-size: 13px;}');
  65.  
  66. $('body').prepend(csdnHelperCss);
  67. $('body').prepend('<div class="popWindow"></div>');
  68.  
  69. //将本页待评论资源自动加入评论队列
  70. $("li .flag a:not([href^='javascript'])").each(function(){
  71. if(this.tagName!="A")
  72. return;
  73. var reg=/\/([_a-zA-Z0-9]+)\/([0-9]+)#/;
  74. var src=$(this).attr('href').match(reg);
  75. addQueue(src[1],src[2],(new Date()).getTime());
  76. $(this).parent().html("已加入评论队列");
  77. });
  78. // 若待评论数大于0则提示用户滞留在本窗口
  79. console.debug("本次任务总数--->"+getJsonLength(queueList));
  80. if(getJsonLength(queueList) > 0){
  81. popWindow("待评论任务数:"+getJsonLength(queueList),0);
  82. popWindow("请保持在本界面,以便进行评价",6000);
  83. setInterval(searchToPost, tTime*1000);
  84. searchToPost();
  85. }else{
  86. if(location.href=='https://download.csdn.net/my/downloads'){
  87. popWindow("恭喜你,暂时没有需要评论的下载项",0);
  88. }else{
  89. popWindow("自动回复请点击跳转到<BR><center><a href=https://download.csdn.net/my/downloads><b><font color=Green>我的下载</font></b></a>查看</center>",0);
  90. }
  91. }
  92.  
  93. function getJsonLength(jsonData){
  94. var jsonLength = 0;
  95. for(var item in jsonData){
  96. jsonLength++;
  97. }
  98. return jsonLength;
  99. }
  100.  
  101. // 添加评论队列
  102. function addQueue(owner,sourceID,stamp){
  103. queueList[stamp] = {owner, sourceID};
  104. console.log(stamp, queueList[stamp]);
  105. popWindow('已添加到任务队列,['+owner+','+sourceID+']',2000);
  106. }
  107. // 显示消息
  108. function popWindow(str,delayTime){
  109. var obj = $('.popWindow').append('<span>'+str+'</span>').children().last();
  110. if(delayTime>0)
  111. obj.delay(delayTime).hide(1500,function(){$(this).remove();});
  112. }
  113.  
  114. function searchToPost(){
  115. // 查询有没有可以评论的资源
  116. for (var stamp in queueList){
  117. var res = queueList[stamp];
  118. post(res['owner'], res['sourceID'], stamp);
  119. break;
  120. }
  121. }
  122. // 发送评论
  123. function post(owner, sourceID, stamp){
  124. $.ajax({
  125. type:"get",
  126. url:"https://download.csdn.net/index.php/comment/post_comment",
  127. headers:{
  128. "Referer":"https://download.csdn.net/download/"+owner+"/"+sourceID,
  129. "Content-type":"application/x-www-form-urlencoded; charset=UTF-8",
  130. "X-Requested-With":"XMLHttpRequest"
  131. },
  132. data:{
  133. "content":contentPL[Math.round(Math.random()*(contentPL.length-1))],
  134. "jsonpcallback":"jQuery1111028717768093608154_"+(new Date()).getTime(),
  135. "rating":"5",
  136. "sourceid":sourceID,
  137. "t":(new Date()).getTime()
  138. },
  139. success:function(res){
  140. var index = res.indexOf("({");
  141. var data = eval(res.substr(index));
  142. var resMsg="----";
  143. console.log(data.succ);
  144. if(data.succ>0){
  145. delete queueList[stamp];
  146. resMsg = '任务成功! 已评论['+owner+','+sourceID+']<br/>-----剩余任务数:' + getJsonLength(queueList);
  147. console.debug(resMsg);
  148. popWindow(resMsg,(tTime+20)*1000);
  149. $('.popWindow').children().each(
  150. function(){
  151. if(this.innerHTML.indexOf("待评论任务数")>=0)
  152. this.innerHTML=("待评论任务数:"+getJsonLength(queueList));
  153. });
  154. }
  155. else{
  156. resMsg = '任务评论失败['+owner+','+sourceID+']'+"<br/>----原因:"+data.msg;
  157. console.debug(resMsg.replace(/<br\/>/,""));
  158. popWindow(resMsg,60000);
  159. if(data.msg.indexOf("您已经发表过评论")>=0){
  160. delete queueList[stamp];
  161. }
  162. }
  163. }
  164. });
  165. }
  166. }, 1000);
  167. }else if(location.host == "blog.csdn.net" || location.host == "lib.csdn.net"){
  168. // 1. 自动展开搜索的内容主体
  169. var acCSDNT = setInterval(function(){
  170. if(document.querySelector("div") != null){
  171. clearInterval(acCSDNT);
  172. // 处理lib.csdn.net
  173. addStyle(".divtexts{height:auto !important;max-height:unset !important;}");
  174. addStyle(".divcodes,.divmark{display:none !important;}");
  175. // 处理blog.csdn.net
  176. addStyle(".article_content{height:auto !important;max-height:unset !important;}");
  177. addStyle(".hide-article-box{display:none !important;}");
  178. }
  179. }, 100);
  180. // 2. 移除多余的广告内容
  181. addStyle(".recommend-ad-box{display:none;}body>div[id*='kp_box_']{display:none;}");
  182. }