12. Web开发:介绍Web开发的基本概念,Servlet和JSP的使用,MVC设计模式的应用等。

Web开发的轻松入门之旅

想象一下,Web开发就像是搭建一个在线的小家,你既是设计师,又是建筑师,还是管家。我们一步步来探索这个过程,保证简单易懂,就像搭积木一样有趣!

Web开发基础认知

Web开发,简单说,就是创建网站或者网络应用的过程。想象你在网上看到的那些花哨页面,背后就是通过编程语言堆砌起来的。主要有两部分工作:前端(页面的样子和互动)和后端(处理数据和逻辑)。

Servlet:后台小能手

Servlet,就像是你家中的智能助手,专门处理后台的事情。比如,当你在网上购物点击“下单”按钮时,Servlet就在背后接收这个请求,检查库存,处理支付,然后告诉你“下单成功”。

实例时间:想象我们要做一个简单的留言本。当用户提交一条留言,Servlet就要接收这条留言,保存到数据库,然后告诉用户“留言成功”。

练习:

    1.    创建一个Servlet类,继承HttpServlet。
    2.    重写doPost方法,获取用户提交的信息,比如姓名和留言内容。
    3.    将这些信息存入数据库(可以先模拟存入一个列表)。
    4.    最后,输出一个确认信息,比如“您的留言已成功提交”。

JSP:动态装修师

JSP(Java Server Pages)则像是你家的装修师傅,它让网页不只好看,还能根据后端的数据变化而变化。比如,显示天气预报,今天晴天就显示太阳图标,雨天就显示雨伞。

实例继续:在我们的留言本项目中,用JSP展示留言列表。每当有新留言,Servlet处理完后,JSP页面自动刷新显示最新的留言。

练习:

    1.    创建一个JSP文件,用来显示留言列表。
    2.    在JSP里,使用表达式和脚本标签从Servlet获取留言数据。
    3.    设计好看的模板,让每条留言看起来既美观又易于阅读。

MVC设计模式:分工明确的团队

MVC(Model-View-Controller)就像一个高效的工作团队。Model负责数据管理(比如数据库操作),View负责展示(比如JSP页面),Controller负责协调(比如Servlet处理请求)。

实例融入MVC:

    •    Model:定义一个留言的类和数据库操作类。
    •    View:JSP页面展示留言列表和提交表单。
    •    Controller:Servlet接收请求,调用Model处理数据,最后选择合适的View展示结果。

练习:

    1.    分离现有的代码,明确哪些属于Model层(数据处理),哪些是View(页面展示),哪些是Controller(请求处理)。
    2.    确保每一层只关注自己的事情,比如Model不知道也不关心页面怎么显示。

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,以下是基于ServletMVC模式设计的简单加减乘除运算的计算器示例: 首先,我们需要创建一个Model类Calculator,用于进行四则运算: ```java public class Calculator { public int add(int num1, int num2) { return num1 + num2; } public int subtract(int num1, int num2) { return num1 - num2; } public int multiply(int num1, int num2) { return num1 * num2; } public int divide(int num1, int num2) { return num1 / num2; } } ``` 然后,我们需要创建一个View类CalculatorView,用于渲染页面: ```java public class CalculatorView { public void render(HttpServletRequest request, HttpServletResponse response, String result) throws ServletException, IOException { request.setAttribute("result", result); request.getRequestDispatcher("calculator.jsp").forward(request, response); } } ``` 在View类中,我们使用JSP页面calculator.jsp,用于渲染页面并显示计算结果: ```html <html> <head> <title>Calculator</title> </head> <body> <h1>Calculator</h1> <form action="calculator" method="post"> <input type="text" name="num1" placeholder="Enter first number" required> <select name="operator"> <option value="add">+</option> <option value="subtract">-</option> <option value="multiply">*</option> <option value="divide">/</option> </select> <input type="text" name="num2" placeholder="Enter second number" required> <input type="submit" value="Calculate"> </form> <h2>Result: <%= request.getAttribute("result") %></h2> </body> </html> ``` 接着,我们需要创建一个Controller类CalculatorController,用于处理请求并调用Model和View: ```java public class CalculatorController extends HttpServlet { private Calculator calculator; private CalculatorView calculatorView; public void init() { calculator = new Calculator(); calculatorView = new CalculatorView(); } public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { calculatorView.render(request, response, ""); } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { int num1 = Integer.parseInt(request.getParameter("num1")); int num2 = Integer.parseInt(request.getParameter("num2")); String operator = request.getParameter("operator"); int result = 0; switch (operator) { case "add": result = calculator.add(num1, num2); break; case "subtract": result = calculator.subtract(num1, num2); break; case "multiply": result = calculator.multiply(num1, num2); break; case "divide": result = calculator.divide(num1, num2); break; } calculatorView.render(request, response, String.valueOf(result)); } } ``` 在Controller类中,我们首先实例化了Calculator和CalculatorView类,然后在doGet方法中渲染页面,而在doPost方法中获取用户输入的数据,调用Model类进行计算,然后将结果传递给View类进行渲染。 最后,我们需要在web.xml中配置Servlet: ```xml <servlet> <servlet-name>CalculatorController</servlet-name> <servlet-class>com.example.CalculatorController</servlet-class> </servlet> <servlet-mapping> <servlet-name>CalculatorController</servlet-name> <url-pattern>/calculator</url-pattern> </servlet-mapping> ``` 现在,我们就可以通过访问http://localhost:8080/calculator来使用我们的简单加减乘除运算的计算器了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

周盛欢

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值