web基础

应用服务器:
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如果显示下图就表示安装成功!
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}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值