时间:2021-05-25
那天突然的一个灵感,是针对防盗链的
正常上传的文件,若被人盗链则增加了自己服务器的负担,上次164.cc就因此被挂
然后想想对策,目前各类防盗链程序也不少,不过使用也并不简单,还有就是不能免费……
所以,只有自己先想办法。那么,现在看看标题,再想想防盗链,或许就有些眉目了
我可以不定时的修改上传文件所在的文件夹名称,而本站程序是动态获得文件夹名称,这样原先盗用本站文件的站点会因路径的错误而找不到文件,从而也就实现了防盗链。
那么,如何使用FSO修改文件夹的名称呢?
一个简单的函数:
复制代码 代码如下:
<%
Functionfldrename(nowfld,newfld)
nowfld=server.mappath(nowfld)
newfld=server.mappath(newfld)
Setfso=CreateObject("Scripting.FileSystemObject")
ifnotfso.FolderExists(nowfld)then
response.write("需要修改的文件夹路径不正确或文件夹名称输入错误")
else
fso.CopyFoldernowfld,newfld
fso.DeleteFolder(nowfld)
endif
setfso=nothing
EndFunction
%>
总的来说就是拷贝当前文件夹的内容到新的文件夹中,然后再删除该文件夹内容,从而间接达到文件夹改名的目的。
这是一个偏执狂问题,因为修改文件夹名称,尤其是要修改名称的该文件夹内容是G量时,这个等待的时间相对FTP远程修改名称就有点不划算了。
有人说FSO可不可以直接修改文件夹名称呢?吾莫之。
应用该函数
<%callfldrename("ex01","ex02")%>
基本意思即将与程序执行文件在同一目录下的ex01文件夹名称修改为ex02
下面是我在本地的测试情况通报:
1,本程序不消耗程序执行时间
2,执行1G文件夹间接改名时间需要50秒左右,其实也就是服务器端的文件复制转移时间
3,CPU消耗不算太高,30%左右
4,若在改名中间突然死机或掉电,则发生两种情况:
a,新文件夹被建立初期(新文件夹并未建好),下次执行程序,会发生错误类型:MicrosoftVBScript运行时错误(0x800A003A)文件已存在,此时只能FTP删除新文件夹再执行(尝试使用FSO删除新文件夹并未凑效)。
b,已经复制了部分文件,下次执行程序,自动覆盖已复制的文件夹内容,原文件夹内容依然存在。只有在复制完毕后,才会将原文件夹及其文件删除。
5,同时需要注意新文件夹的名称,避免和已有文件夹名称重名,当然也可用程序判断
复制代码 代码如下:
<%
Functionfldrename(nowfld,newfld)
nowfld=server.mappath(nowfld)
newfld=server.mappath(newfld)
Setfso=CreateObject("Scripting.FileSystemObject")
ifnotfso.FolderExists(nowfld)then
response.write("需要修改的文件夹路径不正确或文件夹名称输入错误")
else
iffso.FolderExists(newfld)then
response.write("您命名的新文件夹名称已经存在")
else
fso.CopyFoldernowfld,newfld
fso.DeleteFolder(nowfld)
endif
endif
setfso=nothing
EndFunction
%>
6,若在修改文件夹名称的同时,文件夹内有数据库相关操作、音乐文件正在被播放,则显示为MicrosoftVBScript运行时错误(0x800A0046)没有权限,主要即是删除原有文件夹出现的问题(音乐文件已被删除、但文件夹未能被删除)。只有FTP登录处理了。若本文件夹为全图片文件则可以运行成功。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
如果服务器的图片被别的网站盗链,将影响服务器的带宽以及访问速度,这时我们就需要设置图片文件或视频文件的防盗链功能;防盗链功能,简单来说就是你可以直接访问该资源,
本文实例讲述了Referer原理与图片防盗链实现方法。分享给大家供大家参考,具体如下:1、图片防盗链在一些大型网站中,比如百度贴吧,该站点的图片采用了防盗链的规
用Asp隐藏文件路径,实现防盗链 如果我们知道一个静态文件的实际路径如:http:///down.asp?FileName=51windows.pdf来下载这
由于nginx不支持.htaccess,所以,从这个方面直接去防止是行不通的,我们要通过修改配置文件来解决。首先,我们找到需要防盗链的域名的conf文件,路径:
下载服务器时常被人盗链,时间久了导致服务器大量资源浪费,由于服务器使用nginx做为web服务器。nginx的防盗链方法有很多,可以使用现成的防盗链模块ngin