推荐:如何防止非法盗链本站图片目前非法 盗链别站网页图片、文件的现象非常多,下面方法是用asp代码实现的防止盗链方法。 主要思路是用Request.ServerVariables收集得到HTTP_REFERRER,然后根据这个变量的值判断链接是否来自外部,阻止非法链接。 首先,我们需要对图片做如下引用: imgsrc=
将下面代码保存为myimg.asp,在要显示数字(比如QQ号等)的位置插入<imgsrc=myimg.asp?tel=010-0000000>即可。| <% CallCom_CreatValidCode(Request.QueryString(tel)) PublicSubCom_CreatValidCode(pTel) ’----------禁止缓存 Response.Expires=0 Response.AddHeaderPragma,no-cache Response.AddHeadercache-ctrol,no-cache Response.ContentType=Image/BMP Randomize Dimi,ii,iii,rndColor,strLen,sql,rs ConstcOdds=5 ’------------杂点出现的机率 Conststr=0123456789- strLen=len(pTel) rndColor=ChrB(cint(rnd*255))&ChrB(cint(rnd*255))&ChrB(cint(rnd*255)) ’-----------颜色的数据(字符,背景) DimvColorData(1) ’vColorData(0)=ChrB(0)&ChrB(0)&ChrB(0) ’----蓝0,绿0,红0(黑色) ’vColorData(1)=ChrB(255)&ChrB(255)&ChrB(255) ’----蓝250,绿236,红211(浅蓝色) ’vColorData(0)=ChrB(197)&ChrB(106)&ChrB(49) ’----蓝0,绿0,红0(黑色) ’vColorData(1)=ChrB(238)&ChrB(210)&ChrB(193) ’-----蓝250,绿236,红211(浅蓝色) vColorData(0)=ChrB(0)&ChrB(0)&ChrB(0) ’---------蓝0,绿0,红0(黑色) vColorData(1)=ChrB(205)&ChrB(237)&ChrB(245) ’------------蓝250,绿236,红211(浅蓝色) ’--------------------随机产生字符 Randomize DimvCode() redimvCode(strLen-1) Fori=0TostrLen-1 vCode(i)=instr(1,str,mid(pTel,i+1,1),1)-1 Next ’-----------字符的数据 DimvNumberData(11) ’VerdanaFont vNumberData(0)=11111111111000111101110111011101110111011101110111011101110111011110001111111111 vNumberData(1)=11111111111101111110011111110111111101111111011111110111111101111110001111111111 vNumberData(2)=11111111111000111101110111011101111110111111011111101111110111111100000111111111 vNumberData(3)=11111111111000111101110111111101111100111111110111111101110111011110001111111111 vNumberData(4)=11111111111110111111001111101011111010111101101111100001111110111111100111111111 vNumberData(5)=11111111110000011101111111011111110000111111110111111101110111011110001111111111 vNumberData(6)=11111111111000111101101111011111110000111101110111011101110111011110001111111111 vNumberData(7)=11111111110000011101101111111011111101111111011111110111111101111111011111111111 vNumberData(8)=11111111111000111101110111011101111000111101110111011101110111011110001111111111 vNumberData(9)=11111111111000111101110111011101110111011110000111111101111011011110000111111111 vNumberData(10)=11111111111111111111111111111111111111111100000111111111111111111111111111111111 vNumberData(11)=11111111111111111111111111111111111111111111111111111111111111111111111111111111 ’-----------------输出图像文件头<br> Response.BinaryWriteChrB(66)&ChrB(77)&chrb(((strLen*8*10*3+54)mod256))&chrb(((strLen*8*10*3+54)/256)mod256)&ChrB((((strLen*8*10*3+54)/256)/256)mod256)&ChrB(((((strLen*8*10*3+54)/256)/256)/256)mod256)&ChrB(0)&ChrB(0)&_ ChrB(0)&ChrB(0)&ChrB(54)&ChrB(0)&ChrB(0)&ChrB(0)&ChrB(40)&ChrB(0)&_ ChrB(0)&ChrB(0)&ChrB(strLen*8)&ChrB(0)&ChrB(0)&ChrB(0)&ChrB(10)&ChrB(0)&_ ChrB(0)&ChrB(0)&ChrB(1)&ChrB(0) ’------------------输出图像信息头 Response.BinaryWriteChrB(24)&ChrB(0)&ChrB(0)&ChrB(0)&ChrB(0)&ChrB(0)&_ ChrB((strLen*8*10*3)mod256)&ChrB(((strLen*8*10*3)/256)mod256)&ChrB((((strLen*8*10*3)/256)/256)mod256)&ChrB(((((strLen*8*10*3)/256)/256)/256)mod256)&_ ChrB(196)&ChrB(14)&ChrB(0)&ChrB(0)&ChrB(196)&ChrB(14)&ChrB(0)&ChrB(0)&_ ChrB(0)&ChrB(0)&ChrB(0)&ChrB(0)&ChrB(0)&ChrB(0)&ChrB(0)&ChrB(0) Fori=9To0Step-1 ’----------历经所有行 Forii=0TostrLen-1 ’-------历经所有字 Foriii=1To8 ’--------历经所有像素 ’---------逐行、逐字、逐像素地输出图像数据 IfRnd*99+1<cOddsThen ’---------随机生成杂点 Response.BinaryWriterndColor Else Response.BinaryWritevColorData(Mid(vNumberData(vCode(ii)),i*8+iii,1)) EndIf Next Next Next EndSub %> |
分享:通用获取文章上下各三篇文章的代码通用的 获取文章上下各 三 篇文章的代码,示例用的是asp教程,主要是了解SQL语句,其中id指当前文章的. 上 三 篇 Sql=Selecttop3*From contentWhereidid 下 三 篇 Sql=Selecttop3*FromcontentWhereididorderbyiddesc