使用JavaScript破解web


Posted in Javascript onSeptember 28, 2018

并非所有的黑客行为都是恶作剧。下面是如何使用JavaScript使浏览器更好的方法。

JavaScript的在线资源并不缺乏,从教你基础知识的课程到应用程序创建的教程。在本文中,我将解释如何使用JavaScript创建有用的浏览器黑客,以提高您的Web体验和提高工作效率。这篇文章不需要您自己开发应用程序,甚至不需要对产品有特别深入的了解。

书签的力量

我们都知道书签有多有用。它们允许您保存到网页的链接,对其进行分类,并添加其他数据(元数据),以帮助您在将来快速找到该链接,并将其存档到您可以轻松导航的结构中。许多人不知道的是,您还可以将微小的代码片段保存到这些书签中,这些书签是在您所在的网页的上下文中执行的,包括对其结构和样式的访问。

如果你打开Facebook控制台,你会发现它的开发者非常反对这种窥探-这是有理由的。即使没有访问他们的代码,你也可以进行修改,甚至破坏一些应用程序。

使用JavaScript破解web

Facebook的开发者不想让你弄乱他们的控制台。

不过,你可能会忘记你输入的内容,或者丢失一些文本。或者,如果您像我一样,保存您打开的文件,复制它们,到您想要的网站,打开控制台,粘贴和运行的过程似乎需要很大的努力。下面是一些我用来检查网页的长度的代码(用我正在使用的设备上的屏幕来衡量)。这在Edge,Firefox,Chrome,甚至我的手机上都适用:

javascript:alert(document.body.scrollHeight / window.innerHeight)

如果我知道一页有多长,我可以预先决定是否要读。我用它来向客户展示各种设备上有多大或多小的网页。

下面是我使用的另一个工具,用于删除程序员博客文章中的所有图片和文章,只获取高光部分(我还会对它们进行书签;我不会将浏览作为阅读的替代方案)。

javascript:(function(){ [].slice.call(document.querySelectorAll('img, .gist')).forEach(function(elem) { elem.remove(); }); })()

您会注意到,大多数代码并不复杂;实际上,有些代码非常简单。因为这些主要是我个人用的,简单就行了。如果我把这些放在要点中,其他人可以分叉并更新它们,我们可能会有更好的书签。

使用加载项在整个web上进行持久更改。

我们大多数不是网页设计师的人不想要多个浏览器的麻烦。我们也不希望我们的链接被JavaScript片段弄得乱七八糟。我要说的是,我不是在写你自己的插件,而是用现有的插件来增强你的网络体验。

问题

当我第一次开始使用Reddit和Imgur我发现他们的画廊编辑很困难。我本可以停止使用这些工具,但是我需要找到另一个在线服务并上传我的媒体。而且,我可能会忘记并返回Imgu,并且无法浏览我自己的内容。我的解决方案是在控制台和页面检查器中四处游玩,看看我是否能从他们的服务中得到我想要的东西。

使用JavaScript破解web

右击,然后单击“检查元素”,立即查看网页的结构。

大约五分钟后,我注意到大图片和小缩略图之间的细微差别。我需要更大的图片,这样我就可以看到我在拖什么,并建立一些叙事顺序。


我想出的代码比较简单,只有七行。重点不是写最少的代码,甚至是最干净的代码,而是简单地完成任务:开火忘记!

(function(jQuery) {
 jQuery('.sortable-image img, .sortable-image').css({width:'auto',height:'auto'})
 jQuery('.sortable-image img').each( function(e,elem) {
 var fixedImg = jQuery(this).attr('src').replace('s.png','.png');
 jQuery(this).attr( 'src', fixedImg );
 });
})(jQuery);

首先,我告诉网页删除高度和宽度限制,然后循环遍历每个可排序的图像,并替换部分文件名。它不是最干净的代码;它依赖于Imgu的DOM结构保持不变,并拥有jQuery库,但是它的思想是获得所需的东西,这样您就可以继续了。而且,它比向开发团队发送电子邮件以更改每个人的体验要有效得多,因为您发现它很难使用。

我对此使用了一个外接程序,据我所知,它并不是严格意义上的OpenSource(尽管如果您能够找到ChromiumUser-profile文件夹,您确实可以访问代码)[用户JavaScript和CSS]但是它允许您做您想做的事情,甚至可以实现脚本在特定URL或URL模式上运行的规则。

(请注意,Imgu不再使用相同的DOM,因此上面的代码不再工作了。对于您以这种方式发布的大部分代码来说,这是正确的,并且将继续如此。它不是为建立一个帝国而设计的,只是为了让你的生活变得单调乏味。

创作加载项

我想要讨论的最后一个主题是如何创建您自己的附加组件。我将重点关注ChromiumAd-ons,因为我对这些插件有最丰富的经验,但是您可以在Web上找到Firefox和其他支持浏览器的链接。

您还可能想要做一些雄心勃勃的事情,比如向所有页面添加键盘快捷键,其中包含前面的链接或屏蔽网络上特定的仇恨言论。您可以通过为Web使用或创作附加组件来完成此操作(如果浏览器允许)。

首先,您需要一个文件夹来存放您的文件。

mkdir -p ~/projects/addon-name

一旦您有了放置文件的位置,打开您最喜欢的编辑器并创建两个文件:manifest.json和content.js(第二个文件是特定于JS加载项的,它只是我为基于内容的JS使用的命名约定)。

Manifest.json

这个文件的代码是任何铬添加的最重要的部分.它基本上指导插件的工作方式和时间。创建这些专业不属于本文的范围,正如本文所做的那样。创建Firefox扩展

{ "manifest_version": 2, "name": "Whatever you want to call the plugin", "description": "A brief description of what the plugin does. I prefer the GNU philosophy of do one thing well", "version": "2.0", "content_scripts": [ { "matches": [ "*://*/*" ], "js": [ "content.js" ], "run_at": "document_end" } ] }

这只是告诉浏览器在读取所有方案(http:、https:等)的每个网页时,在所有路径上运行content.js。

Content.js

你在你的content.js与您在网页上放置的任何代码相同。为了浏览图库,我使用了我的朋友Barry生成的一段代码,它使用了一个名为相册速递(它是为Windows 7编写的)的旧软件。

document.addEventListener('keyup', function(k) { switch(k.code) { case "ArrowRight": document.querySelector('.nav.controls .link.next').click(); break; case "ArrowUp": document.querySelector('.nav.controls .link.up').click(); break; case "ArrowLeft": document.querySelector('.nav.controls .link.prev').click(); // window.history.back(); // The software Barry uses actually doesn't think to generate "prev" links, so we have to be creative break; default: console.log("Key Pressed:", k); } });

从这里:

导航到chrome://extensions/在你的浏览器里

使用JavaScript破解web

加载解压扩展按钮铬。

导航到保存扩展的文件夹

最后,单击“打开”。

使用JavaScript破解web

浏览铬扩展名文件的路径。

包起来

我希望您喜欢阅读这篇文章,并且它帮助您在不为每个人更改代码的情况下处理软件项目。如果您只是进入JavaScript,在构建您自己的体验之前进行实验,这将帮助您了解哪些模式和方法最适合您。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。如果你想了解更多相关内容请查看下面相关链接

Javascript 相关文章推荐
漂亮的widgets,支持换肤和后期开发新皮肤
Apr 23 Javascript
CLASS_CONFUSION JS混淆 全源码
Dec 12 Javascript
JQuery+JS实现仿百度搜索结果中关键字变色效果
Aug 02 Javascript
js汉字转拼音实现代码
Feb 06 Javascript
原生javascript实现Tab选项卡切换功能
Jan 12 Javascript
JavaScript实现数字数组正序排列的方法
Apr 06 Javascript
js利用clipboardData实现截屏粘贴功能
Oct 12 Javascript
JS正则表达式学习之贪婪和非贪婪模式实例总结
Dec 26 Javascript
jQuery插件FusionWidgets实现的Bulb图效果示例【附demo源码下载】
Mar 23 jQuery
基于vue实现swipe轮播组件实例代码
May 24 Javascript
微信小程序学习笔记之目录结构、基本配置图文详解
Mar 28 Javascript
js实现全选反选不选功能代码详解
Apr 24 Javascript
详解node字体压缩插件font-spider的用法
Sep 28 #Javascript
JS canvas绘制五子棋的棋盘
May 28 #Javascript
在vue中解决提示警告 for循环报错的方法
Sep 28 #Javascript
H5+C3+JS实现五子棋游戏(AI篇)
May 28 #Javascript
解决微信小程序防止无法回到主页的问题
Sep 28 #Javascript
在vue中更换字体,本地存储字体非引用在线字体库的方法
Sep 28 #Javascript
H5+C3+JS实现双人对战五子棋游戏(UI篇)
May 28 #Javascript
You might like
dedecms 制作模板中使用的全局标记图文教程
2007/03/11 PHP
php木马攻击防御之道
2008/03/24 PHP
PHP写MySQL数据 实现代码
2009/06/15 PHP
php有道翻译api调用方法实例
2014/12/22 PHP
php变量与JS变量实现不通过跳转直接交互的方法
2017/08/25 PHP
YII2框架中ActiveDataProvider与GridView的配合使用操作示例
2020/03/18 PHP
IE6与IE7中,innerHTML获取param的区别
2009/03/15 Javascript
jquery 操作DOM案例代码分享
2012/04/05 Javascript
javascript控制swfObject应用介绍
2012/11/29 Javascript
jquery拖动插件(jquery.drag)使用介绍
2013/06/18 Javascript
javascript中普通函数的使用介绍
2013/12/19 Javascript
jQuery-ui引入后Vs2008的无智能提示问题解决方法
2014/02/10 Javascript
JavaScript实现级联菜单的方法
2015/06/29 Javascript
Bootstrap项目实战之子栏目资讯内容
2016/04/25 Javascript
JS实现iframe自适应高度的方法(兼容IE与FireFox)
2016/06/24 Javascript
BootStrap 轮播插件(carousel)支持左右手势滑动的方法(三种)
2016/07/07 Javascript
js实现图片懒加载效果
2017/07/17 Javascript
JS动态添加元素及绑定事件造成程序重复执行解决
2017/12/07 Javascript
详解适配器在JavaScript中的体现
2018/09/28 Javascript
Python实现获取汉字偏旁部首的方法示例【测试可用】
2018/12/18 Python
Python实现将通信达.day文件读取为DataFrame
2018/12/22 Python
Pytorch之卷积层的使用详解
2019/12/31 Python
浅谈keras通过model.fit_generator训练模型(节省内存)
2020/06/17 Python
HTML5 声明兼容IE的写法
2011/05/16 HTML / CSS
Bowflex美国官方网站:高级家庭健身器材
2017/12/22 全球购物
Swanson中国官网:美国斯旺森健康产品公司
2021/03/01 全球购物
Solaris操作系统的线程机制
2012/12/23 面试题
护理专业推荐信
2013/11/07 职场文书
致跳高运动员加油稿
2014/02/12 职场文书
幼儿园中秋节活动反思
2014/02/16 职场文书
元宵节晚会主持人串词
2014/03/25 职场文书
小学生春游活动方案
2014/08/20 职场文书
质量负责人岗位职责
2015/02/15 职场文书
员工试用期转正自我评价
2015/03/10 职场文书
暗恋桃花源观后感
2015/06/12 职场文书
Redis sentinel哨兵集群的实现步骤
2022/07/15 Redis