MVC:开发模式
1、jsp演变历史
- 早期只有servlet,只能使用response输出标签数据,非常麻烦
- 后来又jsp,简化了Servlet的开发,如果过度使用jsp,在jsp中即写大量的java代码,有写html表,造成难于维护,难于分工协作
- 再后来,java的web开发,借鉴mvc开发模式,使得程序的设计更加合理性
2、MVC
- M:Model,模型。JavaBean
- 完成具体的业务操作,如:查询数据库,封装对象
- V:View,视图。JSP
- 展示数据
- C:Controller,控制器。Servlet
- 获取用户的输入
- 调用模型
- 将数据交给视图进行展示
3、优缺点
- 优点:
- 耦合性低,方便维护,可以利于分工协作
- 重用性高
- 缺点:
- 使得项目架构变得复杂,对开发人员要求高
EL表达式
一、概念
Expression Language 表达式语言
二、作用
替换和简化jsp页面中java代码的编写
三、语法
${表达式}
四、注意
- jsp默认支持el表达式的。如果要忽略el表达式
- 设置jsp中page指令中:isELIgnored="true" 忽略当前jsp页面中所有的el表达式
${表达式}
:忽略当前这个el表达式
五、使用
1、运算
- 运算符:
- 算数运算符: + - * /(div) %(mod)
- 比较运算符: > < >= <= == !=
- 逻辑运算符: &&(and) ||(or) !(not)
- 空运算符: empty
- 功能:用于判断字符串、集合、数组对象是否为null或者长度是否为0
- ${empty list}:判断字符串、集合、数组对象是否为null或者长度为0
- ${not empty str}:表示判断字符串、集合、数组对象是否不为null 并且 长度>0
2、获取值
- el表达式只能从域对象中获取值
- 语法:
- ${域名称.键名}:从指定域中获取指定键的值
- 域名称:
pageScope
--> pageContextrequestScope
--> requestsessionScope
--> sessionapplicationScope
--> application(ServletContext)
- 举例:在request域中存储了name=张三
- 获取:${requestScope.name}
- 域名称:
- ${键名}:表示依次从最小的域中查找是否有该键对应的值,直到找到为止。
- 获取对象、List集合、Map集合的值
-
对象:${域名称.键名.属性名}
- 本质上会去调用对象的getter方法
-
List集合:${域名称.键名[索引]}
-
Map集合:
- ${域名称.键名.key名称}
- ${域名称.键名["key名称"]}
-
- ${域名称.键名}:从指定域中获取指定键的值
六、隐式对象
- el表达式中有11个隐式对象
- pageContext:
- 获取jsp其他八个内置对象
- ${pageContext.request.contextPath}:动态获取虚拟目录
- 获取jsp其他八个内置对象
JSTL
-
概念:JavaServer Pages Tag Library JSP标准标签库
- 是由Apache组织提供的开源的免费的jsp标签 <标签>
-
作用:用于简化和替换jsp页面上的java代码
-
使用步骤:
- 导入jstl相关jar包
- 引入标签库:taglib指令: <%@ taglib %>
- 使用标签
-
常用的JSTL标签
-
if
:相当于java代码的if语句- 属性:
- test 必须属性,接受boolean表达式
- 如果表达式为true,则显示if标签体内容,如果为false,则不显示标签体内容
- 一般情况下,test属性值会结合el表达式一起使用
- 注意:
c:if
标签没有else情况,想要else情况,则可以在定义一个c:if标签
- 属性:
-
choose
:相当于java代码的switch语句- 使用choose标签声明 相当于switch声明
- 使用when标签做判断 相当于case
- 使用otherwise标签做其他情况的声明 相当于default
-
foreach
:相当于java代码的for语句
-
-
练习:
- 需求:在request域中有一个存有User对象的List集合。需要使用jstl+el将list集合数据展示到jsp页面的表格table中
三层架构:软件设计架构
界面层(表示层)
:用户看的得界面。用户可以通过界面上的组件和服务器进行交互。业务逻辑层
:处理业务逻辑的。数据访问层
:操作数据存储文件。
案例:用户信息列表展示
-
需求:用户信息的增删改查操作
-
设计:
-
技术选型:Servlet+JSP+MySQL+JDBCTempleat+Duird+BeanUtilS+tomcat
-
数据库设计:
create database day17; -- 创建数据库 use day17; -- 使用数据库 create table user( -- 创建表 id int primary key auto_increment, name varchar(20) not null, gender varchar(5), age int, address varchar(32), qq varchar(20), email varchar(50) );
-
-
开发:
-
环境搭建
- 创建数据库环境
- 创建项目,导入需要的jar包
-
编码
-
-
测试
-
部署运维