20编程21编程爱好者22vb编程,23数控编程24编程中国25编程论坛26编程语言27游戏编程28编程软件下载29编程工具30socket编程31网络编程32编程器33c语言编程,34flash编程35编程软件36数控车床编程37windows编程38编程入门,39windows核心编程40cnc编程41vc 编程,42linux 编程43asp编程44vb编程实例45串口编程46手机编程47编程教程48plc编程,49单片机编程50vc 网络编程51excel编程,52unix网络编程53编程学习,54编程之道55数据库编程56单片机编程器57黑客编程58计算机编程59网页编程60嵌入式编程,61编程高手箴言62flash编程教程63vfp编程64windows网络编程,65编程基础66c语言编程实例67c语言编程软件68vf编程69shell编程,70vb数据库编程71matlab编程,72c语言编程工具73编程思想74php编程,75c编程76jsp编程77电脑编程技巧与维护,78三菱plc编程软件,79vb编程软件下载80pb编程81数控编程实例82asp编程工具,83c专家编程,84win32编程85数控铣床编程86asp.net高级编程,,87vc 数据库编程88vba编程89jsp高级编程90c语言编程宝典,91unix环境高级编程;92编程珠玑93delphi编程94delphi数据库编程95vb编程教程96单片机编程软件
1编程爱好者网站2vb编程网站,3电子商务网站编程4游戏编程网站5最大的编程网站6网站编程软件7可编程逻辑中文网站8网站 编程 语言9网站编程 数据库,10jsp网站编程11asp编程网站12网站编程电子书13好的编程网站,14c语言编程网站15编程门户网站16如何学习网站编程17百度网站的编程语言18vb编程乐园网站指南19wince 编程网站
1asp.net2asp教程,3asp源码4asp免费空间5asp论坛6asp代码7asp源代码8asp下载,9asp源码下载10asp木马11asp.net教程12asp学习13什么是asp14asp空间,15admin.asp dir16asp程序17asp教程下载18asp.net 2.019asp整站程序,20asp文件21十天学会asp22asp入门23asp源程序24asp实例25asp函数26asp服务器27asp.net论坛28asp id,29asp整站下载30asp网站31asp论坛下载32asp源代码下载,33asp整站34asp技术35asp access36asp.net源码37asp简介38asp免费空间申请39asp.net下载,40asp留言板41asp sql42asp 数据库43asp站长助手44asp连接数据库45asp留言本,46asp.net教程下载47asp分页48asp格式49asp论坛程序50asp.net源代码51asp软件52asp模板53asp session54asp语法,55如何打开asp文件56asp解密57asp编程58asp.net实例,59asp实例教程60asp程序下载61asp计数器62asp.net入门,63asp运行环境64asp基础教程65apache asp66asp入门教程,67asp编辑器68asp组件69asp连接access70conn.asp71asp书籍,72asp论文73asp工具74asp文件上传75asp探针76asp原代码下载77asp include78user wantpws.asp79asp split,80asp fso81asp网页制作82printpage.asp83什么是asp.net,84index.asp85asp.net datagrid86asp基础87asp replace88asp代码下载89asp新闻系统
1php论坛2免费php空间,3php下载4php源码5php mysql6php教程7php文件8php空间9apache php10什么是php11apache php mysql12php学习13php论坛下载14iis php15php cms16php入门17php blog18php手册,19php代码20php整站程序21php session22php安装23php源码下载24php配置25php源代码26php cookie27php网站28iis php mysql29php编程30php留言板31php探针32php注入33php.ini34php运行环境35index.php36php教程下载,37php论坛程序38php 文件上传39php服务器40php环境41php 函数;42php格式43php编辑器44php editor45如何打开php文件46php access47十天学会php48php模板49php xml;50php程序51php留言本52php文件怎么打开53php技术54ajax php55php简介56php注入工具57打开php文件58php语言59php mail;60php软件;61免费php mysql空间62php self63php 数组.64php分页,65php nuke66php阅读器67免费php空间申请68国外免费php空间69php程序下载70php 正则表达式71asp php,72php网站管理系统73php程序设计74php是什么文件75php 实例76php 开发工具77php 验证码78php官方网站79php学习资料
1jsp教程2jsp源码3jsp论坛4什么是jsp5jsp源代码6jsp空间7jsp学习8jsp文件9jsp mysql,10jsp入门11jsp连接数据库12jsp技术13eclipse jsp14jsp分页15jsp源代码下载16jsp access17jsp教程下载18jsp开发工具,19jsp代码20jsp简介21jsp环境配置22jsp连接mysql,23jsp实例24免费jsp空间25jsp配置26jsp session,27jsp运行环境28jsp下载29jsp网站30jsp include31jsp编程,32jsp介绍33jsp 数据库34jsp设计35jsp servlet36jsp标签37jsp应用开发详解38jsp 中文39jsp oracle40jsp论文41jsp 文件上传,42jsp高级编程43jsp源码下载44jsp 乱码45jsp开发46jsp分页显示47jsp sql48jsp连接sql49jsp 页面跳转50jsp request51eclipse开发jsp52iis jsp53jsp开发环境54jsp sqlserver,55jsp cookie56jsp服务器57jsp连接access58jsp毕业论文59jsp新闻发布系统60jsp留言板61jsp 电子书62jsp forward63jsp中文网64tomcat jsp65jsp语法66jsp留言本67asp jsp,68jsp import69jsp源程序70jsp基础71jsp毕业设计,72jsp格式73jsp 中文乱码,74jsp开发实例75jsp书籍76jsp论坛下载77jsp 上传,78jsp计数器79jsp 注释80jsp电子教程81jsp 保存用户名密码,82jsp的优点83jsp软件下载84jsp语言85jsp代码下载86jsp blog87jsp 打印88jsp手册

思顿科技-专业网站制作指南、网页设计制作教程、免费网页制作素材下载、免费学习网页制作指南,专业网站建设服务、网站制做指南、免费网页制作指南、网页制作服务、免费空间域名服务、
首页
网页教程
网页素材
收录查询
工具下载
网站欣赏
网站论坛
免费博客
建站服务

ASP.NET高级教程(五)-实战篇(中)
你当前的位置:网站制作指南 --> 技术文档全集 (www.STasp.com)
ASP.NET高级教程(五)---实战篇(结合论坛用户操作谈ASP.NET表单验证)(中)

   做好准备工作,现在就要动真格的了,先让我们看看用户注册的实现。前边已经讲过,ASP.NET可以实现业务逻辑和HTML代码分离,那么让我们来看看到底是如何实现的,下面这个文件是用户注册的页面部分,原型是根据我站点的风格制作的:

<%@PAGE LANGUAGE="C#" CODEBEHIND="REGISTER.CS" AUTOEVENTWIREUP="FALSE" INHERITS="BBS.REGISTER" %>
<%@REGISTER TAGPREFIX="MY" NAMESPACE="BBS.UCTRL"%>
<HTML><HEAD>
<TITLE>新用户注册</TITLE>
<META NAME=VS_TARGETSCHEMA CONTENT="HTML 4.0">
<LINK REL="STYLESHEET" HREF="IMAGES/STYLE.CSS">
<META HTTP-EQUIV=CONTENT-TYPE CONTENT="TEXT/HTML; CHARSET=GB2312">
    <META NAME="GENERATOR" CONTENT="MICROSOFT VISUAL STUDIO 7.0">
    <META NAME="CODE_LANGUAGE" CONTENT="C#"></HEAD>
<SCRIPT LANGUAGE=JAVASCRIPT>
  FUNCTION ONPREVIEW()
  {
    DIVPREVIEW.INNERHTML = FORM1.TXTSIGNATURE.VALUE ;
  }
</SCRIPT>
  <BODY>
    
    <FORM METHOD="POST" RUNAT="SERVER" ID=FORM1>&NBSP;

    <MY:MYHEAD ID="MYHEAD1" RUNAT="SERVER"></MY:MYHEAD>

<!----------------------外面表格形成边框-------------------------------------->
<TABLE WIDTH='722' BORDER='0' CELLSPACING=0
   CELLPADDING='0' ALIGN='CENTER'>
  <TBODY>
   <TR>
   <!-------------------左边竖线---------------------------------------------->
     <TD BGCOLOR='#0097C0' WIDTH='1'>
       <IMG SRC='IMAGES/SHIM.GIF' WIDTH=1>
      </TD>
      <TD WIDTH=720 ALIGN=MIDDLE><BR><BR><BR>
   <!-------------------左边竖线---------------------------------------------->



<!--------------新用户注册开始---------------------------------------------->    
    <TABLE WIDTH=600 ALIGN=CENTER BORDER=0 CELLPADDING=4 CELLSPACING=1
        ID="TBLREGISTER" CLASS=CN BGCOLOR=#000000 RUNAT=SERVER>
        <TBODY>
        <TR BGCOLOR=#FFFFFF>
            <TD COLSPAN=3>
                <P ALIGN=CENTER>新用户注册</P>
            </TD>
        </TR>
        <!--------------用户名开始-------------------------------------------------------->
        <TR BGCOLOR=#FFFFFF>
            <TD WIDTH=60>
                用户名
            </TD>
            <TD WIDTH=300>
                <ASP:TEXTBOX ID="TXTUSERNAME" MAXLENGTH=20 COLUMNS=20 RUNAT="SERVER"></ASP:TEXTBOX>
                <FONT COLOR=RED>*</FONT>
            </TD>
            <TD WIDTH=240>
                用户笔名,4-20字符
                <ASP:REQUIREDFIELDVALIDATOR ID="REQUSERNAME" DISPLAY=DYNAMIC
                    CONTROLTOVALIDATE="TXTUSERNAME" RUNAT=SERVER>
                    不能为空!
                </ASP:REQUIREDFIELDVALIDATOR>
                <ASP:REGULAREXPRESSIONVALIDATOR ID="REGUSERNAME" DISPLAY=DYNAMIC
                    CONTROLTOVALIDATE="TXTUSERNAME" RUNAT=SERVER VALIDATIONEXPRESSION="[^']{4,20}">
                    用户名非法!
                </ASP:REGULAREXPRESSIONVALIDATOR>                        
                <ASP:CUSTOMVALIDATOR ID="CUSUSERNAME" CONTROLTOVALIDATE="TXTUSERNAME"
                    ONSERVERVALIDATE="VALIDUSER" DISPLAY=DYNAMIC RUNAT=SERVER>
                    该用户已存在。
                </ASP:CUSTOMVALIDATOR>                
            </TD>
        </TR>
        <!--------------用户名结束-------------------------------------------------------->

        <!--------------用户密码开始-------------------------------------------------------->
        <TR BGCOLOR=#FFFFFF>
            <TD WIDTH=60>
                密码
            </TD>
            <TD WIDTH=300>
                <ASP:TEXTBOX ID="TXTPASSWORD" MAXLENGTH=10 COLUMNS=10
                    TEXTMODE=PASSWORD RUNAT=SERVER></ASP:TEXTBOX>
                <FONT COLOR=RED>*</FONT>
            </TD>
            <TD WIDTH=240>
                用户密码,4-10字符
                <ASP:REQUIREDFIELDVALIDATOR ID=REQUIREDFIELDVALIDATOR1 DISPLAY=DYNAMIC
                    CONTROLTOVALIDATE="TXTPASSWORD" RUNAT=SERVER>
                    不能为空!
                </ASP:REQUIREDFIELDVALIDATOR>
                <ASP:REGULAREXPRESSIONVALIDATOR ID=REGULAREXPRESSIONVALIDATOR1 DISPLAY=DYNAMIC
                    CONTROLTOVALIDATE="TXTPASSWORD" RUNAT=SERVER VALIDATIONEXPRESSION="[^']{4,10}">
                    密码非法!
                </ASP:REGULAREXPRESSIONVALIDATOR>                                        
            </TD>
        </TR>
        <!--------------用户密码结束-------------------------------------------------------->
        
        <!--------------验证密码开始-------------------------------------------------------->
        <TR BGCOLOR=#FFFFFF>
            <TD WIDTH=60>
                验证密码
            </TD>
            <TD WIDTH=300>
                <ASP:TEXTBOX ID=TXTPASSWORD1 MAXLENGTH=10 COLUMNS=10
                     TEXTMODE=PASSWORD RUNAT=SERVER></ASP:TEXTBOX>
                <FONT COLOR=RED>*</FONT>
            </TD>
            <TD WIDTH=240>
                再次输入密码。
                <ASP:COMPAREVALIDATOR ID="COMPASSWORD" DISPLAY=DYNAMIC
                 CONTROLTOCOMPARE="TXTPASSWORD" CONTROLTOVALIDATE="TXTPASSWORD1" RUNAT=SERVER>
                    两次录入的密码不同!
                </ASP:COMPAREVALIDATOR>
            </TD>
        </TR>
        <!--------------验证密码结束-------------------------------------------------------->

        <!--------------EMAIL开始-------------------------------------------------------->
        <TR BGCOLOR=#FFFFFF>
            <TD WIDTH=60>
                EMAIL
            </TD>
            <TD WIDTH=300>
                <ASP:TEXTBOX ID="TXTEMAIL" MAXLENGTH=100 COLUMNS=30 RUNAT=SERVER></ASP:TEXTBOX>
            </TD>
            <TD WIDTH=240>
                您的电子邮件地址,您可以不填,但请不要胡填。
                <ASP:REGULAREXPRESSIONVALIDATOR ID="REGEMAIL" DISPLAY=DYNAMIC
                    CONTROLTOVALIDATE="TXTEMAIL" VALIDATIONEXPRESSION="[^']*" RUNAT=SERVER>
                    非法字符
                    </ASP:REGULAREXPRESSIONVALIDATOR>
            </TD>
        </TR>
        <!--------------EMAIL结束-------------------------------------------------------->

        <!--------------个人主页开始-------------------------------------------------------->
        <TR BGCOLOR=#FFFFFF>
            <TD WIDTH=60>
                个人主页
            </TD>
            <TD WIDTH=300>
                <ASP:TEXTBOX ID="TXTHOMEPAGE" MAXLENGTH=150 COLUMNS=30 RUNAT=SERVER></ASP:TEXTBOX>
            </TD>
            <TD WIDTH=240>
                您的主页,您可以不填,但请不要胡填。
                <ASP:REGULAREXPRESSIONVALIDATOR ID="REGHOMEPAGE" DISPLAY=DYNAMIC
                    CONTROLTOVALIDATE="TXTHOMEPAGE" VALIDATIONEXPRESSION="[^']*" RUNAT=SERVER>
                非法字符。
                </ASP:REGULAREXPRESSIONVALIDATOR>
            </TD>
        </TR>
        <!--------------个人主页结束-------------------------------------------------------->

        <!--------------签名开始-------------------------------------------------------->
        <TR BGCOLOR=#FFFFFF>
            <TD WIDTH=60>
                签名
            </TD>
            <TD WIDTH=300>
                <ASP:TEXTBOX ID="TXTSIGNATURE" MAXLENGTH=150 COLUMNS=30 ROWS=6 TEXTMODE=MULTILINE RUNAT=SERVER></ASP:TEXTBOX>
            </TD>
            <TD WIDTH=240 VALIGN=TOP>
                <DIV ID="DIVPREVIEW">
                你可以制作自己的签名,不超过255个字符,不能用SCRIPT。<BR><BR>
                </DIV><BR>
                
                <INPUT TYPE=BUTTON ID="BTNPREVIEW" VALUE="预览" ONCLICK="ONPREVIEW()"><BR>
                <ASP:REGULAREXPRESSIONVALIDATOR ID=REGULAREXPRESSIONVALIDATOR2 DISPLAY=DYNAMIC
                    CONTROLTOVALIDATE="TXTSIGNATURE" VALIDATIONEXPRESSION="[^']{0,255}" RUNAT=SERVER>
                使用非法字符或超过255个字符。
                </ASP:REGULAREXPRESSIONVALIDATOR>
            </TD>
        </TR>
        <!--------------签名结束-------------------------------------------------------->
        
        <TR BGCOLOR=#FFFFFF>
            <TD COLSPAN=3 ALIGN=CENTER>
                <ASP:BUTTON ID="BTNSUBMIT" TEXT="确认"  ONCLICK="ONSUBMIT" RUNAT=SERVER></ASP:BUTTON>
            </TD>
        </TR>
    </TABLE><BR><BR><BR>
<!----------------------------------新用户注册结束---------------------->

   <!-------------------右边竖线---------------------------------------------->
     <TD BGCOLOR='#0097C0' WIDTH='1'>
       <IMG SRC='IMAGES/SHIM.GIF' WIDTH=1>
      </TD>
   <!-------------------右边竖线---------------------------------------------->
    </TR>
    
    <!-------------------下边横线---------------------------------------------->
    <TR>
     <TD COLSPAN=3 HEIGHT=1 BGCOLOR=#0097C0><IMG SRC='IMAGES/SHIM.GIF'WIDTH=1 HEIGHT=1></TD>    
    </TR>
    <!-------------------下边横线---------------------------------------------->
</TABLE>

    <MY:BOTTOM ID="MYBOTTOM" RUNAT="SERVER"></MY:BOTTOM>
    </FORM>
  </BODY></HTML>

<!--------------------文件结束--------------------------------->

    怎么样,看上去很熟悉吧,除了页首两句及下面WEBFORM中带RUNAT=SERVER的WEBCONTROL,是不是和普通的HTML一样?注意到页首第一句中的CODEBEHIND="REGISTER.CS"吗,它指定本页后面的代码文件是REGISTER.CS,这是ASP.NET提供的一种机制,它可以将业务逻辑隐藏在与.ASPX同名的CS文件中,而运行时先把这个CS文件编译,这样不但可以提高运行效率,也使代码隐藏起来,避免了ASP中由于系统漏洞而造成源码泄漏所造成的问题。那么,这个包含业务逻辑的代码文件是怎样的呢?下面是这个文件:
NAMESPACE BBS
{
    USING SYSTEM;
    USING SYSTEM.COLLECTIONS;
    USING SYSTEM.COMPONENTMODEL;
    USING SYSTEM.DATA.SQL;
    USING SYSTEM.DRAWING;
    USING SYSTEM.WEB;
    USING SYSTEM.WEB.SESSIONSTATE;
    USING SYSTEM.WEB.UI;
    USING SYSTEM.WEB.UI.WEBCONTROLS;
    USING SYSTEM.WEB.UI.HTMLCONTROLS;
    USING BBS.UCTRL ;
    //USING BBS.MYCLASS ;
    USING MYOWNCLASS ;

    /// <SUMMARY>
    ///    SUMMARY DESCRIPTION FOR REGISTER.
    /// </SUMMARY>
    PUBLIC CLASS REGISTER : SYSTEM.WEB.UI.PAGE
    {
        PROTECTED SYSTEM.WEB.UI.WEBCONTROLS.BUTTON BTNSUBMIT;
        PROTECTED SYSTEM.WEB.UI.WEBCONTROLS.TEXTBOX TXTHOMEPAGE;
        PROTECTED SYSTEM.WEB.UI.WEBCONTROLS.TEXTBOX TXTEMAIL;
        PROTECTED SYSTEM.WEB.UI.WEBCONTROLS.COMPAREVALIDATOR COMPASSWORD;
        PROTECTED SYSTEM.WEB.UI.WEBCONTROLS.TEXTBOX TXTPASSWORD1;
        PROTECTED SYSTEM.WEB.UI.WEBCONTROLS.REGULAREXPRESSIONVALIDATOR REGULAREXPRESSIONVALIDATOR1;
        PROTECTED SYSTEM.WEB.UI.WEBCONTROLS.REQUIREDFIELDVALIDATOR REQUIREDFIELDVALIDATOR1;
        PROTECTED SYSTEM.WEB.UI.WEBCONTROLS.TEXTBOX TXTPASSWORD;
        PROTECTED SYSTEM.WEB.UI.WEBCONTROLS.CUSTOMVALIDATOR CUSUSERNAME;
        PROTECTED SYSTEM.WEB.UI.WEBCONTROLS.REGULAREXPRESSIONVALIDATOR REGUSERNAME;
        PROTECTED SYSTEM.WEB.UI.WEBCONTROLS.REQUIREDFIELDVALIDATOR REQUSERNAME;
        PROTECTED SYSTEM.WEB.UI.WEBCONTROLS.LABEL LBLMESSAGE;
        PROTECTED SYSTEM.WEB.UI.WEBCONTROLS.TEXTBOX TXTUSERNAME;
        PUBLIC MYHEAD MYHEAD1 ;

        //构造函数
        PUBLIC REGISTER()
        {
            PAGE.INIT += NEW SYSTEM.EVENTHANDLER(PAGE_INIT);
        }

        PROTECTED VOID PAGE_LOAD(OBJECT SENDER, EVENTARGS E)
        {
            IF (!ISPOSTBACK)
            {
                //
                // EVALS TRUE FIRST TIME BROWSER HITS THE PAGE
                //
            }
        }

        PROTECTED VOID PAGE_INIT(OBJECT SENDER, EVENTARGS E)
        {
            //
            // CODEGEN: THIS CALL IS REQUIRED BY THE ASP+ WINDOWS FORM DESIGNER.
            //
            INITIALIZECOMPONENT();
            THIS.MYHEAD1.POSITION = 2 ;
        }

        /// <SUMMARY>
        ///    REQUIRED METHOD FOR DESIGNER SUPPORT - DO NOT MODIFY
        ///    THE CONTENTS OF THIS METHOD WITH THE CODE EDITOR.
        /// </SUMMARY>
        PRIVATE VOID INITIALIZECOMPONENT()
        {
            THIS.LOAD += NEW SYSTEM.EVENTHANDLER (THIS.PAGE_LOAD);
        }

        //监测用户是否存在
        PUBLIC BOOL VALIDUSER(OBJECT SENDER , STRING VALUE)
        {
            BBSUSER MYUSER = NEW BBSUSER() ;
            BOOL BEXISTS ;
            TRY
            {
                BEXISTS = MYUSER.GETUSER(THIS.TXTUSERNAME.TEXT) ;            
            }
            CATCH(EXCEPTION E)        //如果出现异常
            {
#IF DEBUG
                RESPONSE.WRITE (E.MESSAGE) ;
                RETURN FALSE ;
#ENDIF
                SERVER.TRANSFER("ERROR.ASPX") ;
                
            }    
                
            RETURN !BEXISTS ;            
        }

        //提交按钮点击
        PUBLIC VOID ONSUBMIT(OBJECT SENDER , EVENTARGS E)
        {
            IF (PAGE.ISVALID)
            {
                //数据入库
                TRY
                {
                    BBSUSER MYUSER = NEW BBSUSER() ;
                    IF(!MYUSER.GETUSER(TXTUSERNAME.TEXT))
                    {
                        MYUSER.CREATEUSER(BBSUSER.CREATETYPE.CREATE , TXTUSERNAME.TEXT , TXTPASSWORD.TEXT ,
                                        TXTEMAIL.TEXT , TXTHOMEPAGE.TEXT , "") ;
                    }
                }
                CATCH(EXCEPTION EXP)
                {
#IF DEBUG
                    RESPONSE.WRITE ("出现异常:" + EXP.MESSAGE) ;
                    RETURN ;
#ENDIF//DEBUG
                    SERVER.TRANSFER("ERROR.ASPX") ;
                }
            }
        }

                    
    }

}

   什么?还是看着眼熟?没错,是不是和前边我定义的那个类差不多?是,本来ASP.NET就是把这个页当作一个对象,注意类定义的那行代码:PUBLIC CLASS REGISTER : SYSTEM.WEB.UI.PAGE , 前面你可以理解,是定义一个REGISTER对象,那:号后面的SYSTEM.WEB.UI.PAGE是什么意思呢?它说明这个REGSITER类是SYSTEM.WEB.UI.PAGE类的派生类(子类),也就是说REGISTER类除了自己成员变量、属性、方法外,还继承SYSTEM.WEB.UI.PAGE类的所有公共(PUBLIC)或保护(PROTECTED)成员变量、属性和方法。明白了这些,你可以安心坐下来研究代码了,做好下面关于表单验证内容的学习准备。


 
| 关于我们 | 联系我们 | 业务合作 | 友情链接 | 网站地图 |
版权所有©思顿科技-专业网站制作指南2004-2006 在线技术支持- QQ:63127313