请求中文乱码解决:
- * 1.使用String进行数据重新编码
- * uname=new String(uname.getBytes("iso8859-1"),"utf-8");
- * 2、使用公共配置
- * get方式:
- * 步骤一:req.setCharacterEncoding("utf-8");
- * 步骤二:
- * 在Tomcat的目录下的conf目录中修改server.xml文件:在Connector标签中增加属性useBodyEncodingRorURI="true"
- * post方式:
- * req.setCharacterEncoding("utf-8");
流程总结:
Servlet流程总结:
- * 浏览器发起请求到服务器(请求)
- * 服务器接受浏览器的请求,进行解析,创建request对象存储请求数据
- * 服务器调用对应的servlet进行请求处理,并将request对象作为实参传递给servlet的方法
- * servlet的方法执行进行请求处理
- * //设置请求编码格式
- * //设置响应编码格式
- * //获取请求信息
- * //处理请求信息
- * //创建业务层对象
- * //调用业务层对象的方法
- * //响应处理结果
数据流转流程:
浏览器--------->服务器--------->数据库
浏览器<---------服务器<---------数据库
请求转发
问题:
服务器在接受到浏览器的请求后,仅仅使用一个Servlet进行请求处理,会造成不同的Servlet逻辑代码冗余,Servlet的职责不明确。
解决:
请求转发
- * 请求转发学习
- * 作用:实现多个servlet联动操作处理请求,这样避免代码冗余,让servlet的职责更加明确。
- * 使用:
- * req.getRequestDispatcher("要转发的地址").forward(req, resp);
- * 地址:相对路径,直接书写servlet的别名即可。
- * 特点:
- * 一次请求,浏览器地址栏信息不改变。
- * 注意:
- * 请求转发后直接return结束即可。
JSP的三种注释
- 前端语言注释:
- 会被转译,也会被发送,但是不会被浏览器执行
- Java语言注释:
- 会被转译,但是不会被servlet执行
- JSP注释:
- 不会被转译。
JSP的page指令学习
<%@ page language="java" import="java.util.*,java.lang.*" pageEncoding="utf-8"%>
<%@ page session="false" %>
<%@ page errorPage="error.jsp" %>
- <%@page 属性名="属性值" 属性名="属性值"......%>
- language:声明JSP要被转译的语言。
- import:声明转译的Java文件要导入的包,不同的包使用逗号隔开。
- pageEncoding:设置jsp文件的数据编码格式。
- contentType="text/html;charset=utf-8" 设置jsp数据响应给浏览器是,浏览器的解析和编码格式。
- session:设置转译的servlet中是否开启session支持,默认开启,true表示开启,false表示关闭。
- errorPage:设置jsp运行错误跳转的页面
- extends:设置jsp转译的Java文件要继承的父类(包名+类名)
作用:配置jsp文件的转译相关的参数。
JSP的局部代码块:
- 特点:
- 局部代码块中声明的Java代码会被原样转译到jsp对应的servlet文件的_JspService方法中
- 代码块中声明的变量都是局部变量
- 使用:<% java代码 %>
- 缺点:
- 使用局部代码块在jsp中进行逻辑判断,书写麻烦,阅读困难。
- 开发:
- servlet进行请求逻辑处理,使用jsp进行页面展现。
JSP的全局代码块:
- 特点:
- 声明的java代码作为全局代码转译到对应的servlet类中。
- 使用:
- <%! 全局代码 %>
- 注意:
- 全局代码块声明的代码,需要使用局部代码块调用。
JSP的脚本段语句:
- 特点:帮助我们快速的获取变量或者方法的返回值作为数据响应给浏览器。
- 使用:<%=变量名或者方法%>
- 注意:不要在变量名或者方法后使用分号
- 位置:除jsp语法要求以外的任意位置。
JSP的静态引入和动态引入:
- 静态引入:
- <%@include file="要引入的jsp文件的相对路径" %>
- 特点:
- 会将引入的jsp文件和当前jsp文件转译成一个java(servlet)文件使用,在网页中也就显示合并后的显示效果。
- 注意:
- 静态引入的jsp文件不会单独转译成java(servlet)文件
- 当前文件和静态引入的jsp文件中不能够使用java代码块声明同名变量。
- 动态引入:
- <%jsp:include page="要引入的jsp文件的相对路径" %></jsp:include>
- 特点:
- 会将引入的jsp文件单独转译,在当前文件转译好的java文件中调用引入的jsp文件的转译文件
- 在网页中显示合并后的显示效果
- 注意:
- 动态引入允许文件中声明同名变量。
- 优点:
- 降低jsp代码的冗余,便于维护升级。
JSP的转发标签forward:
- 使用:
- <jsp:forward page="要转发的jsp文件的相对路径"></jsp:forward>
- 特点:
- 一次请求
- 地址栏信息不改变。
- 注意:
- 在转发标签的两个标签中间除了写<jsp:param name="str" vlaue="aaa"/>字标签不会报错,其他任意字符都会报错。
- <jsp:param name="str" vlaue="aaa"/>
- name属性为附带的数据的键名
- value为附带的数据内容
- 注意:会将数据以?的形式拼接在转发路径的后面
JSP的九大内置对象:
- 内置对象:
- jsp文件在转译成其对应的servlet文件的时候自动生成的并声明的对象。我们在jsp页面中直接使用即可。
- 注意:
- 内置对象在jsp页面中使用,使用局部代码块或者脚本段语句来使用。不能够在全局代码块中使用。
- 内容:九个对象
- pageContext:页面上下文对象,封存了其他内置对象。封存了当前jsp的运行信息。
- 注意:每个jsp文件单独拥有一个pageContext对象。
- 作用域:当前页面。
- request:封存当前请求数据的对象。有Tomcat服务器创建。一次请求
- session:此对象用来存储用户的不同请求的共享数据的。一次会话
- application:也就是ServletContext对象,一个项目只有一个。存储用户共享数据的对象,以及完成其他操作。
- response:响应对象,用来响应请求处理结果给浏览器对象。设置响应头,重定向。
- out:响应对象,jsp内部使用。带有缓冲区的响应对象,效率高于response对象。
- page:代表当前jsp对象。相当于java中的this。
- exception:异常对象。存储当前运行的异常信息。
- 注意:使用此对象需要在page指定中使用属性isErrorPage="true"开启。
- config:也就是ServletConfig,主要用来获取web.xml中的配置数据,完成一些初始化数据的读取。
四个作用域对象:
- pageContext:当前页面。解决了当前页面内的数据共享问题。获取其他内置对象。
- request:一次请求。一次请求的servlet的数据共享。通过请求转发,将数据流转给下一个servlet。
- session:一次会话。一个用户的不同请求的数据共享。将数据从一次请求流转给其他请求。
- application:项目内。不同用户的数据共享问题。将数据从一个用户流转给其他用户。
- 作用:数据流转
JSP的路径:
- 在jsp中资源路径可以使用相对路径完成跳转,但是:
- 问题一:资源的位置不可随意更改
- 问题二:需要使用../进行文件夹的跳出。使用比较麻烦。
- 使用绝对路径:
- /虚拟项目名/项目资源路径
- 例如:
- <a href="/jsp/jspPro.jsp">jspPro</a>
- 注意:在jsp中资源的第一个/表示的是服务器根目录,相当于:localhost:8080
- 使用jsp自带的全局路径声明:
- <%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<base href="<%=basePath%>"> - 作用:给资源股前面添加项目路径: http://127.0.0.1:8080/虚拟项目名/