经常会发现自己的博客被一些垃圾网站抓取,我就在博客进行加密,在访问的时候进行解密,于是爬虫如果不执行js就无法获得内容

本文告诉大家如何加密博客

加密使用把文章内容转换为 Html 之后转换为 base64 然后在加载完成之后把 base64 转换为 html ,这个方式就可以解密文章。

文章的摘要可以不加密,但是文章内容可以使用这方法进行加密。

我使用 Pandoc 转换 html ,推荐使用这个方法。然后把我的文章转换得到的 html 在 base64 转图片 在线解码编码转换得到 base64 。然后把这些代码放在一个 div 内,在页面加载完成就把他转换为 html

我下面会把 js 放在文章最后,大家可以复制去自己博客使用,使用只需要把转换 html 后的代码放在下面的 div 里

  1. <div class="src">
  2. base64
  3. </div>

在页面加载完成就会把 base64 转换为 html 。

这时会发现,打开页面看到的是base64,所以可以先把他隐藏,设置 css 隐藏 src ,请看下面的代码

  1. .src
  2. {
  3. display: none;
  4. }

关键 js 代码

  1. $(document).ready(function()
  2. {
  3. var src = document.getElementsByClassName('src');
  4. for (var i = 0; i < src.length; i++)
  5. {
  6. src[i].innerHTML = utf8to16(base64decode(src[i].innerText));
  7. src[i].style.display = "inline";
  8. }
  9. });

但是很多爬虫还是会执行一下代码,于是他还是可以获得源代码,如何让他无法获得源代码?实际上我还想到另一个方法,先把 html 转换为 二进制, 然后从 0-1000 选一个数作为密码,对他加密。得到的内容转换为 base64 然后放在上面的 div 这样在页面加载完成之后,执行代码,尝试从 0-1000 进行解密,于是就可以获得一个正确 html 这样就可以让js执行时间变长,一般的垃圾网站不会让自己的网站爬这样的文章。

  1. 转换 html

  2. html 转 二进制

  3. 随机从 0-1000 选一个数字

  4. 把 “lindexi” 转二进制,并且把他进行加密,加密的密码就是上面选的数字。

  5. 把 html 转换得到的二进制进行加密

  6. 把上面加密的内容转换为 base64 放在博客里

打开网页时的算法

  1. 获得从 lindexi 转换二进制加密的 base64 从 0-1000 选数字,看哪个数字可以解密得到 “lindexi”

  2. 从上一步拿到的数字对 html 加密后的二进制进行解密

  3. 显示解密后的html

我想的这个算法感觉比较好,但是不会写,不知道有哪位大神可以帮我写。

当然这样也可以做博客加密,就是把随机选一个数字变为自己设置一个字符串。然后打开网页弹出窗口输入字符串解密。

全部代码

  1. var base64EncodeChars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
  2. var base64DecodeChars = new Array(
  3. -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
  4. -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
  5. -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 62, -1, -1, -1, 63,
  6. 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, -1, -1, -1, -1, -1, -1,
  7. -1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14,
  8. 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1, -1, -1, -1, -1,
  9. -1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40,
  10. 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, -1, -1, -1, -1, -1);
  11. function base64encode(str) {
  12. var out, i, len;
  13. var c1, c2, c3;
  14. len = str.length;
  15. i = 0;
  16. out = "";
  17. while(i < len) {
  18. c1 = str.charCodeAt(i++) & 0xff;
  19. if(i == len)
  20. {
  21. out += base64EncodeChars.charAt(c1 >> 2);
  22. out += base64EncodeChars.charAt((c1 & 0x3) << 4);
  23. out += "==";
  24. break;
  25. }
  26. c2 = str.charCodeAt(i++);
  27. if(i == len)
  28. {
  29. out += base64EncodeChars.charAt(c1 >> 2);
  30. out += base64EncodeChars.charAt(((c1 & 0x3)<< 4) | ((c2 & 0xF0) >> 4));
  31. out += base64EncodeChars.charAt((c2 & 0xF) << 2);
  32. out += "=";
  33. break;
  34. }
  35. c3 = str.charCodeAt(i++);
  36. out += base64EncodeChars.charAt(c1 >> 2);
  37. out += base64EncodeChars.charAt(((c1 & 0x3)<< 4) | ((c2 & 0xF0) >> 4));
  38. out += base64EncodeChars.charAt(((c2 & 0xF) << 2) | ((c3 & 0xC0) >>6));
  39. out += base64EncodeChars.charAt(c3 & 0x3F);
  40. }
  41. return out;
  42. }
  43. function base64decode(str) {
  44. var c1, c2, c3, c4;
  45. var i, len, out;
  46. len = str.length;
  47. i = 0;
  48. out = "";
  49. while(i < len) {
  50. /* c1 */
  51. do {
  52. c1 = base64DecodeChars[str.charCodeAt(i++) & 0xff];
  53. } while(i < len && c1 == -1);
  54. if(c1 == -1)
  55. break;
  56. /* c2 */
  57. do {
  58. c2 = base64DecodeChars[str.charCodeAt(i++) & 0xff];
  59. } while(i < len && c2 == -1);
  60. if(c2 == -1)
  61. break;
  62. out += String.fromCharCode((c1 << 2) | ((c2 & 0x30) >> 4));
  63. /* c3 */
  64. do {
  65. c3 = str.charCodeAt(i++) & 0xff;
  66. if(c3 == 61)
  67. return out;
  68. c3 = base64DecodeChars[c3];
  69. } while(i < len && c3 == -1);
  70. if(c3 == -1)
  71. break;
  72. out += String.fromCharCode(((c2 & 0XF) << 4) | ((c3 & 0x3C) >> 2));
  73. /* c4 */
  74. do {
  75. c4 = str.charCodeAt(i++) & 0xff;
  76. if(c4 == 61)
  77. return out;
  78. c4 = base64DecodeChars[c4];
  79. } while(i < len && c4 == -1);
  80. if(c4 == -1)
  81. break;
  82. out += String.fromCharCode(((c3 & 0x03) << 6) | c4);
  83. }
  84. return out;
  85. }
  86. function utf16to8(str) {
  87. var out, i, len, c;
  88. out = "";
  89. len = str.length;
  90. for(i = 0; i < len; i++) {
  91. c = str.charCodeAt(i);
  92. if ((c >= 0x0001) && (c <= 0x007F)) {
  93. out += str.charAt(i);
  94. } else if (c > 0x07FF) {
  95. out += String.fromCharCode(0xE0 | ((c >> 12) & 0x0F));
  96. out += String.fromCharCode(0x80 | ((c >> 6) & 0x3F));
  97. out += String.fromCharCode(0x80 | ((c >> 0) & 0x3F));
  98. } else {
  99. out += String.fromCharCode(0xC0 | ((c >> 6) & 0x1F));
  100. out += String.fromCharCode(0x80 | ((c >> 0) & 0x3F));
  101. }
  102. }
  103. return out;
  104. }
  105. function utf8to16(str) {
  106. var out, i, len, c;
  107. var char2, char3;
  108. out = "";
  109. len = str.length;
  110. i = 0;
  111. while(i < len) {
  112. c = str.charCodeAt(i++);
  113. switch(c >> 4)
  114. {
  115. case 0: case 1: case 2: case 3: case 4: case 5: case 6: case 7:
  116. // 0xxxxxxx
  117. out += str.charAt(i-1);
  118. break;
  119. case 12: case 13:
  120. // 110x xxxx 10xx xxxx
  121. char2 = str.charCodeAt(i++);
  122. out += String.fromCharCode(((c & 0x1F) << 6) | (char2 & 0x3F));
  123. break;
  124. case 14:
  125. // 1110 xxxx 10xx xxxx 10xx xxxx
  126. char2 = str.charCodeAt(i++);
  127. char3 = str.charCodeAt(i++);
  128. out += String.fromCharCode(((c & 0x0F) << 12) |
  129. ((char2 & 0x3F) << 6) |
  130. ((char3 & 0x3F) << 0));
  131. break;
  132. }
  133. }
  134. return out;
  135. }
  136. function CharToHex(str) {
  137. var out, i, len, c, h;
  138. out = "";
  139. len = str.length;
  140. i = 0;
  141. while(i < len)
  142. {
  143. c = str.charCodeAt(i++);
  144. h = c.toString(16);
  145. if(h.length < 2)
  146. h = "0" + h;
  147. out += "\\x" + h + " ";
  148. if(i > 0 && i % 8 == 0)
  149. out += "\r\n";
  150. }
  151. return out;
  152. }
  153. function doEncode() {
  154. var src = document.getElementById('src').value;
  155. document.getElementById('dest').value = base64encode(utf16to8(src));
  156. }
  157. function doDecode() {
  158. var src = document.getElementById('src').value;
  159. var opts = document.getElementById('opt');
  160. if(opts.checked)
  161. {
  162. document.getElementById('dest').value = CharToHex(base64decode(src));
  163. }
  164. else
  165. {
  166. document.getElementById('dest').value = utf8to16(base64decode(src));
  167. }
  168. }
  169. $(document).ready(function()
  170. {
  171. var src = document.getElementsByClassName('src');
  172. for (var i = 0; i < src.length; i++)
  173. {
  174. src[i].innerHTML = utf8to16(base64decode(src[i].innerText));
  175. src[i].style.display = "inline";
  176. }
  177. });

我搭建了自己的博客 https://lindexi.gitee.io/ 欢迎大家访问,里面有很多新的博客。只有在我看到博客写成熟之后才会放在csdn或博客园,但是一旦发布了就不再更新

如果在博客看到有任何不懂的,欢迎交流,我搭建了 dotnet 职业技术学院 欢迎大家加入


本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。欢迎转载、使用、重新发布,但务必保留文章署名林德熙(包含链接:http://blog.csdn.net/lindexi_gd ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请与我联系

jekyll 如何加密博客 防止抓取的更多相关文章

  1. 2019-1-29-jekyll-如何加密博客-防止抓取

    title author date CreateTime categories jekyll 如何加密博客 防止抓取 lindexi 2019-01-29 16:26:17 +0800 2018-2- ...

  2. MWeb 1.4 新功能介绍一:引入文件夹到 MWeb 中管理,支持 Octpress、Jekyll 等静态博客拖拽插入图片和实时预览

    之前在 MWeb 中打开非文档库中的 Markdown 文档,如果文档中有引用到本机图片,是没办法在 MWeb 中显示出来和预览的.这是因为 Apple 规定在 Mac App Store(MAS) ...

  3. 使用 github + jekyll 搭建个人博客

    github + jekyll 本地写markdown,然后push到github,就成了博客 其实我一早就知道这两者可以搭建个人博客,因为本人有个很好的习惯——每天都会去看看一些热门文章,了解行业最 ...

  4. 【环境搭建】使用Jekyll搭建Github博客

    前言 昨天花了差不多一天的时间,使用Jekyll搭建起了一套Github博客,感觉不错,也特将搭建过程记录下来,方便有需要的朋友自行搭建. 搭建步骤 本环境是在Linux环境下搭建完成的 安装前建议使 ...

  5. 使用GitHub Pages+Jekyll搭建个人博客

    GitHub Pages 免费无限容量的站点数据托管工具(国内访问速度较慢),内置Jekyll服务,能将特定名称的代码仓库动态编译为静态网页 Jekyll 基于Ruby的静态网页生成系统,采用模板将M ...

  6. 使用github+jekyll搭建个人博客

    聊聊起初 每次看到大牛们的博客,都会激起一颗一定要搭建自己博客的心,毕竟有着一颗向大牛们看齐的心.但是一直不知道如何下手,从最初的csdn写写博客到在github上建立仓库写代码分享,虽然也能够记录一 ...

  7. 利用jekyll架设个人博客

    jekyll简介 jekyll是一种可以将Markdown或Textile格式文本文件转换成静态网页的工具.利用jekyll编写发布博客的基本过程为: 使用任何一款编辑器编写符合Markdown或Te ...

  8. Jekyll搭建个人博客-拓展版

    关于Jekyll Jekyll 是一个简单的博客形态的静态站点生产机器.它有一个模版目录,其中包含原始文本格式的文档,通过 Markdown (或者 Textile) 以及 Liquid 转化成一个完 ...

  9. 【Python】博客信息爬取-微信消息自动发送

    1.环境安装 python -m pip install --upgrade pip pip install bs4 pip install wxpy pip install lxml 2.博客爬取及 ...

随机推荐

  1. job中shell脚本异常(删除不存在容器),导致job被打断执行的问题 脚本优化方法

    参考:  主要是添加shell的异常处理 https://www.cnblogs.com/AmilyWilly/p/7211168.html?utm_source=itdadao&utm_me ...

  2. 如何解决IntelliJ在打包Maven项目时不打包配置文件

    在pom文件中加上你的配置文件夹目录: <build> <resources> <resource> <directory>src/res</di ...

  3. 工程没有生成lib文件,只生成了dll文件

    解决办法: 在工程上右键 -> 添加 -> 新建项 -> 选"模块定义文件(.def)" -> 随便填写个名字 -> 添加 重新编译编译就可生成.li ...

  4. 【JZOJ3873】【NOIP2014八校联考第4场第2试10.20】乐曲创作(music)

    ujfuiaty 小可可是音乐学院的一名学生,他需要经常创作乐曲完成老师布置的作业. 可是,小可可是一个懒惰的学生.所以,每次完成作业时,他不会重新创作一首新的乐曲,而是去修改上一次创作过的乐曲作为作 ...

  5. 字符串Hash算法比较

    基本概念所谓完美哈希函数,就是指没有冲突的哈希函数,即对任意的 key1 != key2 有h(key1) != h(key2).设定义域为X,值域为Y, n=|X|,m=|Y|,那么肯定有m> ...

  6. Laravel 单设备登录

    https://laravel-china.org/articles/10605/laravel-single-device-login 前几天在 laracasts 看了laravel5.6的新功能 ...

  7. Flask 第二篇

    Flask 中的 Render Redirect HttpResponse 1.Flask中的HTTPResponse 在Flask 中的HttpResponse 在我们看来其实就是直接返回字符串 2 ...

  8. thinkphp5.0中英文切换

    首先来看下它的配置: // 是否开启多语言 'lang_switch_on' => true, //语音列表 'lang_list' => ['zh-cn','en-us'], // 获取 ...

  9. thinkphp 公用函数

    thinkphp 的项目中指定了common/function.php的函数是公用函数. 不但php页面可以使用,模板文件也可以使用:

  10. 【Leetcode链表】反转链表(206)

    题目 反转一个单链表. 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL 进阶: 你可 ...