文章是看黑马做的笔记
https://www.bilibili.com/video/BV1Qf4y1T7Hx?p=98&share_source=copy_web
Web是全球广域网,也称为万维网(www),能够通过浏览器访问的网站。在我们日常的生活中,经常会使用浏览器去访问百度等网站.
JavaWeb就是用java语言来解决Web互联网相关问题。
什么是B/S架构?
B/S 架构:Browser/Server,浏览器/服务器 架构模式,它的特点是,客户端只需要浏览器,应用程序的逻辑和数据都存储在服务器端。浏览器只需要请求服务器,获取Web资源,服务器把Web资源发送给浏览器即可。
HTTP
HTTP( HyperText Transfer Protocol) 超文本传输协议,规定了浏览器和服务器之间的数据传输的规则。
学习HTTP主要就是学习请求和响应数据的具体格式内容
HTTP请求数据的格式
HTTP响应数据格式
响应状态码 | 说明 |
---|---|
1xx | 响应中——临时状态码,表示请求已经接受,告诉客户端应该继续请求或者如果它已经完成则忽略它 |
2xx | 成功——表示请求已经被成功接收,处理已完成 |
3xx | 重定向——重定向到其它地方:它让客户端再发起一个请求以完成整个处理 |
4xx | 客户端错误——处理发生错误,责任在客户端,如:客户端的请求一个不存在的资源,客户端未被授权,禁止访问等 |
5xx | 服务器端错误——处理发生错误,责任在服务端,如:服务端抛出异常,路由出错,HTTP版本不支持等 |
状态码大全:https://cloud.tencent.com/developer/chapter/13553
状态码 | 英文描述 | 解释 |
---|---|---|
200 | OK | 客户端请求成功,即处理成功,这是我们最想看到的状态码 |
302 | Found | 指示所请求的资源已移动到由Location响应头给定的 URL,浏览器会自动重新访问到这个页面 |
304 | Not Modified | 告诉客户端,你请求的资源至上次取得后,服务端并未更改,你直接用你本地缓存吧。隐式重定向 |
400 | Bad Request | 客户端请求有语法错误,不能被服务器所理解 |
403 | Forbidden | 服务器收到请求,但是拒绝提供服务,比如:没有权限访问相关资源 |
404 | Not Found | 请求资源不存在,一般是URL输入有误,或者网站资源被删除了 |
428 | Precondition Required | 服务器要求有条件的请求,告诉客户端要想访问该资源,必须携带特定的请求头 |
429 | Too Many Requests | 太多请求,可以限制客户端请求某个资源的数量,配合 Retry-After(多长时间后可以请求)响应头一起使用 |
431 | Request Header Fields Too Large | 请求头太大,服务器不愿意处理请求,因为它的头部字段太大。请求可以在减少请求头域的大小后重新提交。 |
405 | Method Not Allowed | 请求方式有误,比如应该用GET请求方式的资源,用了POST |
500 | Internal Server Error | 服务器发生不可预期的错误。服务器出异常了,赶紧看日志去吧 |
503 | Service Unavailable | 服务器尚未准备好处理请求,服务器刚刚启动,还未初始化好 |
511 | Network Authentication Required | 客户端需要进行身份验证才能获得网络访问权限 |
服务器代码可以使用socket自己编写,可以接受页面发送的请求和响应数据给前端浏览器有,但是一般都不会自己写,用到的是Web服务器,比如tomcat。
Tomcat
1、安装和配置
Tomcat的官网: https://tomcat.apache.org/
web服务器的作用
封装HTTP协议操作,简化开发
可以将Web项目部署到服务器中,对外提供网上浏览服务
进入官网进行tomcat的下载,选择8版本,找一个没用中文没有空格符的目录下进行解压。进入bin目录,找到starup.bat文件进行启动。
如果你的Java环境变量没用配置好是会发生闪现的错误。我的只在path下布置Java环境,需要弄成JAVA_HOME这种结构。
这个时候再次运行,不会发生闪现,但是中文乱码,需要改变编码方式。
conf/logging.prooperties
现在就不会出现乱码了。
如果想对端口号进行修改,默认的端口号是8080.
conf/server.xml
注: HTTP协议默认端口号为80,如果将Tomcat端口号改为80,则将来访问Tomcat时,将不用输入端口号。
如果启动时出现端口号被占用出错,就会显示
Address already in use: bind
Tomcat部署项目: 将项目放置到webapps目录下,即部署完成。
2、IDEA中创建Maven Web项目
这是你自己建maven的一个目录。
一般这个里面会需要配置镜像,不然下载会很慢。
在main里新建两个文件夹,java和resources。
将pom.xml的多余的删除留下如图所示的部分。
3、IDEA中使用tomcat
加一个tomcat插件,这个比集成本地的方法要方便得多,但是只支持到tomacat7
<build>
<plugins>
<!--Tomcat插件 -->
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<version>2.2</version>
<configuration>
<port>80</port><!--访问端口号 -->
<!--项目访问路径
未配置访问路径: http://localhost:80/tomcat-demo2/a.html
配置/后访问路径: http://localhost:80/a.html
如果配置成 /hello,访问路径会变成什么?
答案: http://localhost:80/hello/a.html
-->
<path>/</path>
</configuration>
</plugin>
</plugins>
</build>
Servlet
在上述新建完一个web工程后,导入依赖
<dependencies>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.1.0</version>
<!--
此处为什么需要添加该标签?
provided指的是在编译和测试过程中有效,最后生成的war包时不会加入
因为Tomcat的lib目录中已经有servlet-api这个jar包,如果在生成war包的时候生效就会和Tomcat中的jar包冲突,导致报错
-->
<scope>provided</scope>
</dependency>
</dependencies>
在java目录下新建一个java文件
package com.mydemo;
import javax.servlet.*;
import javax.servlet.annotation.WebServlet;
import java.io.IOException;
@WebServlet("/demo1")
public class ServletDemo1 implements Servlet {
@Override
public void init(ServletConfig servletConfig) throws ServletException {
}
@Override
public ServletConfig getServletConfig() {
return null;
}
@Override
public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException {
System.out.println("Servlet Hello World");
}
@Override
public String getServletInfo() {
return null;
}
@Override
public void destroy() {
}
}
主要关注service方法,如果能够成功访问,会自动调用service方法。
开始运行
把运行出的这个结果,复制到浏览器,并加上/demo1,进行运行。控制台上会出现Servlt Hello World。成功调用到该Servelt方法。
Servlet由web服务器创建,Servlet方法由web服务器调用
我们自定义的Servlet,必须实现Servlet接口并复写其方法,而Servlet接口中有service方法
关于Servlet生命周期
package com.mydemo;
import javax.servlet.*;
import javax.servlet.annotation.WebServlet;
import java.io.IOException;
@WebServlet(urlPatterns = "/demo2",loadOnStartup = 1)
public class ServletDemo2 implements Servlet {
/**
* 初始化方法
* 1.调用时机:默认情况下,Servlet被第一次访问时,调用
* * loadOnStartup: 默认为-1,修改为0或者正整数,则会在服务器启动的时候,调用
* 2.调用次数: 1次
* */
@Override
public void init(ServletConfig servletConfig) throws ServletException {
System.out.println("init---");
}
/**
* 提供服务
* 1.调用时机:每一次Servlet被访问时,调用
* 2.调用次数: 多次
* */
@Override
public ServletConfig getServletConfig() {
return null;
}
@Override
public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException {
System.out.println("Servlet Hello World");
}
@Override
public String getServletInfo() {
return null;
}
/**
* 销毁方法
* 1.调用时机:内存释放或者服务器关闭的时候,Servlet对象会被销毁,调用
* 2.调用次数: 1次
*/
@Override
public void destroy() {
System.out.println("销毁销毁---");
}
}
涉及到三个方法,分别是 init()、service()、destroy()
init方法在Servlet对象被创建的时候执行,只执行1次
service方法在Servlet被访问的时候调用,每访问1次就调用1次
destroy方法在Servlet对象被销毁的时候调用,只执行1次
我们可以自定义一个类去继承那个封装HTTP协议的实现类HttpServlet,
前端发送GET和POST请求的时候,参数的位置不一致,GET请求参数在请求行中,POST请求参数在请求体中。
表现出来的区别就是,一个可以直接http://localhost:80/demo3去访问,控制台输出得到get=====。一个需要先进入一个页面http://localhost:80/demo3.html,然后输入点击确定,控制台会返回一个post======。
package com.mydemo;
import javax.servlet.*;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@WebServlet(urlPatterns = "/demo3",loadOnStartup = 1)
public class ServletDemo3 extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("get======");
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("post======");
}
}
<form action="/demo3" method="post">
<input name="username"/><input type="submit"/>
</form>