您当前位置:首页 > 文章中心 > SCSCMS > 技术探讨

On Error Resume Next

稿件来源: 阳光企业网站管理系统   撰稿作者: 太阳光   发表日期: 2011-04-13   阅读次数: 155   查看权限: 游客查看

On Error Resume Next是什么意思?

在大部分ASP程序中,特别是数据库连接的地方,常会看到一行代码On Error Resume Next
On Error Resume Next是什么意思?
我们在正常情况下运行ASP,当发生错误时将显示错误信息,同时代码也终止执行。
而使用了On Error Resume Next会使程序遇到错误时代码继续执行。这可是双刃剑!

我们以飞腾V2.01版本inc/ft_conn.asp文件为例

option explicit
on error resume next
'数据库地址设置,根据相应情况作更改,名称越复杂越好。
dim conn,connstr
const db="data#v390/feitec#data.asa"
connstr="provider=microsoft.jet.oledb.4.0;data source=" & server.mappath(db)
set conn = server.createobject("adodb.connection")
conn.open connstr
if err then
	err.clear
	conn.close
	set conn = nothing
	response.write "数据库连接出错,请检查连接字串。"
	response.end
end if

一般来说,如果我们数据库连接不成功都会提示:

Microsoft JET Database Engine (0x80004005)
'E:\网络工作\data#v390\feitec#data.asa'不是一个有效的路径。 确定路径名称拼写是否正确,以及是否连接到文件存放的服务器。
/inc/Ft_conn.asp, 第 20 行

而以上代码我们添加了on error resume next则程序会提示“数据库连接出错,请检查连接字串。”感觉上挺好的,防止了我们的数据库暴露出来!但是它也是可以怕的,因为它抹杀了所有程序错误,不管你的代码是否正确照常执行!假如在set rs=conn.execute("select * from 表")这种情况出错,那CPU就会100%的占用直到死循环,好点服务器还勉强,差点的服务器遭殃,空间商不停你网站才怪!

所以我一直不推荐使用此代码,这犹如自欺欺人一样。让程序带病上岗,而永远表现出都是正常的。真正检查时才会发现全身是病!
解决方法:在以上代码最后加上一句on error goto 0
on error goto 0 是禁用错误程序程序,即保护你的数据库地址不暴露,又不影响其他代码检测!

关键词: Error,asp错误   编辑时间: 2011-04-13

  • 感到高兴

    0

    高兴
  • 感到支持

    0

    支持
  • 感到搞笑

    0

    搞笑
  • 感到不解

    0

    不解
  • 感到谎言

    0

    谎言
  • 感到枪稿

    0

    枪稿
  • 感到震惊

    0

    震惊
  • 感到无奈

    0

    无奈
  • 感到无聊

    0

    无聊
  • 感到反对

    0

    反对
  • 感到愤怒

    0

    愤怒
0%(0)
0%(0)
共有0 条评论 发言请遵守【相关规定

网友评论

会员头像
发 表同步腾讯微博    验证码:  点击更新请先登陆
  • 暂无评论
关闭模块文章图片 article Pictrue
  • 我的妈妈爸爸
  • 基于koa2+mysql+vue2.0+Element阳光内容管理系统
  • 代码覆盖率工具 Istanbul 入门教程
  • 全栈工程师的武器——MEAN
  • 9款超炫的 CSS3 复选框(Checkbox)
  • 微信开发在线翻译功能
  • CSS3那些不为人知的高级属性
  • 给easyui的datebox添加清空事件
  • flash写字效果
  • kendoUI系列教程之DropDownList下拉菜单
  • kendoUI系列教程之datetimepicker日期时间选择
  • kendoUI系列教程之datepicker日期选择
  • kendoUI系列教程之combobox下拉列表框
  • kendoUI系列教程之colorpicker
  • kendoUI系列教程之calendar日历表
  • kendoUI系列教程之autocomplete自动补齐