欢迎来到HELLO素材网! 南京网站制作选择顺炫科技
丰富的DIV CSS模版、JS,jQuery特效免费提供下载
当前位置:主页 > 建站教程 > 网站制作教程 >

剧烈引荐ASP初学者观看:常用ASP技术

发表于2019-04-23 21:03| 次阅读| 来源网络整理| 作者session

摘要:剧烈引荐ASP初学者观看:常用ASP技术
剧烈引荐ASP初学者观看:常用ASP技术

对于用ASP技术编程的初学者来说,无从下手是第一感觉,笔者曾经有这么一段教训。通过一番"磨练"当前,你就会找到灵感。现将自己编程中积攒的一些阅历,拟老本文,奉献给读者。

1 首先要学习一些例子程序。

接到义务后,不要盲目地急于编写代码,而是先看一下他人胜利的例子,然后在其上修正或模仿调试,这样会放慢你相熟的速度。例如,关于ASP编程的教科书上常常有这么一个例子出现,即显示系统以后工夫的语句:<%=now()%> ,别看这么简略的一条语句,里边却蕴含了ASP的编程思维和格式,会给你后边的工作带来很大的协助。比如说,测试IIS(Internet Information Server)WEB SERVER能否失常工作,用上边的一个语句测试就足够了。

2 在WINDOWS NT上装置ODBC后,要测试和后台数据库的确连通后,再末尾编程测试。
能够您没有看懂标题的意思,我在这里解释一下:比如说,后台数据库是ORACLE,那么在NT SEVER上首先要装置SQL*NET(或NET 8),然后配置ODBC,确定和ORACLE数据库连通,可能用SQL*PLUS测试,还要抉择和ORACLE数据库相反的字符集,这个工作要在注册表里实现。最后在ODBC里边测试和ORACLE数据库连通后,阐明WEB SERVER 到后台数据库端的工作就实现了,下边再末尾编程工作。反过来,你若先编程,后做ODBC的工作,那么你无奈调试程序能否正确,能够大大升高编程效率。在ODBC配置中要抉择MICROSOFT ODBC FOR ORACLE,不要抉择ORACLE ODBC DRIVER,否则不能和数据库建设联络。

在ASP程序中,和数据库衔接的语句是比较固定的,举例如下:
Set Conn = Server.CreateObject("ADODB.Connection")
Conn.Open "odbclink","o7people","peoplepd"
在这里,odbclink是数据源的名字,可能说成是ODBC和数据库衔接的定义,o7people是ORACLE的一个用户名,peoplepd是用户o7people的明码。
3 记载下出错信息,寻觅纠错规律。
在编程、调试过程中,是一个出错、纠错的循环过程,然而工夫长了,会发现一些规律,扫除谬误的效率会大大提高。
3.1 出错信息:
Microsoft OLE DB Provider for ODBC Drivers 谬误 ' 80040e14'
[Microsoft][ODBC driver for Oracle][Oracle]ORA-00933: SQL command not properly ended
/default.asp, 行781
这种谬误,普通是在执行 Conn.Execute("SQL 语句")操作时,所定义的"SQL 语句"有成绩,反省此语句就能发现成绩,如日期格式不对,等等。
zhezhong
3.2 出错信息:
ADODB.Field 谬误 ' 800a0bcd'
BOF 或 EOF 中有一个是"真",或许以后的记载已被删除,但运用程序要求操作的是以后的记载。
/lzjsblr.asp, 行123
这个谬误,普通发生在执行下列语句的过程中:
set RS = Conn.Execute("SQL 语句" )
varnum1=RS(0)
RS.CLOSE
所取的值RS(0)有意义或有意义,还要反省"SQL 语句"的正确性。
3.3 出错信息:
Microsoft VBScript 编译器谬误 谬误 ' 800a0409'
未完结的字符串常量
/people/default.asp, 行86
insert_sql = insert_sql & dwdm & ",'" & d1 & "','" & t1 & "','" & t2 & "',
--------------------------------------------------------------------------^
次项谬误也是出在SQL语句的定义上,反省引号、单引号等的配对情况。
4 下边是一个基于阅读器的网上用户注册注销程序,笔者在里边使用了一些技巧,奉献给感兴味的读者。
<html>
<head>
……
<
<%'和数据库衔接
Set Conn = Server.CreateObject("ADODB.Connection")
Conn.Open "odbclink","o7people","peoplepd"
'将抉择的数据放当抉择框
Set RS = Conn.Execute("SELECT dwmc FROM tab_dw order by dwdm")
%>
<% Do While Not RS.EOF %> <option><% = RS(0) %></option>
<%
RS.MoveNext
Loop
RS.Close
%>
<%
'定义变量
Dim D1,D2,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,csrq,sqrq
'事情触发按钮
B1="commit"
B2="return"
%>
<%
'将信息初始化
Sub Reset()
D1 = ""
……
T9 = date()
T10 = ""
End Sub
%>
<%
Call Reset()
%>
<%
'信息提交条件(触发条件)
if Request("B1") = "commit" Then ' Save Button
D1 = Request("D1")
set DWDM_RS = Conn.Execute("SELECT dwdm FROM table_dw where dwmc='"&D1&"' " )
DWDM=DWDM_RS(0)
DWDM_RS.CLOSE
D2 = Request("D2")
……
'日期数据转换成ORACLE辨认的格式
csrq = DAY(T6) & "-" & month_array(Month(T6)) & "-" & Year(T6)
sqrq = DAY(T9) & "-" & month_array(Month(T9)) & "-" & Year(T9)
'定义SQL语句
Sql_insert = "INSERT INTO peopleuser(dwdm,dwmc,sjks,tele,address,zipcode,xm,xb,csrq,peoplename,peoplepd,sqsj,bz) VALUES ('"
Sql_insert = Sql_insert & DWDM & "','" & D1 & "','" & T1 & "','" & T2 & "','" & T3 & "','" & T4 & "','"
Sql_insert = Sql_insert &T5&"','"& D2 & "','" & CSRQ & "','" & T7 & "','" & T8 & "','" & SQRQ & "','"
Sql_insert = Sql_insert & T10 & "')"
'将信息入库
Set LFMC_R4 = Conn.Execute(Sql_insert)
'信息提交实现后,将屏幕信息初始化
call reset()
end if
%>

。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。

  1、设计布局
  如今是模块化程序设计的天下,运用程序要完成的指标就是金字塔尖,停止程序设计布局的意义就在于,对造成金字塔的根底模块停止划分,布局得越具体,模块分工越明白,越容易明确下一步该做什么,这好比搭积木的游戏,你可能把你的积木块组合成各种各样的外形,但首先要相熟每个积木块的性能。

  2、有恃无恐
  实战之前,先找几个样例程序钻研钻研,最最少明确怎样扫尾,怎样开头,别打无预备之仗。

  3、葵花宝典
  做一份所用程序文语的精简列表,包括根本数据类型、各类运算符阐明、根本语句构造、常用要害词(保留字)、常用函数(控件)阐明等等。

  4、自由独立
  为你的运用程序建设一个单独的目录,这样既方便运用程序言件的治理,而且假设你要给程序搬“家”,卷起铺盖就可能走人了。

  5、见名知意
  程序再小,用的变量也不会少,变量起名该当见名知意是个老话题了,益处是不言而喻的。引荐程序员利用“匈牙利命名法”,它会使你的起名工作变得轻而易举,而且相当业余。

  6、对称之美
  中国人讲究对称之美,用在编程里也很适合,假设程序里用到A循环嵌套B判别,B判别又蕴含C循环之类的构造,记着利用缩进法,让A:ENDDO对齐A:DO,B:ENDIF对齐B:IF……诸如此类,依次缩进,总之对称就等于美观加易读。

  7、多加注解
  对程序中自定义的变量、函数、子程序加以性能性的注释阐明,别嫌费事。假设过了三月五月,连本人写的货色都看不明确了,那才大费事。

  8、环境保护
  假设运用程序需求修正系统设置,记着运用末尾前先保存设置,运用完结后要恢复设置,千万别污染环境。

  9、拿来主义
  一集体的力气是有限的,大家的力气是无限的,往常多看看他人的程序,假设碰巧有好的阅历,巧的方法,用得上的段子,无妨拿来。

  10、忍者无敌
  当你以为程序代码写的“百分百”正确,而程序编译执行百分百有故障,你根本属于晕菜的时分,千万要忍,歇口吻,重头来,别放弃!相信最终的成功是属于你的!

。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。

1.记载集关闭之前再次打开:
------------------------------------
sql="select * from test"
rs.open sql,conn,1,1
if not rs.eof then
dim myName
myName=rs("name")
end if
sql="select * from myBook"
rs.open sql,conn,1,1
-------------------------------------
处理:在第二次rs.open之前先关闭 rs.close

set rs1=server.createobject
rs1.open sql,conn,1,1

2,用SQL要害字做表名或字段名
-------------------------------------
sql="select * from user"
rs.open sql,conn,1,1
-------------------------------------
user为sql要害字
处理:改为
sql="select * from [user]"


3,用锁定模式去停止update
-------------------------------------
sql="select * from [user]"
rs.open sql,conn,1,1
rs.addnew

rs("userName")="aa"
rs.update
-------------------------------------
以后记载集的打开模式为只读
处理:
改为
rs.open sql,conn,1,3

4,在查询语句中采用的对比字段值与字段类型不符
-----------------------------------------
sql="select * from [user] where"
rs.open sql,conn,1,1
-----------------------------------------
假定表中设计ID为数字型,那么些时出错。
处理:
sql="select * from [user] whereselect * from [user] whereselect * from [user] whereselect * from [user] whereaa"
那么sql将成为
sql="select * from [user] where id=aa"
处理:
在后面加上
if isnumeric(myID)=false then 出错揭示

这也可能有效防止 sql injection 漏洞攻击。

7,因为数据库文件所在目录的NTFS权限而惹起的'不能更新。数据库或对象为只读"谬误。
阐明:
WIN2K系统间断了WINNT系统的NTFS权限。
对于系统中的文夹都有默许的平安设置。
而经过HTTP对WWW访问时的系统默许用户是 iusr_计算机名 用户 ,它属于guest组。
当经过HTTP访问时,可能ASP或JSP,也或是PHP或.NET程序对数据停止修正操作:
比如:
当打开某一个文章时,程序设定,文章的浏览次数=原浏览次数+1
执行
conn.execute("update arts set clicks=clicks+1 where id=n")
语句时,假设 iusr_计算机名 用户没有对数据库的写权限时,就会出错.
处理方法:
找到数据库所在目录
右键》属性》平安选项卡》设置 iusr_计算机名 用户的写权限(当然,也可能是everyone)