- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的 onclick 函数在我传递一个变量时工作得很好,但在我尝试传递两个变量时却没有响应。我的语法有问题吗?
支持此代码的所有内容都已经过测试并且工作正常,所以我确定 onclick 代码行的语法有问题。任何帮助都是极好的。
------------onclick code---------------------------------------------------
Response.Write "<td class=""alt""><input type=""button"" onclick=""deleteRecordAtt(" & AttID &","& StoredPath & " )"" value=""remove"" /></td></tr>"
-----------function reference code in main page---------------------------------------
function deleteRecordAtt(AttID, StoredPath){
if(confirm("This will delect the attachment path"))
{
document.location.href="delete_attachments.asp?EMAIL_LETTERS_HOLD_ID="+AttID+"&RedirURL="+escape(document.location.href);
}
}
-----------function code in source page ----------------------------------------------
<%
Dim AttID, RedirectURL, StoredPath
Dim objConn
AttID=request("EMAIL_LETTERS_HOLD_ID")
RedirectURL=request("RedirURL")
Set objConn = CreateObject("ADODB.Connection")
objConn.Open "DSN=MyDSN"
objConn.Execute("UPDATE EMAIL_SEND_ATTACHMENTS set ATTACHMENTS = Replace(LTRIM(RTRIM(ATTACHMENTS)), '"& StoredPath & "' ,'') WHERE EMAIL_LETTERS_HOLD_ID= "& AttID & " ")
objConn.Close
Set objConn = Nothing
response.redirect RedirectURL
%>
最佳答案
onclick=""deleteRecordAtt(" & AttID &","& StoredPath & " )""
在不转义的情况下连接字符串——从来都不是一个好主意。大概 AttID 是一个整数,这就是为什么你不用那个参数,但 StoredPath 是一个字符串。由于您没有转义或包装该字符串,您上面的 Write 将以 HTML 代码结束,例如(假设“storedpath”是一个文件名):
onclick="deleteRecordAtt(123, file.gif)"
当然,未加引号的“file.gif”不能解析为 JavaScript:会导致语法错误。确保您在浏览器中打开了脚本错误,这样您就可以看到何时出现此类错误,而不是静静地失败。
天真的解决方案是添加包装引号:
onclick=""deleteRecordAtt(" & AttID &", '"& StoredPath & "' )""
结果是:
onclick="deleteRecordAtt(123, 'file.gif')"
这会起作用。但是,如果您的 StoredPath 变量中包含单引号怎么办?或 < 或 & 字符 - 这些总是需要使用 Server.HTMLEncode() 进行编码,除非您希望应用程序中存在跨站点脚本安全漏洞。
您需要的是一个 VBScript 函数,通过将带外字符转义为 JavaScript\xNN 十六进制字符转义,将字符转义为 JavaScript 字符串文字。一个简单的版本将以类似的东西开始(未经测试,我不是 VBScript 编码器):
<%
jsLiteral= Replace(StoredPath, "\", "\x5C")
jsLiteral= Replace(jsLiteral, "'", "\x27")
jsLiteral= "'" & jsLiteral & "'"
%>
<input ... onclick="deleteRecordAtt(<%= AttID %>, <%= Server.HTMLEncode(jsLiteral) >)">
编辑以添加问题编辑:
objConn.Execute("UPDATE EMAIL_SEND_ATTACHMENTS set ATTACHMENTS = Replace(LTRIM(RTRIM(ATTACHMENTS)), '"& StoredPath & "' ,'') WHERE EMAIL_LETTERS_HOLD_ID= "& AttID & " ")
同样,在不转义的情况下连接字符串。这给你一个 SQL 注入(inject)错误 - StoredPath 变量中的单引号字符导致查询失败。如果攻击者说了类似的话:
StoredPath=', ''));DROP TABLE EMAIL_SEND_ATTACHMENTS;--
然后哎呀,再见数据库!更有可能的是,您会受到目前在网络上传播俄罗斯恶意软件的众多自动 SQL 注入(inject)攻击之一的攻击。</p>
转义您的 SQL 字符串文字,或者更好的是,使用参数化查询。
i click yes, and nothing happens
再次确保 JavaScript 错误已打开,以便您可以看到任何问题。我不知道在这种情况下是否是问题所在,但是:
document.location.href="delete_attachments.asp?EMAIL_LETTERS_HOLD_ID="+AttID+"&RedirURL="+escape(document.location.href);
应阅读:
location.href= "delete_attachments.asp?EMAIL_LETTERS_HOLD_ID="+AttID+"&RedirURL="+encodeURIComponent(location.href);
JavaScript 的 escape() 不应该被使用,因为它与 encodeURIComponent() 执行的正确 URL 编码微妙且恼人地不兼容。
还有 location - window.location 的缩写 - 实际上是与 document.location 不同的对象,如果您希望将浏览器移动到新页面,它是正确的使用对象。写入 document.location 应该不起作用,但如果幸运的话,有时在某些浏览器上它可能仍然可以。
关于javascript - 传递两个变量时的onclick语法问题,经典asp,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/457669/
本文实例总结了常用SQL语句优化技巧。分享给大家供大家参考,具体如下: 除了建立索引之外,保持良好的SQL语句编写习惯将会降低SQL性能问题发生。 ①通过变量的方式来设置参数 好:
写CSS的同学们往往会体会到,随着项目规模的增加,项目中的CSS代码也会越来越多,如果没有及时对CSS代码进行维护,CSS代码不断会越来越多。CSS代码交错复杂,像一张庞大的蜘蛛网分布在网站的各个位
所以我必须解决类的背包问题。到目前为止,我想出了以下内容。我的比较器是确定两个主题中哪一个是更好选择的函数(通过查看相应的(值,工作)元组)。 我决定迭代工作量小于 maxWork 的可能主题,并且为
前言:复杂类型说明 要了解指针,多多少少会出现一些比较复杂的类型,所以我先介绍一下如何完全理解一个复杂类型,要理解复杂类型其实很简单,一个类型里会出现很多运算符,他们也像普通的表达式一样,有优先级
代码如下: 复制代码代码如下: USE [tempdb] GO /****** Object: UserDefinedFunction [dbo].[fun
最近收到一个工作要求,让我完成一个每天一次的Linux服务器巡检工作(服务器的版本为红帽6.4),不可以使用监控软件来操作。在这里,把我的巡检过程和巡检脚本放送给大家做一参考。 首先,巡检内容
可以在 Classic ASP 中动态创建“空”对象并创建对象属性吗? 以这个 JavaScript 示例为例: var sample = new Object(); sample.prop = "O
我正在向旧的经典 asp 站点添加功能,但遇到了一个有趣的问题。页面上的以下行导致有用的错误“需要对象:''” strServerName = Request.ServerVariables("ser
我有一个经典的 ASP 应用程序,我正在处理日期截止。我的服务器位于中部时间,但我在东部时间。发生的情况是我的应用程序认为它早了一个小时,而我的截止时间晚了一个小时。我敢肯定,如果用户在太平洋时间,他
我是经典 ASP 的初学者。需要拆分一个由逗号分隔的许多电子邮件组成的字符串,并使用稍后生成的附加代码将结果插入(逐个电子邮件)到表格中。每条记录都应该有一个电子邮件地址。问题是我陷入了数组范围错误。
这个问题已经有答案了: one condition, multiple events (2 个回答) 已关闭 6 年前。 如何用更小的语句替换 1,2,3..。我尝试将 1 放入 10,但显示错误。
我是 ExtJS 的新手,所以我不知道是否可能。 Google 只回答如何为图表制作工具提示,所以... 我需要制作一个带有工具提示的网格,当用户将鼠标放在单元格上时将显示该工具提示。在该工具提示中,
我正在使用一个非常奇怪的 VB 版本...它不需要我告诉它什么是什么,它想自己弄清楚。 在 C# 中,我可以轻松地对数组进行硬编码...在 VB 中则不然。 我想在调用函数时创建一个硬编码数组...但
我的数据库访问代码如下: set recordset = Server.CReateObject("ADODB.Recordset") set cmd1 = Server.CreateObject(
我有 html 按钮和文本框的代码:文本框是我输入文本的地方,以便我可以在表格上进行一些更改。 'textbox " /> 'button Clear 我现在需要做的是单击“清除”按
我有一个表单,提交后会通过电子邮件发送。该表单使用 JavaScript 进行验证。经典 ASP 处理表单,即获取输入的数据、创建然后发送电子邮件。有报道称正在提交空白表格。仅发送标题和 Logo 。
加载页面 A.asp 默认情况下正在执行,从那里开始执行电子邮件的情况,如果是电子邮件,我们将调用页面 B。我想在控件被执行时执行相同的电子邮件情况从页面 B 转移到页面 A。请帮助我。 Page A
我正在使用经典 ASP 开发一个项目,例如,我想添加一些用户作为临时列表,当我提交表单时,这些数据将保存到数据库中。 我知道如何在 asp.net 中使用它,但不知道如何在经典 asp 中使用它。 例
我有一个带有简单 html 表的经典 ASP 页面,我想根据从数据库中提取的未知数量的记录循环表行,但是,当我使用 do/while 循环循环记录时,我收到一条错误消息,指出 Either BOF o
嘿,一直在寻找一段时间,但我似乎找不到任何有关如何在经典 asp 中处理日期的信息。 现在,我需要一种方法来计算今年过去的天数。我正在考虑一个简单的函数,它将获取当前日期,然后使用 (day = 1,
我是一名优秀的程序员,十分优秀!