解除百度云浏览器端对下载大文件的限制

百度网盘对浏览器端下载大文件做了一些限制,当超过一定大小的文件必须使用百度云管家才可以下载,这给用户的使用带来了不便。

[不看分析请直接拉到页底]

1. 百度网盘限速原理

  当点击下载一个大文件的时候百度网盘会弹出这样一个提示框。

  

  我们给下个断点,看看是什么代码创建了这个提示框。

  

  然后再次点击下载一个大文件,我们发现断点已经断下来了。

  

  可以看出这里是在把提示对话框显示出来,我们需要查看调用栈往上找找。

  

  跳过一些jQuery的操作,我们看到了这样一个函数,继续往上找。

  

  这个isPlatformWindows的分支很可疑,我们跟进去看一下,于是我把DOM断点取消了,并在1748行这里下了个断点。

  

  断下来了,跟进去看看。

  

  这个函数只是简单的判断了 navigator.platform 这个平台相关的字符串,我们修改一下看看会发生什么结果

  

  

  让代码继续跑起来

  

  嗯,我们成功了。

2. 写段代码来破解吧

  从上面的调试中我们已经知道了百度是通过判断 window.navigator.platform 是不是以 win32 开头来判断是否是运行浏览器下载的,所以我们只需要修改这个变量就轻松解除了限制。

  经过尝试我发现,platform这个属性被百度冻结了。

  所以只能修改 navigator 。

  修改代码如下:

  

Object.defineProperty(this , ‘navigator‘ , {value: { platform: "" }});

  

一句话总结:

  打开浏览器控制台(F12) 在命令行行 Object.defineProperty(this , ‘navigator‘ , {value: { platform: "" }}); 这段代码即可解除百度网盘对浏览器下载大文件的限制。

时间: 2024-10-27 09:04:24

解除百度云浏览器端对下载大文件的限制的相关文章

百度云使用第三方工具下载文件

第一种:首先打开http://www.loveno.net/baiduyun/login.html点"与你的百度网盘相连" 走完流程之后进入到你自己的百度云,把要下载的文件放到"我的应用数据"里的"zqqian123"里. 如果没有"zqqian123"文件夹,自行创建 然后回到你走完流程的那个界面,就能看到下载地址,可以直接下载,下载软件推荐用idm 第二种: 需要的软件:1.es文件管理器 2.adm pro 这两个均为安

在ASP.NET中支持断点续传下载大文件(ZT)

IE的自带下载功能中没有断点续传功能,要实现断点续传功能,需要用到HTTP协议中鲜为人知的几个响应头和请求头. 一. 两个必要响应头Accept-Ranges.ETag         客户端每次提交下载请求时,服务端都要添加这两个响应头,以保证客户端和服务端将此下载识别为可以断点续传的下载: Accept-Ranges:告知下载客户端这是一个可以恢复续传的下载,存放本次下载的开始字节位置.文件的字节大小: ETag:保存文件的唯一标识(我在用的文件名+文件最后修改时间,以便续传请求时对文件进行

datasnap 上传/下载大文件(本Demo以图传片文件为例)

datasnap 上传/下载大文件(本Demo以图传片文件为例) 作者:admin 来源: 日期:2011-8-17 11:44:51 人气:737 标签: QQ空间 新浪微博 腾讯微博 腾讯朋友 QQ收藏 百度空间 百度贴吧 更多0 好久没写技术文了 datasnap传大流. 完整代码,同时感谢叶兄传流的指点,(只公开十天) 附:下面代码,转载请注明出处 ::code 服务端: function TServerMethods1.DownLoadFile(AfileName: string):

ASP.Net 下载大文件的实现 (转)

原文:http://www.cnblogs.com/luisliu/p/4253815.html 当我们的网站需要支持下载大文件时,如果不做控制可能会导致用户在访问下载页面时发生无响应,使得浏览器崩溃.可以参考如下代码来避免这个问题. 关于此代码的几点说明: 1. 将数据分成较小的部分,然后将其移动到输出流以供下载,从而获取这些数据. 2. 根据下载的文件类型来指定 Response.ContentType .(这个网址可以找到大部分文件类型的对照表:http://tool.oschina.ne

ASP.Net 下载大文件的实现

当我们的网站需要支持下载大文件时,如果不做控制可能会导致用户在访问下载页面时发生无响应,使得浏览器崩溃.可以参考如下代码来避免这个问题. 关于此代码的几点说明: 1. 将数据分成较小的部分,然后将其移动到输出流以供下载,从而获取这些数据. 2. 根据下载的文件类型来指定 Response.ContentType .(这个网址可以找到大部分文件类型的对照表:http://tool.oschina.net/commons) 3. 在每次写完response时记得调用 Response.Flush()

ASP.NET Core下载大文件的实现

当我们的ASP.NET Core网站需要支持下载大文件时,如果不做控制可能会导致用户在访问下载页面时发生无响应,使得浏览器崩溃.可以参考如下代码来避免这个问题. 关于此代码的几点说明: 将数据分成较小的部分,然后将其移动到响应输出流以供下载,从而获取这些数据. 根据下载的文件类型来指定 Response.ContentType .(这个网址可以找到大部分文件类型的对照表:http://tool.oschina.net/commons) 在每次调用Response.Body.Write后记得调用

下载大文件时OutofMemoryException

有一个大文件下载的问题,这两天查了一下,主要原因有两个: 发送的Get请求中,没有设置HttpCompletionOption这个参数,当下载大文件的时候,会等到response body中的数据全部加载完才开始下载.现在已经改成了HttpCompletionOption.ResponseHeadersRead,这样只要head加载完就可以开始下载 下载的时候使用FileStreamResult File(Stream fileStream, string contentType, string

百度Fex webuploader.js上传大文件失败

项目上用百度webuploader.js上传文件,option选项里面已经设置单个文件大小,但是上传低于此阈值的文件时仍然不成功. 我现在的理解是,框架是将文件post到后台服务器端的.. 百度发现是IIS里面对大文件有限制.. <system.webServer> <validation validateIntegratedModeConfiguration="false" /> <modules runAllManagedModulesForAllRe

转(Response.WriteFile 无法下载大文件解决方法)

以前用Response.WriteFile(filename),但当遇到大文件时无法完整下载. 该方法最大的问题,它不是直接将数据抛到客户端,而是在服务器端(IIS)上缓存.当下载文件比较大时,服务器压力会很大,iis虽然支持2G大小的文件下载,但当文件上了很多M时,由于服务器以及网络等因素的影响,异常概率相当大.所以当需要下载大文件时就不能使用上面的方法了. 微软推荐以下方法代替之: ■将数据分成较小的部分,然后将其移动到输出流以供下载,从而获取这些数据. ■为用户提供用于下载文件的链接. ■