应用服务器:
1、
Tomcat
2、JBoss
3、Webphere
4、WebLogic
5、Resin
tomcat的安装:
1、下载Tomcat(www.apache.org)
2、在环境变量中设置
CATALINA_HOME=Tomcat的路径
JAVA_HOME=Java 路径
3、将Tomcat的bin路径添加到环境变量中
4、启动Tomcat,在命令提示符中输入catalina.bat start
5、启动之后在浏览器中输入http://localhost:8080如果显示下图就表示安装成功!
5、启动之后在浏览器中输入http://localhost:8080如果显示下图就表示安装成功!
tomcat的目录结构:
·只要将相应的项目复制到webapps中就可以直接访问该项目
·conf文件夹是一些配置文件所放置的文件夹
·conf文件夹中的文件
在server.xml中可以完成对站点访问的配置
web.xml中可以完成一些web的基本访问的配置
server.xml中的重要配置:
Connector用来配置相应的访问属性,port表示访问端口为8888,URIEncoding表示访问的字符编码
Host中存储了所有访问的主机,对于任意一台计算机而言均有一个默认的访问地址localhost,这个文件是在drivers/etc/host这个文件中配置的
Context表示访问的虚拟路径,path表示要访问的网页上下文路径,docBase表示要访问的文件夹所在路径,reloadable表示是否在修改之后进行重新启动,如果使用eclipse开发建议设置为false,因为在eclipse中会通过debug进行启动
web.xml中的重要配置:
listings表示是否在显示页面时打开文件列表,建议在调试时打开,方便查询一些特殊的网页文件
表示默认访问的文件
web项目的目录结构:
web项目的发布:
两种发布方式:
1、将相应的项目目录拷贝到Tomcat目录的webapps目录中,之后直接在浏览器中输入访问的地址:localhost:8080/项目名称
2、打开Tomcat->conf->server.xml,在<Host name="localhost">这个主机中增加一个Context即可
<Context path="/hello" docBase="项目路径" reloadable="false"/>即可以完成项目发布,之后通过localhost:8080/hello就可以访问该目录
servlet:
servlet:可以将Java程序运行到web环境中
创建servlet:
1、写一个类让其继承HttpServlet。
2、覆盖doGet方法,在doGet方法中加入一些测试程序
3、配置web.xml让该servlet可以访问
servlet的配置:
a.创建<servlet>
<servlet-name>xxxx</servlet-name> ---->为该servlet设定一个名称
<servlet-class>xxx.xxx.xxx</servlet-class>---->servlet的类,要加入包路径
b.创建<servlet-mapping>
<servlet-name>xxxx</servlet-name>------>说明servlet的name
<url-pattern>/xxx<url-pattern>------->声明在浏览器中需要访问的地址
具体的使用说明看下图
调用过程如下图
servlet的生命周期:
对应Servlet而言,用户将请求提交给Servlet,首先会由web容器(Tomcat)截获,并且在web.xml中解析请求获取相应的Servlet,之后根据情况判断是否执行init方法(见备注),之g调用的service方法,doGet和doPost会自动调用service方法,通过request对象处理完请求之后可以通过resp对象向浏览器输出相应信息。当服务器关闭时调用destory方法销毁这个servlet
备注:init方法解释
1、init方法有两个一个带参数,一个不带参数,如果两个都覆盖了(这种情况基本不会出现)会调用带参数
2、带参数的这个init方法可以获取web.xml中<init-param>中的数据,通过config.getInitParamxx("username")可以获取一下xml的Teacher这个值,init什么时候执行需要根据web.xml中servlet配置中的load-on-startup>来确定
<
init-param
>
<
param-name
>
username
</
param-name
>
<
param-value
>
Teacher
</
param-value
>
</
init-param
>
<
load-on-startup
>
1
</
load-on-startup
>
<!-- 0或者不写load-on-startup都是在第一次调用 servlet时才执行init方法,如果>0会在启动时调用 init方法 -->
HTTP协议的基础:
MIME类型:
MIME是通过标准化电子邮件报文的头部的附加域(fields)而实现的;这些头部的附加域,描述新的报文类型的内容和组织形式.
内容类型(Content-Type),这个头部领域用于指定消息的类型。一般以下面的形式出现。
type有下面的形式。
Text:用于标准化地表示的文本信息,文本消息可以是多种字符集和或者多种格式的;
Multipart:用于连接消息体的多个部分构成一个消息,这些部分可以是不同类型的数据;
Application:用于传输应用程序数据或者二进制数据;
Message:用于包装一个E-mail消息;
Image:用于传输静态图片数据;
Audio:用于传输音频或者音声数据;
Video:用于传输动态影像数据,可以是与音频编辑在一起的视频数据格式。
subtype用于指定type的详细形式。content-type/subtype配对的集合和与此相关的参数,将随着时间而增长。为了确保这些值在一个有序而且公开的状态下开发,MIME使用Internet Assigned Numbers Authority (IANA)作为中心的注册机制来管理这些值。常用的subtype值如下所示:
text/plain(纯文本)
text/html(HTML文档)
application/xhtml+xml(XHTML文档)
image/gif(GIF图像)
image/jpeg(JPEG图像)【PHP中为:image/pjpeg】
image/png(PNG图像)【PHP中为:image/x-png】
video/mpeg(MPEG动画)
application/octet-stream(任意的二进制数据)
application/pdf(PDF文档)
application/msword(Microsoft Word文件)
message/rfc822(RFC 822形式)
multipart/alternative(HTML邮件的HTML形式和纯文本形式,相同内容使用不同形式表示)
application/x-www-form-urlencoded(使用HTTP的POST方法提交的表单)
multipart/form-data(同上,但主要用于表单提交时伴随文件上传的场合)
此外,尚未被接受为正式数据类型的subtype,可以使用x-开始的独立名称(例如application/x-gzip)。vnd-开始的固有名称也可以使用(例:application/vnd.ms-excel)。
状态相应代码:
get和post请求:
Get请求就是用户在浏览器中输入地址都是使用GET请求
1、对于Servlet而言,专门通过doGet方法来处理Get请求,doGet方法中有一个很重要参数HttpServletRequest对象,通过这个对象可以有效的获取Get请求中的参数
2、GET请求通过key=value的形式来传递参数,通过?来确定后面的数据都是参数,同&来分割不同的参数,可以使用req的
getParameterNames
获取传递进来的所有参数名
3、通过req.getParameter(参数名)可以获取这个参数值
Enumeration<String> params = req.getParameterNames ();//获取传入的所有参数
//遍历出所有参数的名称
while
(params.hasMoreElements()) {
System.
out
.println(params.nextElement());
}
|
//获取用户名和密码进行判断
String username = req.getParameter(
"username"
);
String password = req.getParameter(
"password"
);
|
post请求需要通过form表单才能完成数据的传递,POST请求的请求参数并不是通d浏览器的路径进行传递的,而是放置在http的header信息中进行传递的,安全性要高一些。
在Servlet中需要通过doPost方法进行处理,处理方式和GET的方式完全一致。
< form action = "check" method= "POST">
Username:
<
input
type
=
"text"
name
=
"username"
/><
br
/>
Password:
<
input
type
=
"password"
name
=
"pwd"
/><
br
/>
<
input
type
=
"submit"
/>
</
form
>
|
以上代码将会发送一个post请求给/check这个servlet来处理,其中input表单中name的值就表示req.getParameter(xxx)中的参数xxx
|
字符编码问题:
可能存在两种和字符相关情况
1、在浏览器中通过操作员直接输入,此时默认的字符编码是当前操作系统的字符编码,由于经常使用的是windowsxp,所有默认字符编码是GBK
2、通过url的链接过去时,默认传递的字符编码又是页面的字符编码
3、可以在调用request之前通过request.setCharacterEncoding(xxx)来设置统一的字符编码,并且要修改Tomcat的Connector配置:
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443"
useBodyEncodingForURI="true"
URIEncoding="UTF-8"
/>
|
post的字符编码:
在处理request之前通过request.
setCharacterEncoding(xxx)来设置相应的字符编码
jsp讲解:
jsp的基础语法:
1、是<%%>来包围的代码都是java代码
2、对于jsp而言,默认定义了一下一些重要的内置对象
·out---->PrintWriter(resp.getWriter())
由于out对象使用较多,所以有如下一种替换方式,直接在html中通过<%=xx%>完成out的使用
|
·request--->HttpServletRequest
·session---->HttpSession
·application---->ServletContext
·response ----->HttpServletResponse
jsp的运行原理:
对于所有的jsp而言,它都会被转换为servlet来执行,只是这个转换的过程由Tomcat服务器完成,我们可以通过work目录来查询相应的代码
所以JSP的页面在第一次运行时会相对比较慢,因为要完成JSP-Servlet的转换。
重定向:
有两种方式
1、response.sendRedirect(
"02.jsp"
);
这种方式属于客户端跳转,在浏览器的地址栏显示的是跳转后的地址
传递参数可以直接在地址后使用?xxx=xxx来传递,但是中文传递不了
特别注意:如果要使用客户端跳转一定要在sendRedirect之后使用return;
2、
<
jsp:forward
page
=
"02.jsp"
></
jsp:forward
>
属于服务器端跳转,该种跳转在客户端的浏览器上依然会显示原有的地址
传递参数的方式在标签中加入jsp:param标签,注意也不支持中文传递
<
jsp:forward
page
=
"02.jsp"
>
<
jsp:param
value
=
"张三"
name
=
"username"
/>
</
jsp:forward
>
jsp的常用内置对象:
scope的范围对象:
1、pageContext对象:
作用域范围
1、在当前页面attribute的值存在
2、客户端跳转attribute作用域的值丢失
3、服务器端跳转值会丢失
request对象:
作用域范围
1、当前页面可以存储数据
2、客户端跳转无法存储数据
3、服务器端跳转可以存储数据
总体来说使用request传递数据仅仅支持在服务器端跳转
session对象:
1、当前页面有数据
2、客服端跳转有数据
3、服务器端跳转有数据
只有在重新启动浏览器之后数据才会丢失,可以使用session很方便的实现购物车和用户登录检测
对于session的数据而言可以使用session.invalidate()来结束session
session.removeAttribute(),来移除session中的数据
application对象:
只有在重启服务器数据才会丢失,计数器
路径问题:
相对路径:
相对于当前文件夹来设置路径,其中..表示上一级目录
<
a
href
=
"../../02/2.jsp"
>
Link To 02
</
a
>
以上代码表示访问当前文件夹的上一级文件夹的上一级文件夹中的02文件夹中的2.jsp
建议不要使用相对路径
绝对路径:
根据整个网站的根目录来确定绝对路径,使用/来指明根目录
特别注意,在java中,/表示的不带有上下文路径,所以需要使用request.getContextPath()来获取上下文路径。
<
a
href
=
"
<%=
request.getContextPath()
%>
/01/1.jsp"
>
Link To 01
</
a
>
在开发过程一般都是使用绝对路径。
包含:
有两种包含方式:
·
<%@
include
file
=
"/inc/header.jsp"
%>
以上包含属于静态包含,直接把整个文件包含进来,在包含前不做任何处理
|
以下的是动态包含:
·
<
jsp:include
page
=
"/inc/header.jsp"
></
jsp:include
>
在包含之前会先对这个动态文件进行编译,之后把编译的结果以静态文件的形式包含进来。
|
最佳实践:建议使用动态包含
注意:在包含文件时可以直接使用绝对路径,系统会自动加上上下文路径
过滤器介绍:
Filter(过滤器)和Servlet很类似,均需要进行相应的配置
1、Filter的创建
·定义一个类让其实现Filter接口
2、Filter的设置
·在doFilter()方法中加入相应的拦截代码,加入了相应的拦截代码之后需要使用chain.doFilter(req,resp)让请求继续走
3、Filter的配置
·在web.xml中进行配置
< filter>
<
filter-name
>
TestFilter
</
filter-name
>
<
filter-class
>
org.itat.filter.MyFilter
</
filter-class
>
</
filter
>
<
filter-mapping
>
<
filter-name
>
TestFilter
</
filter-name
>
<
url-pattern
>
/*
</
url-pattern
>
</
filter-mapping
>
|
url-pattern表要拦示截哪些请求:/
·/* :表示拦截所有请求
·/01/1.jsp : 表示仅仅只对01/1.jsp文件进行拦截
·/01/* : 表示拦截01/这个文件夹中的所有信息
特别注意:/01/*.jsp这种方式是不允许的,只允许以上三种方式
|
使用过滤器解决字符编码:
定义一个CharacterEncodingFilter,在doFilter中使用request.setCharacterEncoding(xxx);来解决
注意:当有多个Filter被定义的时候会每一个filter都执行,执行顺序按照web.xml中配置先后执行
为了让一些常量在配置文件中定义,可以使用<init-param>
< filter >
<
filter-name
>
CharacterFilter
</
filter-name
>
<
filter-class
>
org.itat.filter.CharacterEncodingFilter
</
filter-class
>
<
init-param
>
<
param-name
>
Char
</
param-name
>
<
param-value
>
UTF-8
</
param-value
>
</
init-param
>
</
filter
>
|
init-param就是用来定义相应的初始化参数,需要在Filter的init中通过config来获取
|
@Override
public
void
init(FilterConfig config)
throws
ServletException {
charEncoding
= config.getInitParameter(
"Char"
);
//获取初始化参数
if
(
charEncoding
==
null
||
""
.equals(
charEncoding
)) {
charEncoding
=
"UTF-8"
;
}
}
|
charEncoding需要在doFilter中使用,所以将charEncoding定义成成员变量。
|
request.setCharacterEncoding( charEncoding );
chain.doFilter(request,response);
|
使用过滤器根据正则表达式过滤访问地址:
1、在初始化参数中传递一个正则表达式
< init-param >
<
param-name
>
pattern
</
param-name
>
<
param-value
>
.*\. jsp|.*Servlet
</
param-value
>
</
init-param
>
|
.*\.jsp|.*Servlet表示匹配.jsp结尾和Servlet结尾的所有字符串
|
2、获取浏览器的访问地址
HttpServletRequest req = (HttpServletRequest)request;
String url = req.getRequestURI();//获取浏览器的访问地址
|
参数中是ServletRequest,ServletRequest中没有getRequestURI方法,getRequetURL方法是在HttpServletRequest中,所以需要进行强制类型转换(
HttpServletRequest req = (HttpServletRequest)request;
)。
|
3、判断是否匹配
if(url.matches( pattern)) {
System.
out
.println(url);
System.
out
.println(url.matches(
pattern
));
request.setCharacterEncoding(
charEncoding
);//修改字符编码
}
|
EL表达式:
获取请求参数中的值使用${param.username}