小技巧:如何突破某些网站只能登陆后才能进行文字拷贝的限制
我写公众号文章时,经常需要从一些网站的文章上查阅一些资料。比如我想把这个网页上的一个标题“SAP Fiori 2.0用户体验设计概念获红点大奖”进行拷贝。
然而当我按了键盘上的拷贝快捷键Ctrl C后,却收到这个提示,告诉我只有登陆后才能够进行复制操作。
可是为了登陆我得先注册,有点麻烦。如果赶时间的话,可以使用这篇文章的小技巧,达到不用先注册再登陆,也能任意拷贝网页文字的效果。
下面是详细步骤。
1. 和往常一样打开您想复制文字的网页,先不忙按Ctrl C。按F12打开Chrome浏览器的开发者工具。
切换到Network标签页。为了避免干扰,先点Clear按钮把Network标签页下的网络请求全部清除掉。最后如下图所示:
2. 和往常一样,点击复制的快捷键Ctrl C。此时看到了意料之中的登陆框。然而我们关心的是:到底是哪一行JavaScript代码触发了这个登陆框?
从Chrome开发者工具的Network标签页里,我们找到了答案。
首先在Network标签页里我们找到了登录对话框的实现文件artlogin.html。接着,把鼠标放到下图标注了“2”的VN1134:1,Chrome开发者工具就会自动在一个悬浮窗口里显示出到底是哪一行JavaScript产生了artlogin.html的加载。答案就是标注了“3”的几个函数。这几个函数是以调用栈的方式显示的。
最底层的调用栈里的函数是DisplayPageinfo.document.body.oncopy。做过前端开发的朋友们只要看到这个oncopy,心中就有数了:这就是该网站处理用户按了Ctrl+C进行文字拷贝的处理函数,oncopy又会调用copyArt函数。
现在我们就进入copyArt函数一探究竟。果然,下图第3961行试图读取用户对于当前网站的cookie信息。如果cookie为空,那么进入第3962行if语句的第一个分支:第3970行的$(“#LayerLogin”).load(“/artlogin.html”)负责的正是登陆对话框的加载。
讲到这里,解决方案已经很清楚了:在执行第3962行代码判断网站cookie之前,我们随便给变量CurUserNameCookiescgcg赋上一些内容,让它的值不为空,确保进入IF的ELSE分支就行了。
如下图,在Chrome开发者工具的Console标签页里给Cookie变量赋值:
于是进入了我们期望的ELSE分支,此时,我在网页上选中的文本“SAP Fiori 2.0用户体验设计概念获红点大奖”已经成功写入JavaScript变量selhtml中,请大家看代码第3986行。
直接点Chrome开发者工具的”Continue”按钮结束调试,打开记事本按粘贴的快捷键Ctrl+V,成功了。
要获取更多Jerry的原创技术文章,请关注公众号”汪子熙”或者扫描下面二维码:
相关文章
- [python学习] 简单爬取图片网站图库中图片
- w3schools网站的HTML教程之HTML编辑器
- 如何实时主动监控你的网站接口是否挂掉并及时报警
- 【华为云实战开发】8.如何快速搭建C#网站并实现持续集成?
- 我也要谈谈大型网站架构之系列(2)——纵观历史演变(下)
- 火狐浏览器Firefox 如何下载网页的SWF视频,硅谷动力的网站视频怎么下载
- 将样式表放在顶部——高性能网站建设指南规则5(读书笔记)
- 网站的高可用架构 Availability
- java实现复制网站内容
- Python 自动登录网站(处理Cookie)
- 云拨测助力节卡机器人 全面优化海外网站性能
- 蚂蚁变大象:浅谈常规网站是如何从小变大的(五)(转)
- 蚂蚁变大象:浅谈常规网站是如何从小变大的(四)(转)
- discuz !NT 3.5 论坛整合 .net 网站用户登录,退出
- 网站开启https后加密协议始终是TLS1.0如何配置成TLS1.2?
- .NET C#使用微信公众号登录网站
- 视频网站数据平台变迁之路(二)
- Docker Dockefile制作nginx php镜像搭建Wordpress网站
- 如何将 SAP UI5 应用托管到 Github 网站上并运行
- 利用云存储快速实现网站备份
- 如何绕过CDN查询网站真实IP
- 【Python成长之路】Python爬虫 --requests库爬取网站乱码(xe4xb8xb0xe5xa)的解决方法【华为云分享】
- 73:应急响应-WEB分析php&javaweb&自动化工具 ——可以基于网站访问日志,检测是否有攻击360星图工具就是这样;还可以使用ELK去做攻击者画像,同时做攻击溯源
- prism 的学习网站