JavaWeb
1、基本概念
1.1、web开发
- web : 网页的意思,如:www.baidu.com
- 静态web
- html、css
- 提供给所有人看的数据始终不会发生变化的页面!
- 动态web
- 淘宝,几乎是所有的网站;
- 提供给所有人看的数据始终会发生变化,每个人在不同的时间,不同的地点看到的信息各不相同!
- 技术栈:servlet/JSP、ASP、PHP
- 总结:在Java中,动态web资源开发的技术统称为:JavaWeb;
1.2、web应用程序
web应用程序:可以提供浏览器访问的程序;
- a.html、b.html…多个web资源,这些web资源可以被外界访问,对外界提供服务;
- 你们访问到的任何一个页面或者资源,都存在于这个世界的某一个角落的计算机上。
- url
- 这个统一的web资源会被放在同一个文件夹下,web应用程序–>Tomcat:服务器
- 一个web应用由多部分组成(静态web,动态web)
- html、css、js
- jsp、servlet
- java程序
- jar包
- 配置文件(Properties)
web应用程序编写完毕后,若想提供给外界访问:需要一个服务器来统一管理;
1.3 、静态web
- *.html: *.html这些都是网页的后缀,如果服务器上一直存在这些东西,我们就可以直接进行读取。

-
静态web存在的缺点:
-
web页面无法动态更新,所有用户看到都是同一个页面
- 轮播图,点击特效:伪动态
- javaScript【实际开发中,用的最多】
- VBScript
-
它无法和数据库交互(数据无法持久化,用户无法交互)
-
1.4、动态web
页面会动态展示:“web的页面展示的效果因人而异”;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZoIXJXFL-1616291219380)(C:\Users\Administrator\Desktop\3.png)]
优点:
-
web页面可以动态更新,所有用户看到都不是同一个页面
-
它可以与数据库交互(数据能够持久化,用户可以交互)
缺点:
- 假如服务器的动态web资源出现了错误,我们需要重新编写我们的后台程序,重新发布;
- 停机维护
2、web服务器
2.1、技术
ASP:
- 微软:国内最早流行的就是ASP;
- 在HTML中嵌入了VB的脚步,ASP+COM;
- 在ASP开发中,基本一个页面都有几千行的业务代码,页面极其混乱
PHP:
- PHP开发速度很快,功能很强大,跨平台,代码很简单(70%,WP)
- 无法承载大访问的情况(局限性)
JSP/Servlet:
- B/S:浏览和服务器
- C/S:客户端和服务器
- sun公司主推的B/S架构
- 基于Java语言
- 可以承载三高问题带来的影响;
- 语法像ASP,ASP—>JSP,加强市场强度;
2.2 web服务器
服务器是一种被动的操作,用来处理用户的一些请求和用户一些响应信息;
-
Tomcat
Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache、Sun 和其他一些公司及个人共同开发而成。由于有了Sun 的参与和支持,最新的Servlet 和JSP 规范总是能在Tomcat 中得到体现,Tomcat 5支持最新的Servlet 2.4 和JSP 2.0 规范。因为Tomcat 技术先进、性能稳定,而且免费,因而深受Java 爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web 应用服务器。
Tomcat 服务器是一个免费的开放源代码的Web 应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP 程序的首选。对于一个Java初学者来说,它是最佳的选择。
Tomcat 实际上运行JSP 页面和Servlet。目前Tomcat最新版本为9.0.41**。**
-
IIS
- 微软的;
3、Tomcat
-
下载tomcat 。https://tomcat.apache.org ;下载相应的版本。解压就能使用
-
文件夹作用:
-
启动、关闭Tomcat

-
访问测试:https://localhost:8080/
-
可能预见的问题:java环境变量没有配置、闪退问题,需要配置兼容性
-

-
可以配置启动的端口号:

-
可以配置主机的名称:
-
默认的主机名为:localhost–>127.0.0.1
-
默认网站应用存放的位置为:webapps
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true">
-
-
Tomcat启动日志乱码
12-Jan-2019 11:15:48.911 淇℃伅 [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name: Windows 10 12-Jan-2019 11:15:48.911 淇℃伅 [main] org.apache.catalina.startup.VersionLoggerListener.log OS.鐗堟湰: 10.0 12-Jan-2019 11:15:48.911 淇℃伅 [main] org.apache.catalina.startup.VersionLoggerListener.log 缁�.閫�: amd64 12-Jan-2019 11:15:48.911 淇℃伅 [main]-
修改tomcat的conf下的logging.properties中的参数
<!--将UTF-8改到GBK就行了保存后重启tomcat就正常了。 --> java.util.logging.ConsoleHandler.encoding = GBK
20-Mar-2021 13:47:59.775 信息 [main] org.apache.coyote.AbstractProtocol.stop 正在停止ProtocolHandler ["http-nio-8080"] 20-Mar-2021 13:47:59.793 信息 [main] org.apache.coyote.AbstractProtocol.destroy 正在摧毁协议处理器 ["http-nio-8080"] -
-
拓展:高难度面试题
请你谈谈网站是如何进行访问的!
-
输入一个域名;回车
-
检查本机的C:\Windows\System32\drivers\etc\hosts配置文件下有没有这个域名映射;
-
有:直接返回对应的ip地址,这个地址中,有我们需要访问的web程序,可以直接访问
127.0.0.1 www.baidu.com -
没有:去DNS服务器找,找到的话就返回,找不到就返回找不到;

-
-
-
发布一个web网站
不会就先模仿
-
将自己写的网站,放到服务器(Tomcat)中指定的web应用的文件夹(webapps)下,就可以访问了
-
网站应有的结构
--webapps:Tomcat服务器的web目录 --ROOT --kuangstudy:网站的目录名 --WEB-INF -classes:java程序 -lib:web应用所依赖的jar包 -web.xml:网站配置文件 -- index.html 默认的首页 --static -css -style.css -js -img --......
-
4、HTTP
4.1、什么是HTTP
http(超文本传输协议)是一个简单的请求-响应协议;通常运行在TCP之上。
- 文本:HTML,字符串,~…
- 超文本:图片,音乐,视频,定位,地图…
- 80
HTTPS:安全的
- 443
4.2、两个时代
- http1.0
- http/1.0:客户端可以与web服务器连接后,只能获得一个web资源,断开连接
- http2.0
- http/1.1:客户端可以与web服务器连接后,可以获得多个web资源。
4.3、HTTP请求
-
客户端—发请求(Request)—服务器
百度:
Request URL: https://www.baidu.com/ 请求地址 Request Method: GET //提交方式:get、post Status Code: 200 OK //状态码:200 Remote(远程) Address: 180.101.49.11:443 Referrer Policy: no-referrer-when-downg1rade -
请求行
- 请求行中的请求方式:get
- 请求方式:get,post,head,delete,put,tract。。。
- get:请求能够携带的参数比较少,大小有限制,会在浏览器的url地址栏显示数据内容,不安全,但高效
- post:请求能够携带的参数没有限制,大小没有限制,不会再浏览器的url地址栏显示数据内容,安全,但不高效。
4.4、HTTP响应
-
服务器—响应—客户端
百度:
Cache-Control: private //缓存控制 Connection: keep-alive //连接 Content-Encoding: gzip //编码 Content-Type: text/html;charset=utf-8 //类型 ---------------------------------------------------- Accept: text/html Accept-Encoding: gzip, deflate, br Accept-Language: zh-CN,zh;q=0.9 //语言 Cache-Control: max-age=0 Connection: keep-alive -
响应状态码
-
200:请求响应成功
-
3**:请求重定向
重定向:你重新到我给你新位置去;
-
404:找不到资源
-
5XX:服务器代码错误 500 502:网关错误
-
常见面试题
当你的浏览器中地址栏输入地址并回车的一瞬间到页面能够展示回来,经历了什么?
5、maven
我为什么要学习这个技术?
1.早javaweb开发中,需要使用大量的jar包,我们手动去导入;
2.如何能够让一个东西自动帮我导入和配置这个jar包。
由此,maven诞生了!
5.1、Maven项目架构管理工具
我们目前用来就是方便导入jar包的!
maven的核心思想:约定大于配置;
- 有约束,不要去违反。
Maven会规定好你该如何去编写我们的java代码,必须要按照这个规范来;
5.2、下载安装Maven
官网:https://maven.apache.org/
5.3、配置阿里云镜像和本地仓库


<!-- 阿里镜像仓库 -->
<mirrors>
<mirror>
<id>alimaven</id>
<name>aliyun maven</name>
<url>
http://maven.aliyun.com/nexus/content/groups/public/
</url>
<mirrorOf>central</mirrorOf>
</mirror>
</mirrors>
5.4、常见问题
-
maven由于他的约定大于配置,我们之后可能遇见我们写的配置文件,无法被导出或者生效的问题,解决发案:
<!--在build中配置resources,来防止我们资源导出失败的问题--> <build> <resources> <resource> <directory>src/main/resources</directory> <includes> <include>**/*.properties</include> <include>**/*.xml</include> </includes> <filtering>true</filtering> </resource> <resource> <directory>src/main/java</directory> <includes> <include>**/*.properties</include> <include>**/*.xml</include> </includes> <filtering>true</filtering> </resource> </resources> </build>
6、Servlet
6.1、Servlet简介
-
servlet 就是sun公司开发动态web的一门技术
-
Sun在这些API中提供了一个接口叫做:Servlet,如果你想开发一个Servlet程序,只需要完成两个小步骤;
-
编写一个类,实现Servlet接口
-
把开发好的Java类部署到web服务器中。
-
把实现了Servlet接口的Java程序叫做,Servlet
6.2、HelloServlet
servlet接口在sun公司有两个默认实现类:HttpServlet,
-
构建一个普通的mavn项目,删掉里面的src目录,以后我们的学习就在这个项目里面建立Moudel;这个空的工程就是maven主工程;
-
关于maven父子工程的理解:
父项目中会有:
<modules> <module>servlet-01</module> </modules> <packaging>pom</packaging>子项目会有:
<parent> <artifactId>myServlet</artifactId> <groupId>org.example</groupId> <version>1.0-SNAPSHOT</version> </parent>父项目中的java子项目可以直接使用:son extends father
-
最新web.xml 配置
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0"
metadata-complete="true">
</web-app>
-
编写一个servlet程序
-
编写一个普通类
-
实现servlet接口,这里我们直接继承HttpServlet类
public class HelloServlet extends HttpServlet { //由于get或者post只是请求实现的不同方式,可以相互调用,业务逻辑都一样; @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { //resp.getOutputStream(); PrintWriter writer = resp.getWriter(); //响应流 writer.print("Hello,Servlet!"); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { super.doPost(req, resp); } }
-
-
编写Servlet的映射
为什么需要映射:我们写的是java程序,但是需要通过浏览器访问,而浏览器需要连接web服务器,所以我们需要再web服务器中注册我们写servlet,还需要给它一个浏览器能够访问的路径;
<!--注册servlet --> <servlet> <servlet-name>hello</servlet-name> <servlet-class>com.zdt.servlet.HelloServlet</servlet-class> </servlet> <!--servlet的请求路径 --> <servlet-mapping> <servlet-name>hello</servlet-name> <url-pattern>/hello</url-pattern> </servlet-mapping>- web.xml文件是什么?有什么用?
一般的web工程中都会用到web.xml,web.xml主要用来配置,可以方便的开发web工程。web.xml主要用来配置Filter、Listener、Servlet等。但是要说明的是web.xml并不是必须的,一个web工程可以没有web.xml文件
- WEB工程加载web.xml过程
经过个人测试,WEB工程加载顺序与元素节点在文件中的配置顺序无关。即不会因为 filter 写在 listener 的前面而会先加载 filter。WEB容器的加载顺序是:ServletContext -> context-param -> listener -> filter -> servlet。并且这些元素可以配置在文件中的任意位置。
加载过程顺序如下:
- 启动一个WEB项目的时候,WEB容器会去读取它的配置文件web.xml,读取和两个结点。
- 紧急着,容创建一个ServletContext(servlet上下文),这个web项目的所有部分都将共享这个上下文。
- 容器将转换为键值对,并交给servletContext。
- 容器创建中的类实例,创建监听器。
原文链接:https://blog.youkuaiyun.com/ckc_666/article/details/82964812
-
配置Tomcat
-

-

-

-
注意:配置项目发布的路径就可以了
-
-
启动测试

6.3、Servlet原理
Servlet是有web服务器调用,web在收到浏览器请求后,会:

6.4、Mapping问题
-
一个servlet可以指定一个映射路径
<!--注册servlet --> <servlet> <servlet-name>hello</servlet-name> <servlet-class>com.zdt.servlet.HelloServlet</servlet-class> </servlet> <!--servlet的请求路径 --> <servlet-mapping> <servlet-name>hello</servlet-name> <url-pattern>/hello</url-pattern> </servlet-mapping> -
一个servlet可以指定多个映射路径
<servlet-mapping> <servlet-name>hello</servlet-name> <url-pattern>/hello</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>hello</servlet-name> <url-pattern>/hello2</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>hello</servlet-name> <url-pattern>/hello3</url-pattern> </servlet-mapping> -
一个servlet可以指定通用映射路径
<!-- --> <servlet-mapping> <servlet-name>hello</servlet-name> <url-pattern>/hello/*</url-pattern> </servlet-mapping> <!-- 默认请求路径 --> <servlet-mapping> <servlet-name>hello</servlet-name> <url-pattern>/*</url-pattern> </servlet-mapping> -
指定一些后缀或者前缀等等…
<!-- 可以自定义后缀实现请求映射,注意点:“*”前面不能加映射的路径--> <servlet-mapping> <servlet-name>hello</servlet-name> <url-pattern>*.do</url-pattern> </servlet-mapping> -
优先级问题:
指定了固有的映射路径优先级最高,如果找不到就会走默认的处理请求;
<!--404 --> <servlet> <servlet-name>error</servlet-name> <servlet-class>com.zdt.servlet.ErrorServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>error</servlet-name> <url-pattern>/*</url-pattern> </servlet-mapping>
6.5、ServletContext
web容器在启动的时候,它会为每个web程序创建一个对应的servletContext对象,它代表了当前的web应用;
1、共享数据
我在这个servlet中保持的数据,可以在下一个servlet中使用。
public class HelloServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("使用doget!");
PrintWriter writer = resp.getWriter();
writer.print("hello,servlet");
/* this.getInitParameter(); 初始化参数
this.getServletConfig() servlet配置
this.getServletContext() servlet上下文
*/
ServletContext servletContext = this.getServletContext();
String username = "秦家" ;//数据
//将一个数据保存在了ServletContext中,名字为:username,值为:username
servletContext.setAttribute("username",username);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
}
}
public class GetServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
ServletContext context = this.getServletContext();
String username = (String) context.getAttribute("username");
resp.setContentType("text/html");
resp.setCharacterEncoding("utf-8");
resp.getWriter().print("名字:"+username);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doGet(req,resp);
}
}

<servlet>
<servlet-name>getServlet</servlet-name>
<servlet-class>com.zdt.servlet.GetServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>getServlet</servlet-name>
<url-pattern>/getServlet</url-pattern>
</servlet-mapping>
测试结果:HelloServlet中声明的对象username,放入ServletContext中。GetServlet通过调用
ServletContext里面的属性名username,能够获得HelloServlet放入的username值。从而证明:在这个Servlet中保持的数据,可以在下一个Servlet中使用
2、配置初始化,获取初始化参数
<!--配置一些web应用初始化参数 -->
<context-param>
<param-name>url</param-name>
<param-value>jdbc:mysql://localhost:3306/mybatis</param-value>
</context-param>
<!--注册servlet -->
<servlet>
<servlet-name>sdome01</servlet-name>
<servlet-class>com.zdt.servlet.ServletDemo01</servlet-class>
</servlet>
<!--servlet的请求路径 -->
<servlet-mapping>
<servlet-name>sdome01</servlet-name>
<url-pattern>/sdome01</url-pattern>
</servlet-mapping>
public class ServletDemo01 extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
ServletContext context = this.getServletContext();
//获取web应用参数: url
String url = context.getInitParameter("url");
resp.getWriter().print(url);
}
}
3、请求转发

浏览器A,发送请求给ServletB,B对请求A处理,但是没有返回,而是给了服务器另一个sevrlet再加工,而后返回。这个过程,请求头和响应头用的都是同一个。里面的协议,编码,数据都不改变。即:两个servlet间是实现了通信。
调用demo02配置,实际上是在context.getRequestDispatcher方法进行了路径的转发。转发到了/getServlet路径下面
public class ServletDemo02 extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
ServletContext context = this.getServletContext();
System.out.println("进入了ServletDemo02。。。");
/*//转法的请求路径
RequestDispatcher requestDispatcher = context.getRequestDispatcher("/getServlet");
//调用forward实现请求转发:
requestDispatcher.forward(req,resp);*/
//等于上面两句的简写。
context.getRequestDispatcher("/getServlet").forward(req,resp);
}
}
4、读取资源文件
propreties
- 在java目录下新建propreties
- 在resources目录下新建propreties
发现:都被打包到了同一个路径下:classes,我们俗称这个路径为:ClassPath(类路径);
思路:需要一个文件流;
username=root
password=123456
public class ServletDemo05 extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
InputStream is = this.getServletContext().getResourceAsStream("/WEB-INF/classes/db.properties");
Properties prop = new Properties();
prop.load(is);
String user = prop.getProperty("username");
String pwd = prop.getProperty("password");
resp.getWriter().print(user+":"+pwd);
}
}
访问测试即可;
6.6、HttpServletResponse
响应:web服务器接收到客户端的http请求,针对这个请求,分别创建了一个代表请求的HttpServletRequest对象,代表响应的一个HttpServletResponse对象
- 如果要获取客户端请求过来的参数:找HttpServletRequest
- 如果要给客户端响应一些信息:找HttpServletResponse
1、简单分类
负责向浏览器发生数据的方法:
ServletOutputStream getOutputStream() throws IOException;
PrintWriter getWriter() throws IOException;
负责向浏览器发送响应头的方法:
void setCharacterEncoding(String var1);
void setContentLength(int var1);
void setContentLengthLong(long var1);
void setContentType(String var1);
void setDateHeader(String var1, long var2);
void addDateHeader(String var1, long var2);
void setHeader(String var1, String var2);
void addHeader(String var1, String var2);
void setIntHeader(String var1, int var2);
void addIntHeader(String var1, int var2);
2、常见应用
-
向浏览器输出消息
-
下载文件
- 要获取下载文件的路径
- 下载的文件名是啥?
- 设置想办法让浏览器能够支持下载我们需要的东西
- 获取下载文件的输入流
- 创建缓冲区
- 获取OutputStream对象
- 将FileOutputStream流写入到缓冲区
- 使用OutputStream将缓冲区的数据输入客户端!
public class FileServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { // 要获取下载文件的路径 String realPath = "F:\\IdeaProjects\\myServlet\\response\\src\\main\\resources\\3.png"; System.out.println("下载文件的路径:"+realPath); // 下载的文件名是啥? String filename = realPath.substring(realPath.lastIndexOf("\\")+1); // 设置想办法让浏览器能够支持下载我们需要的东西,中文文件名使用URLEncoder.encode(filename,"utf-8")进行转码,防止出现乱码! resp.setHeader("Content-Disposition", "attachment;filename="+ URLEncoder.encode(filename,"utf-8")); // 获取下载文件的输入流 FileInputStream in = new FileInputStream(realPath); // 创建缓冲区 int len = 0; byte[] bu = new byte[1024]; // 获取OutputStream对象 ServletOutputStream out = resp.getOutputStream(); // 将FileOutputStream流写入到缓冲区,使用OutputStream将缓冲区的数据输入客户端! while ((len =in.read(bu))>0){ out.write(bu,0,len); } in.close(); out.close(); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { super.doPost(req, resp); } } -
验证码功能
- 验证怎么来的?
- 前端实现
- 后端实现,需要用到java的图片类,生成一个图片。
- 验证怎么来的?
public class ImageServlet extends HttpServlet {
//生成随机数
private String makeNum(){
Random random = new Random();
String num = random.nextInt(99999999)+"";
StringBuffer sb = new StringBuffer();
for (int i = 0; i < 7-num.length(); i++) {
sb.append("0");
}
num = sb.toString()+num;
return num;
}
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//如何让浏览器5秒自动刷新一次;
resp.setHeader("refresh","5");
//在内存中创建一个图片
BufferedImage image = new BufferedImage(80,20,BufferedImage.TYPE_INT_RGB);
//得到图片
Graphics2D g = (Graphics2D) image.getGraphics();//笔
//设置图片的背景颜色
g.setColor(Color.white);
g.fillRect(0,0,80,20);
//给图片写数据
g.setColor(Color.blue);
g.setFont(new Font(null,Font.BOLD,20));
g.drawString(makeNum(),0,20);
//告诉浏览器,这个请求用图片的方式打开
resp.setContentType("image/jpeg");
//网站存在缓存,不让浏览器缓存
resp.setDateHeader("expires",-1);
resp.setHeader("Cache-Control","no-cache");
resp.setHeader("Pragma","no-cache");
//把图片写给浏览器
ImageIO.write(image,"jpg",resp.getOutputStream());
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
super.doPost(req, resp);
}
}
3、实现重定向

web资源B收到客户端A请求后,B会通知客户端A去访问另一个web资源C,这个过程就是重定向;
常见场景:
- 用户登录
void sendRedirect(String var1) throws IOException
测试:
public class RedirectServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
/*resp.setHeader("Location","/response/rs");
resp.setStatus(302);*/
resp.sendRedirect("/response/ImageServlet");
}
}
面试题:请你聊聊重定向和转发的区别?
相同点:页面都会实现跳转
不同点:请求转发的时候,url不会产生变化。
<html>
<body>
<h2>Hello World!</h2>
<%-- 这里提交的路径,需要寻找到项目的路径
${pageContext.request.contextPath}:代表当前的项目
--%>
<form action="${pageContext.request.contextPath}/requestTest" method="get">
用户名:<input type="text" name="username"></br>
密码:<input type="password" name="password"></br>
<input type="submit" value="提交">
</form>
</body>
</html>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<h1>欢迎光临!</h1>
</body>
</html>
public class RequestTest extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//System.out.println("进入这个请求!!!");
String username = req.getParameter("username");
String password = req.getParameter("password");
System.out.println(username+":"+password);
//重定向时候一定要注意,路径问题,否则404
resp.sendRedirect("/response/success.jsp");
}
}
上面是2个页面的重定向,测试成功。
6.7、HttpServletRequest
HttpServletRequest代表客户端的请求,用户通过http协议访问服务器;http中的所有信息会被封装到HttpServletRequest里面,通过这个HttpServletRequest的方法,获得客户端的所有信息。
| 方法 | 解释 |
|---|---|
| getRequestURI() | 返回请求行中的参数部分。 |
| getQueryString () | 方法返回请求行中的参数部分(参数名+值) |
| getRemoteHost() | 返回发出请求的客户机的完整主机名。 |
| getRemoteAddr() | 返回发出请求的客户机的IP地址。 |
| getPathInfo() | 返回请求URL中的额外路径信息。额外路径信息是请求URL中的位于Servlet的路径之后和查询参数之前的内容,它以"/"开头。 |
| getRemotePort() | 返回客户机所使用的网络端口号。 |
| getLocalAddr() | 返回WEB服务器的IP地址。 |
| getParameterValues() | 返回参数名传递的值,数组形式。 |
| getParameter() | 返回参数名传递的值,单个值。 |
1、获取前端传递的参数,请求转发
public class RepusetTest extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//后台接收乱码,问题
req.setCharacterEncoding("utf-8");
resp.setCharacterEncoding("utf-8");
String username = req.getParameter("username");
String password = req.getParameter("password");
String [] hoppers = req.getParameterValues("hoppers");
System.out.println("username = " + username + ", password = " + password);
System.out.println(Arrays.toString(hoppers));
System.out.println("==================================");
//通过请求转发
//这里的"/"代表当前的web应用
//方法:1、resp.sendRedirect("/repuest/success.jsp");
//方法:2、resp.sendRedirect(req.getContextPath()+"/success.jsp");
req.getRequestDispatcher("/success.jsp").forward(req,resp);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doGet(req,resp);
}
}
<div>
<form action="${pageContext.request.contextPath}/login" method="post">
用户名:<input type="text" name="username"><br>
密码:<input type="password" name="password"><br>
爱好:<input type="checkbox" name="hoppers" value="上网">上网
<input type="checkbox" name="hoppers" value="睡觉">睡觉
<input type="checkbox" name="hoppers" value="游戏">游戏
<input type="checkbox" name="hoppers" value="音乐">音乐
<br>
<input type="submit">
</form>
</div>
ln("==================================");
//通过请求转发
//这里的"/“代表当前的web应用
//方法:1、resp.sendRedirect(”/repuest/success.jsp");
//方法:2、resp.sendRedirect(req.getContextPath()+"/success.jsp");
req.getRequestDispatcher("/success.jsp").forward(req,resp);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doGet(req,resp);
}
}
```html
<div>
<form action="${pageContext.request.contextPath}/login" method="post">
用户名:<input type="text" name="username"><br>
密码:<input type="password" name="password"><br>
爱好:<input type="checkbox" name="hoppers" value="上网">上网
<input type="checkbox" name="hoppers" value="睡觉">睡觉
<input type="checkbox" name="hoppers" value="游戏">游戏
<input type="checkbox" name="hoppers" value="音乐">音乐
<br>
<input type="submit">
</form>
</div>

2073

被折叠的 条评论
为什么被折叠?



