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的朋友都知道表单验证是个比较头疼的问题,有经验的WEB程序员有这么一句话,那就是客户端不相信服务器端,服务器端不相信客户端。什么意思呢,就是说做表单验证时服务器端程序不能假定客户端程序是正确的而不加检测,这样如果客户端关闭JAVASCRIPT就可能造成出错,而如果只做服务器端检测,那么需要提交到服务器端再返回,那么效率会大打折扣,并且对于用户极不方便。所以只能客户端和服务器端做两次验证。现在ASP.NET提供了新的表单验证机制,下面我将结合实例简单讲一下,想要了解ASP.NET提供的几个验证WEBCONTROL的详细资料,可以参照我的ASP+初级教程。
    在讲表单验证以前,先做点准备工作。前面谈到用ASP.NET开发需要转换编程思维,也就是用面向对象的思想去考虑问题,BBS对象我们已经构造好了,现在让我们来看一下一个论坛系统中另外一个很重要的对象:用户。可以说,论坛系统的主体是用户,没有用户那也就谈不上什么论坛了,所以围绕用户的操作很多,比如说添加/删除用户,查询/修改用户资料等等,有些论坛还有积分机制,根据用户登录次数或发言多少来决定积分,已表明该用户的活跃程度。那么,我们应该如何来构造论坛用户这个对象呢?看看

下面的类定义:
NAMESPACE MYOWNCLASS
{
    USING SYSTEM;
    USING MYOWNCLASS ;
    USING SYSTEM.DATA.SQL ;
    USING SYSTEM.WEB.UTIL ;

    ////////////////////////////////////////////////////////////////////
    //
    // CLASS NAME :       BBSUSER
    //
    // DESCRIPTION:       论坛用户类,构造一个论坛用户对象
    //
    // DATE:              2000/02/03
    //
    /// ////////////////////////////////////////////////////////////////
    PUBLIC CLASS BBSUSER
    {
        //新建枚举类型,创建用户方式,创建还是修改
        PUBLIC ENUM CREATETYPE
        {
            CREATE = 0 ,
            MODIFY
        }

        //私有成员变量
        PRIVATE INT M_INTID ;                //用户ID
        PRIVATE STRING M_STRUSERNAME ;            //用户名
        PRIVATE STRING M_STRPASSWORD ;            //密码
        PRIVATE STRING M_STREMAIL ;            //用户EMAIL
        PRIVATE STRING M_STRHOMEPAGE ;            //个人主页
        PRIVATE STRING M_STRSIGNATURE ;            //签名

        //属性,全部只读
        PUBLIC INT ID
        {
            GET
            {
                RETURN M_INTID ;
            }
        }

        PUBLIC STRING USERNAME
        {
            GET
            {
                RETURN M_STRUSERNAME ;
            }
        }

        PUBLIC STRING PASSWORD
        {
            GET
            {
                RETURN M_STRPASSWORD ;
            }
        }

        PUBLIC STRING EMAIL
        {
            GET
            {
                RETURN M_STREMAIL ;
            }
        }

        PUBLIC STRING HOMEPAGE
        {
            GET
            {
                RETURN M_STRHOMEPAGE ;
            }
        }

        PUBLIC STRING SIGNATURE
        {
            GET
            {
                RETURN M_STRSIGNATURE ;
            }
        }
        //构造函数
        PUBLIC BBSUSER()
        {
            //
            // TODO: ADD CONSTRUCTOR LOGIC HERE
            //
            M_STRUSERNAME = "" ;
            M_STRPASSWORD = "" ;
            M_STREMAIL = "" ;
            M_STRHOMEPAGE = "" ;
            M_STRSIGNATURE = "" ;
        }

        //根据用户名查询用户资料
        PUBLIC BOOL GETUSER(STRING A_STRUSERNAME)
        {
            //如果用户名中包含单引号则抛出一个异常
            IF (A_STRUSERNAME.INDEXOF("'") != -1)
            {
                THROW(NEW EXCEPTION("用户名包含非法字符")) ;
            }

            BOOL BEXISTS = FALSE ;

            MYCONNECTION MYCONN = NEW MYCONNECTION() ;
            TRY
            {
                MYCONN.OPEN() ;
                SQLCOMMAND MYCOMMAND = NEW SQLCOMMAND() ;
                MYCOMMAND.ACTIVECONNECTION = MYCONN ;
                MYCOMMAND.COMMANDTEXT = "SELECT * FROM BBSUSER WHERE

USERNAME='" + A_STRUSERNAME + "'";

                SQLDATAREADER MYREADER ;
                MYCOMMAND.EXECUTE(OUT MYREADER) ;
                
                IF (MYREADER.READ())
                {
                    M_INTID = (INT)MYREADER["ID"] ;
                    M_STRUSERNAME = MYREADER["USERNAME"].TOSTRING() ;
                    M_STRPASSWORD = MYREADER["PASSWORD"].TOSTRING() ;
                    M_STREMAIL = MYREADER["EMAIL"].TOSTRING() ;
                    M_STRHOMEPAGE = MYREADER["HOMEPAGE"].TOSTRING() ;
                    M_STRSIGNATURE = MYREADER["SIGNATURE"].TOSTRING() ;
                    BEXISTS = TRUE ;
                }
                ELSE
                {
                    BEXISTS = FALSE ;
                }

                MYREADER.CLOSE() ;
                MYCONN.CLOSE() ;
                
            }
            CATCH(SQLEXCEPTION E)        //如果出现异常
            {

                THROW(NEW EXCEPTION("数据库异常:" + E.MESSAGE)) ;
                
            }                    

            //返回结果
            RETURN BEXISTS ;            
        }

        //重载,根据用户ID查找用户
        PUBLIC BOOL GETUSER(INT A_INTUSERID)
        {

            BOOL BEXISTS = FALSE ;

            MYCONNECTION MYCONN = NEW MYCONNECTION() ;
            TRY
            {
                MYCONN.OPEN() ;
                SQLCOMMAND MYCOMMAND = NEW SQLCOMMAND() ;
                MYCOMMAND.ACTIVECONNECTION = MYCONN ;
                MYCOMMAND.COMMANDTEXT = "SELECT * FROM BBSUSER WHERE ID=" +

A_INTUSERID.TOSTRING() ;

                SQLDATAREADER MYREADER ;
                MYCOMMAND.EXECUTE(OUT MYREADER) ;
                
                IF (MYREADER.READ())
                {
                    M_INTID = (INT)MYREADER["ID"] ;
                    M_STRUSERNAME = MYREADER["USERNAME"].TOSTRING() ;
                    M_STRPASSWORD = MYREADER["PASSWORD"].TOSTRING() ;
                    M_STREMAIL = MYREADER["EMAIL"].TOSTRING() ;
                    M_STRHOMEPAGE = MYREADER["HOMEPAGE"].TOSTRING() ;
                    M_STRSIGNATURE = MYREADER["SIGNATURE"].TOSTRING() ;
                    BEXISTS = TRUE ;
                }
                ELSE
                {
                    BEXISTS = FALSE ;
                }

                MYREADER.CLOSE() ;
                MYCONN.CLOSE() ;
                
            }
            CATCH(SQLEXCEPTION E)        //如果出现异常
            {

                THROW(NEW EXCEPTION("数据库异常:" + E.MESSAGE)) ;
                
            }                    

            //返回结果
            RETURN BEXISTS ;            
        }

        //新建用户
        PUBLIC VOID CREATEUSER(BBSUSER.CREATETYPE A_ENUMCREATETYPE ,STRING

A_STRUSERNAME ,
                                STRING A_STRPASSWORD ,

STRING A_STREMAIL ,
                                STRING A_STRHOMEPAGE ,

STRING A_STRSIGNATURE)
        {
            //监测参数有效性
            IF (A_STRUSERNAME.INDEXOF("'") != -1 || A_STRPASSWORD.INDEXOF("'")

!= -1
                || A_STREMAIL.INDEXOF("'") != -1 ||

A_STRHOMEPAGE.INDEXOF("'") != -1
                || A_STRSIGNATURE.INDEXOF("'") != -1)
            {
                THROW(NEW EXCEPTION("包含非法字符")) ;
            }

            TRY
            {
                MYOWNCLASS.MYCONNECTION MYCONN = NEW MYCONNECTION() ;
                SQLCOMMAND MYCMD = NEW SQLCOMMAND() ;

                //判断是新建用户还是修改用户资料
                IF (A_ENUMCREATETYPE == BBSUSER.CREATETYPE.CREATE)
                {
                    MYCMD.COMMANDTEXT = "INSERT INTO BBSUSER(USERNAME ,

PASSWORD , EMAIL , HOMEPAGE , SIGNATURE)"
                            + "VALUES('" + A_STRUSERNAME + "','"

+ A_STRPASSWORD + "','"
                            + A_STREMAIL + "','" + A_STRHOMEPAGE

+ "','" + A_STRSIGNATURE + "')" ;
                }
                ELSE
                {
                    MYCMD.COMMANDTEXT = "UPDATE BBSUSER SET EMAIL='" +

A_STREMAIL
                        + "' , HOMEPAGE='" + A_STRHOMEPAGE + "' ,

SIGNATURE='"
                        + A_STRSIGNATURE + "' WHERE USERNAME='" +

A_STRUSERNAME + "'";
                }
                MYCONN.OPEN() ;
                MYCMD.ACTIVECONNECTION = MYCONN ;
                MYCMD.EXECUTENONQUERY() ;
                MYCONN.CLOSE() ;

            }
            CATCH(SQLEXCEPTION EXP)
            {
                THROW(NEW EXCEPTION("数据库出错:" + EXP.MESSAGE)) ;
            }

        }

        //取回密码
        PUBLIC VOID GETPASSWORD(STRING A_STRUSERNAME , STRING A_STREMAIL)
        {

            IF (GETUSER(A_STRUSERNAME) && M_STREMAIL == A_STREMAIL)
            {
                //发送EMAIL
                SYSTEM.WEB.UTIL.MAILMESSAGE MYMAIL = NEW MAILMESSAGE() ;
                MYMAIL.FROM = "LYP@SERVER1.DOMAIN" ;
                MYMAIL.SUBJECT = "取回您的密码" ;
                MYMAIL.BODY = "请牢记您的密码:" + M_STRPASSWORD ;
                MYMAIL.TO = A_STREMAIL ;
                SMTPMAIL.SEND(MYMAIL) ;
            }
            ELSE
            {
                THROW (NEW EXCEPTION("该用户不存在")) ;
            }
        }
        
    }
}

    通过前面的学习,你可能已经能够看懂这个类定义的大部分内容,那些是成员变量,那些是属性,那些是方法都可以理解了,在这里需要解释的只有以下两部分内容,首先看这段代码:
        
PUBLIC ENUM CREATETYPE
{
    CREATE = 0 ,
    MODIFY
}
    这段代码的作用是创建BBSUSER类的一个枚举变量,写过C程序的朋友很容易理解,建立这个枚举变量的作用是简化记忆,用容易记忆的名称代替值,比如上边这个定义,当在方法CREATEUSER里作为第一个参数时,BBSUSER.CREATETYPE.CREATE实际的值是0,代表这个方法的目的是创建用户,而如果是BBSUSER.CREATETYPE.MODIFY,则代表目的是修改用户资料。显而易见,用IF (A_ENUMCREATETYPE == BBSUSER.CREATETYPE.CREATE)这样的语句比用IF (A_INTCREATETYPE == 1)更容易记忆,最大限度减少出错的可能。

    另外一个要解释的内容是:你可能已经注意到在类的定义中有两个 GETUSER方法的定义,其作用域和返回值都相同,只是参数类型不同。没错,这种做法叫重载(OVERRIDE),是并且只能是面向对象程序语言实现多态性的基本方法,那么这样做有什么好处呢?就是根据参数不同由类自己决定应该调用那个正确的方法,这样讲可能有些抽象,那么举个例子来说吧,这个GETUSER方法的作用是取得用户资料,那么它可以通过用户名来取得资料,也可以通过用户ID来取得,如果不用函数的重载,那么我们需要建两个函数,可能一个叫GETUSERFROMNAME(STRING A_STRNAME) , 而另一个是GETUSERFORMID(INT A_INTID),在调用时
需要判断一下决定调用那个方法,象这样:
IF ( BBSUSER.ID != "")
{
  GETUSERFROMID(BBSUSER.ID) ;
}
ELSE IF(BBSUSER.NAME != "")
{
  GETUSERFROMNAME(BBSUSER.NAME) ;
}

    以上两种方法孰优孰劣恐怕已经不用我说了吧。
    好了,既然我们已经创建好BBSUSER对象,下面就可以利用它来进行对用户的操作了。

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