大家在浏览网站找资料或数据的时候往往会遇到一些网页打开禁止选中文本复制,又或是右键无效,甚至是连按F12或Ctrl+U也无法打开网站源码的情况——给人一种咫尺天涯的感觉。
因此这里我教大家几个非常方便的方法来解决这些复制上的问题,也是帮助大家更好的查找自己“心仪的学习资料”——毕竟读书人的事能算偷么。
方法1 — 眼疾手快
在打开网页的同时,快速按下F12就可以顺利打开源码,然后你就可以在 “elements” 里大摇大摆的找到自己需要的资源和图片了。这是因为很多网站是利用插件或是一些程序来阻止访问用户复制内容的,而这些程序启动的时候通常会有一些延迟,因此就给了我们一个“偷鸡” 的手段。
但是这种方式有时候也会遇到优化的比较好的网站,这时候你手速再快也没用,或者你复制出来的是一串乱码,这里推荐第二个解决方法。
方法2 — Violentmonkey暴力猴
这个方法需要使用浏览器的扩展程序——Violentmonkey 暴力猴(一个开源的用户脚本管理器,支持很多浏览器)对封锁的网页进行处理,这里我们以Google Chrome浏览器为例:
首先用 Chrome 浏览器打开 Chrome 的网上应用店:
在搜索框中搜索 Violentmonkey,然后选择第一个(即暴力猴),添加至 Chrome:
成功添加后,点击浏览器右上角 猴子 + 加号:
这时会进入到 Code 页面,先将里面所有的代码全部删除:
然后下载并打开下方的code文本,将下面的代码复制粘贴进去:
// ==UserScript==
// @namespace https://www.github.com/Cat7373/
// @name 网页限制解除
// @name:en Remove web limits
// @name:zh 网页限制解除
// @name:zh-CN 网页限制解除
// @name:zh-TW 網頁限制解除
// @name:ja ウェブの規制緩和
// @description 通杀大部分网站,可以解除禁止复制、剪切、选择文本、右键菜单的限制。
// @description:en Pass to kill most of the site, you can lift the restrictions prohibited to copy, cut, select the text, right-click menu.
// @description:zh 通杀大部分网站,可以解除禁止复制、剪切、选择文本、右键菜单的限制。
// @description:zh-CN 通杀大部分网站,可以解除禁止复制、剪切、选择文本、右键菜单的限制。
// @description:zh-TW 通殺大部分網站,可以解除禁止復制、剪切、選擇文本、右鍵菜單的限制。
// @description:ja サイトのほとんどを殺すために渡し、あなたは、コピー切り取り、テキスト、右クリックメニューを選択することは禁止の制限を解除することができます。
// @homepageURL https://cat7373.github.io/remove-web-limits/
// @supportURL https://github.com/Cat7373/remove-web-limits/issues/
// @author Cat73
// @version 1.3
// @license LGPLv3
// @compatible chrome Chrome_46.0.2490.86 + TamperMonkey + 脚本_1.3 测试通过
// @compatible firefox Firefox_42.0 + GreaseMonkey + 脚本_1.2.1 测试通过
// @compatible opera Opera_33.0.1990.115 + TamperMonkey + 脚本_1.1.3 测试通过
// @compatible safari 未测试
// @match *://*/*
// @grant none
// @run-at document-start
// ==/UserScript==
(function() {
'use strict';
// 域名规则列表
var rules = {
black_rule: {
name: "black",
hook_eventNames: "",
unhook_eventNames: ""
},
default_rule: {
name: "default",
hook_eventNames: "contextmenu|select|selectstart|copy|cut|dragstart",
unhook_eventNames: "mousedown|mouseup|keydown|keyup",
dom0: true,
hook_addEventListener: true,
hook_preventDefault: true,
hook_set_returnValue: true,
add_css: true
}
};
// 域名列表
var lists = {
// 黑名单
black_list: [
/.*\.youtube\.com.*/,
/.*\.wikipedia\.org.*/,
/mail\.qq\.com.*/,
/translate\.google\..*/
]
};
// 要处理的 event 列表
var hook_eventNames, unhook_eventNames, eventNames;
// 储存名称
var storageName = getRandStr('qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM', parseInt(Math.random() * 12 + 8));
// 储存被 Hook 的函数
var EventTarget_addEventListener = EventTarget.prototype.addEventListener;
var document_addEventListener = document.addEventListener;
var Event_preventDefault = Event.prototype.preventDefault;
// Hook addEventListener proc
function addEventListener(type, func, useCapture) {
var _addEventListener = this === document ? document_addEventListener : EventTarget_addEventListener;
if(hook_eventNames.indexOf(type) >= 0) {
_addEventListener.apply(this, [type, returnTrue, useCapture]);
} else if(unhook_eventNames.indexOf(type) >= 0) {
var funcsName = storageName + type + (useCapture ? 't' : 'f');
if(this[funcsName] === undefined) {
this[funcsName] = [];
_addEventListener.apply(this, [type, useCapture ? unhook_t : unhook_f, useCapture]);
}
this[funcsName].push(func);
} else {
_addEventListener.apply(this, arguments);
}
}
// 清理循环
function clearLoop() {
var elements = getElements();
for(var i in elements) {
for(var j in eventNames) {
var name = 'on' + eventNames[j];
if(elements[i][name] !== null && elements[i][name] !== onxxx) {
if(unhook_eventNames.indexOf(eventNames[j]) >= 0) {
elements[i][storageName + name] = elements[i][name];
elements[i][name] = onxxx;
} else {
elements[i][name] = null;
}
}
}
}
}
// 返回true的函数
function returnTrue(e) {
return true;
}
function unhook_t(e) {
return unhook(e, this, storageName + e.type + 't');
}
function unhook_f(e) {
return unhook(e, this, storageName + e.type + 'f');
}
function unhook(e, self, funcsName) {
var list = self[funcsName];
for(var i in list) {
list[i](e);
}
e.returnValue = true;
return true;
}
function onxxx(e) {
var name = storageName + 'on' + e.type;
this[name](e);
e.returnValue = true;
return true;
}
// 获取随机字符串
function getRandStr(chs, len) {
var str = '';
while(len--) {
str += chs[parseInt(Math.random() * chs.length)];
}
return str;
}
// 获取所有元素 包括document
function getElements() {
var elements = Array.prototype.slice.call(document.getElementsByTagName('*'));
elements.push(document);
return elements;
}
// 添加css
function addStyle(css) {
var style = document.createElement('style');
style.innerHTML = css;
document.head.appendChild(style);
}
// 获取目标域名应该使用的规则
function getRule(url) {
function testUrl(list, url) {
for(var i in list) {
if(list[i].test(url)) {
return true;
}
}
return false;
}
if(testUrl(lists.black_list, url)) {
return rules.black_rule;
}
return rules.default_rule;
}
// 初始化
function init() {
// 获取当前域名的规则
var url = window.location.host + window.location.pathname;
var rule = getRule(url);
// 设置 event 列表
hook_eventNames = rule.hook_eventNames.split("|");
// TODO Allowed to return value
unhook_eventNames = rule.unhook_eventNames.split("|");
eventNames = hook_eventNames.concat(unhook_eventNames);
// 调用清理 DOM0 event 方法的循环
if(rule.dom0) {
setInterval(clearLoop, 30 * 1000);
setTimeout(clearLoop, 2500);
window.addEventListener('load', clearLoop, true);
clearLoop();
}
// hook addEventListener
if(rule.hook_addEventListener) {
EventTarget.prototype.addEventListener = addEventListener;
document.addEventListener = addEventListener;
}
// hook preventDefault
if(rule.hook_preventDefault) {
Event.prototype.preventDefault = function() {
if(eventNames.indexOf(this.type) < 0) {
Event_preventDefault.apply(this, arguments);
}
};
}
// Hook set returnValue
if(rule.hook_set_returnValue) {
Event.prototype.__defineSetter__('returnValue', function() {
if(this.returnValue !== true && eventNames.indexOf(this.type) >= 0) {
this.returnValue = true;
}
});
}
console.debug('url: ' + url, 'storageName:' + storageName, 'rule: ' + rule.name);
// 添加CSS
if(rule.add_css) {
addStyle('html, * {-webkit-user-select:text!important; -moz-user-select:text!important;}');
}
}
init();
})();
复制完成后,点击保存,这时会在代码上方提示网页限制解除
这个脚本基本上可以解决绝大多数的网页禁止复制问题,只要访问这类网站,暴力猴就会直接匹配该脚本,我们就可以正常复制或查看网页源码了。
方法3 — view-source 直接抓取文字
这个方法比较简单,但是稍稍麻烦一些,首先在页面的URL上直接添加 view-source:
,例如:view-source:https://baidu.com/
这样我们就可以直接打开该页面的源码:
接下来是处理文字部分,我们要将这些源码中的文字部分进行整理,这里我建议使用 html 过滤器:https://tool.chinaz.com/htmlfil
将源码里所有的内容粘贴到 HTML 脚本过滤中,然后设置过滤即可获得纯文字内容了。
最后结语
以上就是我推荐使用的三种方法了,都可以解决网页无法复制或打开源码的问题,当然实际上还有很多其他方式可以使用,但是我依然比较推荐使用第二种方法来处理,也就是 Violentmonkey暴力猴,尽管有些麻烦,但只要设置过一次,后面每次使用都会比较轻松。