Web开发模式【Mode I 和Mode II的介绍、应用案例】(五)

简介: 笔记

⑤开发web层

5.1我们来先做注册的界面吧!


  • 提供注册界面的Servlet

publicclassRegisterUIServletextendsjavax.servlet.http.HttpServlet{

       protectedvoiddoPost(javax.servlet.http.HttpServletRequestrequest,javax.servlet.http.HttpServletResponseresponse)throwsjavax.servlet.ServletException,IOException{

   

           //直接跳转到显示注册界面的JSP

           request.getRequestDispatcher("/WEB-INF/register.jsp").forward(request,response);

   

       }

   

       protectedvoiddoGet(javax.servlet.http.HttpServletRequestrequest,javax.servlet.http.HttpServletResponseresponse)throwsjavax.servlet.ServletException,IOException{

   

           this.doPost(request,response);

       }

   }


  • 开发注册界面的JSP

<h1>欢迎来到注册界面!</h1>


<%--提交给处理注册的处理Servlet--%>


<formmethod="post"action="${pageContext.request.contextPath}/RegisterServlet">


   <table>

       <%--对于id来讲是服务器分配的不需要用户自己输入--%>

       <tr>

           <td>用户名</td>

           <td>

               <inputtype="text "name="username">

           </td>

       </tr>

       <tr>

           <td>密码</td>

           <td>

               <inputtype="text"name="password">

           </td>

       </tr>

       <tr>

           <td>确认密码</td>

           <td>

               <inputtype="text"name="password">

           </td>

       </tr>

       <tr>

           <td>邮箱</td>

           <td>

               <inputtype="text"name="email">

           </td>

       </tr>

       <tr>

           <td>生日</td>

           <td>

               <inputtype="text "name="birethday">

           </td>

       </tr>

       <tr>

           <td>

               <inputtype="submit"value="提交">

           </td>

           <td>

               <inputtype="reset"value="重置!">

           </td>

       </tr>

   </table>

</form>


  • JSP页面是这样子的

65.jpg

  • 接下来,我们要开发处理用户注册提交的Servlet

//首先要接受Parameter的参数,封装到User里面去

       Stringusername=request.getParameter("username");

       Stringpassword=request.getParameter("password");


       //......如果参数过多,我们就要写好多好多类似的代码了...


  • 此时,我们应该想起反射机制中的BeanUtils开发包..为了更好地重用,我就将它写成一个工具类

/*

   * 将Parameter参数的数据封装到Bean中,为了外边不用强转,这里就使用泛型了!

   *

   * @request   由于要获取的是Parameter参数的信息,所以需要有request对象

   * @tClass    本身是不知道封装什么对象的,所以用class

   *

   * */


   publicstatic<T>Trequest2Bean(HttpServletRequesthttpServletRequest,Class<T>tClass){


       try{


           //创建tClass的对象

           Tbean=tClass.newInstance();


           //获取得到Parameter中全部的参数的名字

           Enumerationenumeration=httpServletRequest.getParameterNames();


           //遍历上边获取得到的集合

           while(enumeration.hasMoreElements()){


               //获取得到每一个带过来参数的名字

               Stringname=(String)enumeration.nextElement();


               //获取得到值

               Stringvalue=httpServletRequest.getParameter(name);


               //把数据封装到Bean对象中

               BeanUtils.setProperty(bean,name,value);

           }

           returnbean;

       }catch(Exceptione){

           e.printStackTrace();

           thrownewRuntimeException("封装数据到Bean对象中出错了!");

       }

   }


  • 经过我们测试,日期不能直接封装到Bean对象中,会直接报出异常

66.jpg

目录
相关文章
|
2月前
|
存储 监控 安全
如何在Python Web开发中确保应用的安全性?
如何在Python Web开发中确保应用的安全性?
|
2月前
|
前端开发 JavaScript
探索现代Web应用的微前端架构
【10月更文挑战第40天】在数字时代的浪潮中,Web应用的发展日益复杂多变。微前端架构作为一种新兴的设计理念,正逐步改变着传统的单一前端开发模式。本文将深入探讨微前端的核心概念、实现原理及其在实际项目中的应用,同时通过一个简单的代码示例,揭示如何将一个庞大的前端工程拆分成小而美的模块,进而提升项目的可维护性、可扩展性和开发效率。
|
18天前
|
弹性计算 Java 关系型数据库
Web应用上云经典架构实践教学
Web应用上云经典架构实践教学
Web应用上云经典架构实践教学
|
27天前
|
Kubernetes 安全 Devops
有效抵御网络应用及API威胁,聊聊F5 BIG-IP Next Web应用防火墙
有效抵御网络应用及API威胁,聊聊F5 BIG-IP Next Web应用防火墙
59 10
有效抵御网络应用及API威胁,聊聊F5 BIG-IP Next Web应用防火墙
|
18天前
|
弹性计算 Java 数据库
Web应用上云经典架构实战
本课程详细介绍了Web应用上云的经典架构实战,涵盖前期准备、配置ALB、创建服务器组和监听、验证ECS公网能力、环境配置(JDK、Maven、Node、Git)、下载并运行若依框架、操作第二台ECS以及验证高可用性。通过具体步骤和命令,帮助学员快速掌握云上部署的全流程。
|
2月前
|
前端开发 JavaScript UED
在数字化时代,Web 应用性能优化尤为重要。本文探讨了CSS与HTML在提升Web性能中的关键作用及未来趋势
在数字化时代,Web 应用性能优化尤为重要。本文探讨了CSS与HTML在提升Web性能中的关键作用及未来趋势,包括样式表优化、DOM操作减少、图像优化等技术,并分析了电商网站的具体案例,强调了技术演进对Web性能的深远影响。
43 5
|
2月前
|
机器学习/深度学习 人工智能 JavaScript
JavaScript和TypeScript的未来发展趋势及其在Web开发中的应用前景
本文探讨了JavaScript和TypeScript的未来发展趋势及其在Web开发中的应用前景。JavaScript将注重性能优化、跨平台开发、AI融合及WebAssembly整合;TypeScript则强调与框架整合、强类型检查、前端工程化及WebAssembly的深度结合。两者结合发展,特别是在Vue 3.0中完全采用TypeScript编写,预示着未来的Web开发将更加高效、可靠。
53 4
|
18天前
|
弹性计算 负载均衡 安全
云端问道-Web应用上云经典架构方案教学
本文介绍了企业业务上云的经典架构设计,涵盖用户业务现状及挑战、阿里云业务托管架构设计、方案选型配置及业务初期低门槛使用等内容。通过详细分析现有架构的问题,提出了高可用、安全、可扩展的解决方案,并提供了按量付费的低成本选项,帮助企业在业务初期顺利上云。
|
2月前
|
监控 安全 测试技术
如何在实际项目中应用Python Web开发的安全测试知识?
如何在实际项目中应用Python Web开发的安全测试知识?
36 4
|
2月前
|
机器学习/深度学习 数据采集 Docker
Docker容器化实战:构建并部署一个简单的Web应用
Docker容器化实战:构建并部署一个简单的Web应用