JavaWeb就是在服务器端以Java语言为解释运行基础的web程序。

php代码要想在服务器端运行,需要在服务器软件(通常是Apache)上加php的解释器,Java也一样,但是这个解释器是Tomcat。但还是有点不一样,可能与两种语言的特性有关:php是脚本语言,解释执行;而Java需要编译执行。php解释器添加到Apache上就可以了,但是只是将请求转交给Tomcat来执行并返回结果。(具体区别以后总结)

在eclipse中设置Javaweb环境

java web开发的基础:servlet

servlet是java提供的用于远程访问的接口,有一个http专用的子接口httpservlet抽象类,开发者只需要继承/实现相应类/接口即可进行http访问即web开发。有三种途径

  1、实现javax.servlet.Servlet接口;        --》顶层接口,只是定义了几个生命周期方法和简单方法

  2、 继承javax.servlet.GenericServlet类;      --》servlet接口的简单实现

  3、 继承javax.servlet.http.HttpServlet类;     --》专用于http协议的GenericServlet类的实现,注意这个类是没有抽象方法的抽象类

而tomcat的作用就是

  ①建立低层的连接,

  ②将请求信息封装为java对象(如ServletConfig,(Http)ServletRequest等,这是接口,有tomcat实现并传入),重要,需要掌握这些对象的用法。

  参考:http://blog.csdn.net/tong_xinglong/article/details/12972819

    http://blog.sina.com.cn/s/blog_696024a90100o6hq.html

  ③调用相应的servlet,通过web.xml配置文件

     <servlet>
<servlet-name>AServlet</servlet-name>
<servlet-class>hello.AServlet</servlet-class>
<init-param>
<param-name>p1</param-name>
<param-value>v1</param-value>
</init-param>
<init-param>
<param-name>p2</param-name>
<param-value>v2</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>AServlet</servlet-name>
<url-pattern>/aservlet</url-pattern>
</servlet-mapping>

web.xml配置

 package hello;

 import java.io.IOException;
import java.util.Enumeration; import javax.servlet.Servlet;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse; /*Servlet是该体系的顶端接口
*
*/
public class AServlet implements Servlet { private ServletConfig sc; @Override
/*生命周期方法:!!!初始化方法,在servlet在被tomcat创建时调用,只有一次,在执行构造函数方法之后立即被调用
*注意:声明周期方法是被tomcat调用,所以传入的参数是由其自动传入,而且该对象也是有tomcat创建的,
* 但是依据的是用户自己的web.xml配置文件
*
* 初始化方法通常用来给servlet类进行赋值
*/
public void init(ServletConfig ServletConfig) throws ServletException {
System.out.println("init...");
//使用tomcat提供的SerletConfig对象获取对应配置信息
Enumeration<String> e=ServletConfig.getInitParameterNames();
while(e.hasMoreElements()){
String para=e.nextElement();
System.out.println(para+"..."+ServletConfig.getInitParameter(para));
} this.sc=ServletConfig;
this.init();
} public void init() {
/*!!!该方法留空,是留给子类(如果有)覆盖的,不要是覆盖生命周期方法,因为其需要对该类进行配置
* 这里要再次注意:Java中函数只要返回值/参数个数/参数类型 不同即使重写
* 该方法只要在生命周期的init方法中调用即可,由继承的特点即可工作
*
* 这也是GenericServlet类中使用的方式
*/
} @Override
public ServletConfig getServletConfig() {
System.out.println("getServletConfig...");
return this.sc;
} @Override
public String getServletInfo() {
System.out.println("getServletInfo...");
return null;
} /*生命周期方法:每次请求servlet都会调用,在init方法之后
*
*/
@Override
public void service(ServletRequest ServletRequest, ServletResponse ServletResponse)
throws ServletException, IOException {
System.out.println("service...");
} /*生命周期方法:销毁方法。注意并不是真正的删除对象,删除是垃圾回收器的任务,这里只是切断与对象的连接
*同样只执行一次
*/
@Override
public void destroy() {
System.out.println("destroy...");
} }

AServlet

package hello;

import java.io.IOException;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebInitParam;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; public class BServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
//注意这里的两个方法:doGet()和doPost()必须实现一个
//就是使用的传输方法:get/post,就实现对应的方法
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
System.out.println("doGet...");
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
System.out.println("doPost...");
}
}
、、

HttpServlet的一个简单实例

servlet细节:

1、每个servlet只会生成一个类实例,即单例模式,所以有线程安全问题。线程安全的解决方法有

  1、不在servlet中创建成员,使用局部变量

  2、可以创建无状态成员。所谓状态成员也就是描述一个事物的,即类的属性。

  3、创建有状态成员,但是状态必须是只读的。也就是说可以有属性,但是只有读取的方法而没有写的方法。

2、servlet对象的创建时间:默认是在用户首次调用时创建对象,所以第一次使用时较慢;但是可以在web.xml中对应的servlet配置中配置一条

  <load-on-startup>0</load-on-startup>,只要值>=0即可在tomcat开启时自动创建。如果有多个,则按照值升序依次创建

3、在web.xml配置<url-pattern>的值可以有多个与一个<servlet-name>对应,并且可以使用*通配符。

  注意:通配符只能放在开头(匹配路径)或结尾(匹配扩展名)。

  匹配的优先级:具体的路径(/a/b.jsp)>使用通配符的路径(/a/b.*)>根路径(/,匹配所有路径)

web.xml中的默认配置有以下作用

1、servlet和JSP的关系:

     <servlet>
<servlet-name>jsp</servlet-name>
<servlet-class>org.apache.jasper.servlet.JspServlet</servlet-class>
<init-param>
<param-name>fork</param-name>
<param-value>false</param-value>
</init-param>
<init-param>
<param-name>xpoweredBy</param-name>
<param-value>false</param-value>
</init-param>
<load-on-startup>3</load-on-startup>
</servlet> <servlet-mapping>
<servlet-name>jsp</servlet-name>
<url-pattern>*.jsp</url-pattern>
<url-pattern>*.jspx</url-pattern>
</servlet-mapping>

web.xml中的配置

由配置信息可知:所有以JSP结尾的文件都会转交到org.apache.jasper.servlet.JspServlet这个类中进行处理

2、访问一个不存在的路径时显示404页面

     <servlet>
<servlet-name>default</servlet-name>
<servlet-class>org.apache.catalina.servlets.DefaultServlet</servlet-class>
<init-param>
<param-name>debug</param-name>
<param-value>0</param-value>
</init-param>
<init-param>
<param-name>listings</param-name>
<param-value>false</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet> <servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>

web.xml中的配置

由配置信息可知:所有没有其他servlet接收的路径(即无效不存在的路径)都会被转到org.apache.catalina.servlets.DefaultServlet中去处理,就是显示404页面

3、配置session,以后使用

     <session-config>
<session-timeout>30</session-timeout>
</session-config>

web.xml中的配置

参考:http://blog.csdn.net/guihaijinfen/article/details/8363839

servlet是通过配置文件,使用反射技术产生对象实例的

 package hello;

 import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.Set; import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; /**
* Servlet implementation class CServlet
*/
@WebServlet("/CServlet")
public class CServlet extends HttpServlet {
private static final long serialVersionUID = 1L; /**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//获取Servlet公共配置参数示例
getInitPara();
//获取该项目下的资源
getPath();
//获取该项目的类资源
getClassPath1();
getClassPath2();
} private void getInitPara() {
/*Servlet除了可以使用自己局部的参数,还可以使用公共的配置参数,即<context-para>中的配置参数
* 必须通过ServletContext对象的方法来获取
*/
ServletContext app=this.getServletContext();
String context_value=app.getInitParameter("context-para");
System.out.println(context_value);
} private void getPath() {
//获取该项目中指定资源的真实路径,带盘符
String realPath=this.getServletContext().getRealPath("/index.jsp");
//D:\Java\tomcat\apache-tomcat-7.0.42\me-webapps\hello\index.jsp
System.out.println(realPath); //还可以进一步获取流对象
//InputStream is=this.getServletContext().getResourceAsStream("/index.jsp"); //还可以获取一个路径下的所有资源路径,注意只是浅获取,即只获取该目录下而不向下获取,用Set集合保存
Set<String> set=this.getServletContext().getResourcePaths("/WEB-INF");
System.out.println(set);
} private void getClassPath1() throws IOException {
//获取类路径下资源,通过ClassLoader对象,在获取该资源的输入流对象就可以读取资源(文件)的内容了
ClassLoader cl=this.getClass().getClassLoader();
//注意:使用ClassLoader对象时,这里的路径是相对于 /项目/WEB-INF/classes ,也就是编辑器中的 /src
InputStream is=cl.getResourceAsStream("/a.txt");
BufferedReader br=new BufferedReader(new InputStreamReader(is));
String line="";
while((line=br.readLine())!=null){
System.out.println(line);
}
} private void getClassPath2() throws IOException {
//获取类路径下资源,通过Class对象,在获取该资源的输入流对象就可以读取资源(文件)的内容了
Class<? extends CServlet> c=this.getClass();
/*注意:使用Class对象时,
* 如果路径以 / 开头,则相对 /项目/WEB-INF/classes ,也就是编辑器中的 /src
* 如果不以 / 开头,则相对于当前servlet路径
*/
InputStream is=c.getResourceAsStream("a.txt");
is=c.getResourceAsStream("/../../index.jsp");
BufferedReader br=new BufferedReader(new InputStreamReader(is));
String line="";
while((line=br.readLine())!=null){
System.out.println(line);
}
} }

servlet的一些应用

HTTP访问乱码问题:

1、客户端:最常见的是浏览器,在url中有中文时,最好使用URLEncoder对其进行编码,而且最好使用UTF-8编码

2、服务器端:

  ①接收数据:通过servlet接收,然后通过getParameter()进行获取时,使用的编码默认是iso-8859-1,所以要对接收到的数据进行重新转码包装

  ②响应数据:首先使用iso-8859-1编码,如果超过编码范围则使用系统编码,

javaweb一的更多相关文章

  1. 从啥也不会到可以胜任最基本的JavaWeb工作,推荐给新人的学习路线(二)

    在上一节中,主要阐述了JavaScript方面的学习路线.先列举一下我朋友的经历,他去过培训机构,说是4个月后月薪过万,虽然他现在还未达到这个指标. 培训机构一般的套路是这样:先教JavaSE,什么都 ...

  2. JavaWeb——Servlet

    一.基本概念 Servlet是运行在Web服务器上的小程序,通过http协议和客户端进行交互. 这里的客户端一般为浏览器,发送http请求(request)给服务器(如Tomcat).服务器接收到请求 ...

  3. JavaWeb——Listener

    一.基本概念 JavaWeb里面的listener是通过观察者设计模式进行实现的.对于观察者模式,这里不做过多介绍,大概讲一下什么意思. 观察者模式又叫发布订阅模式或者监听器模式.在该模式中有两个角色 ...

  4. .JavaWeb文件上传和FileUpload组件使用

    .JavaWeb文件上传 1.自定义上传 文件上传时的表单设计要符合文件提交的方式: 1.提交方式:post 2.表单中有文件上传的表单项:<input type="file" ...

  5. javaWeb应用打包

    在Java中,使用"jar"命令来对将JavaWeb应用打包成一个War包,jar命令的用法如下:

  6. JavaWeb——tomcat安装及目录介绍

    一.web web可以说,就是一套 请求->处理->响应 的流程.客户端使用浏览器(IE.FireFox等),通过网络(Network)连接到服务器上,使用HTTP协议发起请求(Reque ...

  7. 做JavaWeb开发不知Java集合类不如归家种地

    Java作为面向对象语言对事物的体现都是以对象的形式,为了方便对多个对象的操作,就要对对象进行存储.但是使用数组存储对象方面具有一些弊端,而Java 集合就像一种容器,可以动态地把多个对象的引用放入容 ...

  8. JavaWeb基础学习体系与学习思路

    对于JAVAWEB的学习,首先一定要明确的是学习整体框架和思路,要有一个把控.对于WEB,很多人认为是做网页,简单的把静态网页与JAVAWEB与网页设计一概而论. 拿起一本JS就开始无脑的学习,学了一 ...

  9. Eclipse下配置javaweb项目快速部署到tomcat

    用惯了VS,再用Eclipse,完全有一种从自动挡到手动挡的感觉啊. 很多同学在Eclipse下开发web项目,每一次修改代码,看效果的时候都有右键项目->Run as -> Run on ...

  10. javaweb学习笔记之servlet01

    一.Servlet概述 A servlet is a small Java program that runs within a Web server. Servlets receive and re ...

随机推荐

  1. Saying Good-bye to Cambridge Again

    Saying Good-bye to Cambridge Again Very quietly I take my leave,      As quietly as I came here;     ...

  2. Python json数据中文输出问题。

    这个问题困扰了我好久好久,最后看了一眼官方文档,解决问题了. 问题描述:从web上获取的json数据,然后对应的保存到了python的类型中.再次输出这个数据时,中文总会变成\u1234这种形式. P ...

  3. array.fliter无法正确过滤出我想要的数组

    var checked_list = state.files.filter(function(item, id){ // console.log('click the ' + item.id); re ...

  4. SSD-tensorflow-2 制作自己的数据集

    VOC2007数据集格式: VOC2007详细介绍在这里,提供给大家有兴趣作了解.而制作自己的数据集只需用到前三个文件夹,所以请事先建好这三个文件夹放入同一文件夹内,同时ImageSets文件夹内包含 ...

  5. Python中的引用计数法

    目录 引用计数法 增量操作 计数器溢出的问题 减量操作 终结器 插入计数处理 引用计数法 增量操作 如果对象的引用数量增加,就在该对象的计数器上进行增量操作.在实际中它是由宏Py_INCREF() 执 ...

  6. nl---统计行号

    nl命令读取 file 参数(缺省情况下标准输入),计算输入中的行号,将计算过的行号写入标准输出.在输出中,nl命令根据您在命令行中指定的标志来计算左边的行.输入文本必须写在逻辑页中.每个逻辑页有头. ...

  7. [APIO2010]巡逻(树的直径)

    [APIO2010]巡逻 题目描述 在一个地区中有 n 个村庄,编号为 1, 2, ..., n.有 n – 1 条道路连接着这些村 庄,每条道路刚好连接两个村庄,从任何一个村庄,都可以通过这些道路到 ...

  8. GenIcam标准关键词整理

    1.<?xml> 版本信息和编码方式 IntSwissKnife 需计算和判断的节点 MaskedIntReg 需查询的节点 2.<RegisterDescription> 寄 ...

  9. docker安装cloudera manager,切换cloudera-scm用户报错can not open session

    在root帐号下su - cloudera-scm报错can not open session 在网上搜,大概是说ulimit超过限制之类,搞了很久才找到/etc/security/limits.d/ ...

  10. iOS 动画Animation - 5:UIBezier

    首先说明:这是一系列文章,參考本专题下其它的文章有助于你对本文的理解. 在之前的bolg中大家会发现总是会出现UIBezier,可是我也没有做过多介绍,今天就集中介绍一下UIBezier.首先.UIB ...