仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 696|回复: 12
打印 上一主题 下一主题

[学习教程] ASP网页编程之ASP程序平安篇

[复制链接]
灵魂腐蚀 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-16 23:15:03 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
ASP是依赖组件的,能访问数据库的组件好多就有好多种,再有就是你微软的工具可是什么都要收钱的啊!平安|程序在做平安设置前,我们先懂得一下进侵者的打击伎俩。如今很盛行注进打击,所谓注进打击,就是使用提交特别地点将ASP中援用的一般SQL语句和进侵者所必要的SQL语句一并实行,使进侵者到达进侵的目标。如今更是有一些剧本注进工具公布,使菜鸟也能够轻松完成对ASP的注进打击。那末我们先来懂得一下这些工具是如何注进的。
起首,进侵者会对一个网站断定可不成以举行注进,假定一篇文章的地点为:http://www.scccn.com/news.asp?id=1一样平常会以提交两个地点来测试,如:
http://www.scccn.com/news.asp?id=1and1=1
http://www.scccn.com/news.asp?id=1and1=2
第一个地点前面加了and1=1,组成的SQL语句也就变成了:Select*from表单名whereid=1and1=1这句话要建立就必需and前后语句都建立。那末后面的文章地点是能够会见的,前面的1=1也是客不雅建立的,那末第一个地点就能够一般显现;相反1=2是明显不建立的,关头就看这步了,假如提交and1=2页面仍是一般显现申明他并未将and1=2写进SQL语句,此站也就不存在注进毛病;但假如提交and1=2以后前往了毛病页面则申明此站点将前面的语句带进了SQL语句并实行了,也就申明他能够举行SQL注进。(注:假如地点前面跟的是news.asp?id=1就得变成news.asp?id=1and1=1来补全引号了)
那末,晓得能够注进后进侵者能够做甚么呢?
这里就复杂的说一下,好比提交如许的地点:
http://www.scccn.com/news.asp?id=1andexists(select*from表名where列名=数据)
依据前往的准确或毛病页面来判别猜的表名和列名是不是准确,详细完成时是先猜表名再猜列名。当猜出表名和列名以后还能够用ASC和MID函数来猜出各列的数据。MID函数的格局为:mid(变量名,第几个字符入手下手读取,读取几个字符),好比:mid(pwd,1,2)就能够从变量pwd中的第一名入手下手读取两位的字符。ASC函数的格局为:ASC("字符串"),如:asc("a")就能够读出字母a的ASCII码了。那末实践使用的时分就能够写为:asc(mid(pwd,1,1))如许读取的就是pwd列的第一个字符的ASCII码,提交:asc(mid(pwd,1,1))>97以前往的页面是不是为准确页面来判别pwd列的第一个字符的ASCII码是不是年夜于97(a的ASCII码),假如准确就再试是不是小于122(z的ASCII码)……如许渐渐减少字符的ASCII码的局限,猜到实在的ASCII码也只是工夫的成绩。一名一名的猜就能够失掉数据库中的用户名和暗码了。另有一种ASP考证缺点――就是用户名和暗码都输or1=1,机关SQL语句Select*form表单名whereusername=or1=1andpwd=or1=1就能够到达绕过暗码考证的目标。
说了那末多,实在提防的办法很复杂,我们把特别字符(如and、or、、")都克制提交就能够避免注进了。ASP传输数据分为get和post两种,get是经由过程将数据增加到URL后提交的体例,post则是使用邮寄信息数据字段将数据传送到服务器。
那末,我们先来看看怎样将get体例提交数据中的特别字符过滤。起首要晓得,IIS是以字符串的情势将get哀求传给asp.dll的,在将数据传送给Request.QueryString以后,asp剖析器会剖析出Request.QueryString的信息,然后跟据"&"来分出各个数组内的数据。如今我们要让get体例不克不及提交以下字符:
、and、exec、insert、select、delete、update、count、*、%、chr、mid、master、truncate、char、declare
那末,避免get体例注进的代码就以下:
<%
dimsql_leach,sql_leach_0,Sql_DATA
sql_leach=",and,exec,insert,select,delete,update,count,*,%,chr,mid,master,truncate,char,declare"
sql_leach_0=split(sql_leach,",")
IfRequest.QueryString""Then
ForEachSQL_GetInRequest.QueryString
ForSQL_Data=0ToUbound(sql_leach_0)
ifinstr(Request.QueryString(SQL_Get),sql_leach_0(Sql_DATA))>0Then
Response.Write"请不要实验举行SQL注进!"
Response.end
endif
next
Next
EndIf
%>
个中,变量sql_leach中的字符串就是指定过滤的字符,以","离隔。
接着过滤post提交体例的注进,我们能够看到,request.form也是以数组情势存在的,只需对它再举行一次轮回判别就能够了。避免以post体例注进的ASP代码以下:
<%
IfRequest.Form""Then
ForEachSql_PostInRequest.Form
ForSQL_Data=0ToUbound(sql_leach_0)
ifinstr(Request.Form(Sql_Post),sql_leach_0(Sql_DATA))>0Then
Response.Write"请不要实验举行SQL注进!"
Response.end
endif
next
next
endif
%>
如许,get和post注进都被克制了。
别的就是数据库的成绩,起首如今很盛行的用*.asp定名数据库已没甚么意义了,由于能够用下载软件来下载;在数据库名前加#的感化也不年夜,固然会见时扫瞄器只会见#后面的内容,可是假如将#用其unicode表达法(%23)交换失落就能够会见了。既然如许,那末我们克制进侵者暴库就能够了。一样平常暴数据库的办法,是将读取数据库的文件名(如conn.asp)前的"/"交换为"%5c"(""的unicode表达法)如许就能够使ASP将%5c注释为会见网站根目次,而实践是数据库不在指定地位,找不到数据库,再将IE设置为"显现友爱的HTTP毛病信息"的情形下天然就暴出了数据库的路径。
提防的办法也对照复杂,就是让ASP程序即便在堕落的情形下也不报错间接实行下一步就能够了。在ASP文件中加这么一句:onerrorresumenext就OK了。
另有几点要注重的:
1.数据库定名长些并只管放在网站根目次下,数据库的表名和字段名只管分歧惯例;
2.保留敏感信息(如用户和暗码)的数据库只管和在前台页面援用的数据库分隔(假如用新的暴库办法由前台页面暴出了数据库,那末进侵者也得不到有代价的信息);
3.背景的目次名和上岸页面的名字要改的不平常些,万万不成呈现admin大概login之类的字符,以避免被注进软件扫描到背景。
4.假如前台或背景有上传文件的功效,牢记不克不及有任何其他功效间接的或直接的具有变动文件名的权限。
如许的多重保证就加倍平安些了。


</p>ASP由于使用了COM组件所以它会变的十分强大,但是这样的强大由于WindowsNT系统最初的设计问题而会引发大量的安全问题。只要在这样的组件或是操作中一不注意,哪么外部攻击就可以取得相当高的权限而导致网站瘫痪或者数据丢失;
爱飞 该用户已被删除
沙发
发表于 2015-1-17 23:44:58 | 只看该作者
如何更好的使自己的工具看上去很不错等等。其实这些都不是问题的实质,我们可以在实践中不断提升自己,不断充实自己。
只想知道 该用户已被删除
板凳
发表于 2015-1-21 10:27:41 | 只看该作者
另外因为asp需要使用组件,所以了解一点组件的知识(ADODB也是组件)
愤怒的大鸟 该用户已被删除
地板
发表于 2015-1-25 15:22:04 | 只看该作者
学习是为了用的,是为了让你的程序产生价值,把握住这个原则会比较轻松点。除此之外,课外时间一定要多参加一些社会实践活动,来锻炼自己的能力。
透明 该用户已被删除
5#
发表于 2015-1-25 21:19:37 | 只看该作者
下载一个源代码,然后再下载一个VBScript帮助,在源代码中遇到不认识的函数或是其他什么程序,都可以查帮助进行解决,这样学习效率很高。
第二个灵魂 该用户已被删除
6#
发表于 2015-1-26 19:12:15 | 只看该作者
不是很难但是英文要有一点基础网上的教程很少有系统的详细的去买书吧,另不用专门学习vb关于vbscript脚本在asp教材都有介绍
飘灵儿 该用户已被删除
7#
发表于 2015-1-27 07:49:25 | 只看该作者
Application:这个存储服务端的数据,如果不清除,会直到web应用程序结束才清除(例如重启站点)
兰色精灵 该用户已被删除
8#
发表于 2015-1-31 06:51:36 | 只看该作者
接下来就不能纸上谈兵了,最好的方法其实是实践。实践,只能算是让你掌握语言特性用的。而提倡做实际的Project也不是太好,因为你还没有熟练的能力去综合各种技术,这样只能使你自己越来越迷糊。
飘飘悠悠 该用户已被删除
9#
发表于 2015-2-6 17:59:12 | 只看该作者
最近在学asp,不要问我为什么不直接学.net,因为公司网站是asp做的所以有这个需要,卖了本书asp入门到精通,对里面的六大内置对象老是记不住,还有很多属性和方法看的头晕。
冷月葬花魂 该用户已被删除
10#
发表于 2015-2-17 22:50:46 | 只看该作者
ASP.Net摆脱了以前ASP使用脚本语言来编程的缺点,理论上可以使用任何编程语言包括C++,VB,JS等等,当然,最合适的编程语言还是MS为.NetFrmaework专门推出的C(读csharp),它可以看作是VC和Java的混合体吧。
admin 该用户已被删除
11#
发表于 2015-3-5 23:34:58 | 只看该作者
多看多学多思。多看一些关于ASP的书籍,一方面可以扩展知识面一方面可以鉴借别人是如何掌握、运用ASP的;多学善于关注别人,向同学老师多多学习,不论知识的大小;多思则是要将学到的知识灵活运用。
再现理想 该用户已被删除
12#
发表于 2015-3-12 16:36:46 | 只看该作者
以上是语言本身的弱点,在功能方面ASP同样存在问题,第一是功能太弱,一些底层操作只能通过组件来完成,在这点上是远远比不上PHP/JSP,其次就是缺乏完善的纠错/调试功能,这点上ASP/PHP/JSP差不多。
若相依 该用户已被删除
13#
发表于 2015-3-20 00:21:16 | 只看该作者
如何更好的使自己的东西看上去很不错等等。其实这些都不是问题的实质,我们可以在实践中不断提升自己,不断充实自己。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-9-22 07:16

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表