知识屋:更实用的电脑技术知识网站
所在位置:首页 > 科技

JavaWeb学习过程

发表时间:2022-03-25来源:网络

JavaWeb

总结于狂神说java
他讲的很好,观看推荐

动态web

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-MxvCPXRT-1622964828729)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210520205235520.png)]

Tomcat

conf 配置文件

server.xml

修改端口号

主机名称

Idea配置Tomcat

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Vv2u3fPh-1622964828731)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210520222246627.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0-1622964828733)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210520222318073.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-f24o0PrK-1622964828735)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210520222536460.png)]

报错的原因,我们访问一个网站,需要指定一个文件夹的名字

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JSIfXLGR-1622964828735)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210520223137103.png)]

解决问题 创建一个artifacti

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-60zI9gcx-1622964828737)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210520223312915.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Db8vMMrz-1622964828737)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210520223628449.png)]

面试题

请你谈谈网站时如何访问的

​ 1.输入域名;回车

​ 2.检查本机 C:\Windows\System32\drivers\etc\hosts 配置文件下有没有这个域名的映射

1.有:直接返回对应IP地址,这个地址中,有我们需要访问的web程序,可以直接访问

127.0.0.1 www.yesheng.com

2.没有:去DNS服务器找,找到就返回,找不到就返回找不到

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LYp3VtCe-1622964828738)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210520201645533.png)]

发布一个web网站

不会就先模仿

将自己写的网站,放到服务器(Tomcat)中指定的web应用的文件夹(webapps)下,就可以访问了

网站应该有的结构

--webapps:Tomcat服务器的web目录 -ROOT -yeshen:网站的目录名 -WEB-INF -classes:java程序 -lib:web应用所依赖的jar包 -web.xml:网站配置文件 -index.html 默认的首页 -static -css -style.css -js -img -....

web.xml配置版本

Http

什么是Http

Http(超文本传输协议) 是一个简单的请求-响应协议,它通常运行在TCP之上。

文本:html,字符串超文本:图片,音乐,视频,定位,地图。。。80

Https:安全的

443

Http两个时代

http1.0:客户端与服务器建立连接后,只能获得一个web资源,断开连接

http1.1:客户端与服务器建立连接后,获得多个web资源

Http请求

客户端–发请求(Request)–服务器

百度:

Request URL: https://www.baidu.com/ Request Method: GET //get方法/post方法 Status Code: 200 OK //状态码:200 Remote(远程) Address: 183.232.231.174:443 Referrer Policy: unsafe-url

消息头

Accept:告诉浏览器,他所支持的数据类型 Accept-Encoding:支持的编码格式 GBK UTF-8 GB2312 Accept-Language:告诉浏览器 语言环境 Cache-Control:缓存控制 Connection:告诉浏览器,请求完成是断开还是连接 Host:主机

Http响应

服务器–响应–客户端

百度:

Cache-Control: private 缓存控制 Connection: keep-alive 连接: Content-Encoding: gzip Content-Type: text/html;charset=utf-8 编码类型

响应体

Accept:告诉浏览器,他所支持的数据类型 Accept-Encoding:支持的编码格式 GBK UTF-8 GB2312 Accept-Language:告诉浏览器 语言环境 Cache-Control:缓存控制 Connection:告诉浏览器,请求完成是断开还是连接 Host:主机 Refrush:告诉客户端,多久刷新一次 Location:让网页重新定位

状态码

200 :请求响应成功

3**:请求重定向

重新到我给的新位置

404:找不到资源

资源不存在

500:服务器代码错误

502:网关错误

常见面试题

当你的浏览器地址中输入地址回车时的一瞬间到页面额能够展示回来,经历了什么?

Maven

Maven架构管理工具

目前方便导入jar包

Maven的核心思想:约定大于配置

有约束,不要去违反

Maven会规定号你该如何去写java代码,必须按照这个规范来

下载Maven

官网:http://maven.apache.org/

Maven环境变量

M2_HOME=E:\gj\Maven\apache-maven-3.8.1\bin

MAVEN_HOME=E:\gj\Maven\apache-maven-3.8.1

path %MAVEN_HOME%\bin

阿里云镜像

镜像:mirrors

加速下载

国内建议阿里云

alimaven aliyun maven http://maven.aliyun.com/nexus/content/groups/public/ central

本地仓库

本地仓库,远程仓库

建立一个本地仓库localRepository

E:\gj\Maven\apache-maven-3.8.1\maven-repo

标记文件夹功能

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-gBzh7zdk-1622964828738)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210520221707142.png)]

pom.xml

pom.xml是Maven的核心配置文件

4.0.0 com.ye javaweb-01-maven 1.0-SNAPSHOT war javaweb-01-maven Maven Webapp http://www.example.com UTF-8 1.7 1.7 junit junit 4.11 test javaweb-01-maven maven-clean-plugin 3.1.0 maven-resources-plugin 3.0.2 maven-compiler-plugin 3.8.0 maven-surefire-plugin 2.22.1 maven-war-plugin 3.2.2 maven-install-plugin 2.5.2 maven-deploy-plugin 2.8.2

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-i0XdrHZ0-1622964828739)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210520225534913.png)]

maven由于他的约定大于配置,以后遇到写的配置文件,无法导出或生效的问题,解决方案

src/main/resources **/*.properties **/*.xml false src/main/java **/*.properties **/*.xml false

IDEA操作

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hk7eDPqg-1622964828739)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210520230412703.png)]

Maven仓库操作

没有的jar包,去这个地址找,然后放到pom.xml https://mvnrepository.com/

maven默认项目中的web.xml版本问题

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img--1622964828740)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210521111301566.png)]

解决

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HSe6ByJ4-1622964828740)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210521111755237.png)]

Servlet

server简介

Servlet是sun公司开发动态web的一门技术开发Servlet程序,两个步骤 编写好一个类,实现servlet接口把开发好的java类部署到web服务器中

把实现了servlet接口的Java程序叫做,servlet

HelloServlet

1.构建一个普通的Maven项目,

​ 删掉src目录,以后在这个项目中创建Moudel;这个空的工程就是Maven的主工程

2.关于Maven父子工程的理解;

​ 父项目中会有

servlet-01

​ 父项目中的java 子项目可以直接使用

3.Maven环境优化

​ 1)修改web.xml为最新的

​ 2)将Maven的结构搭建完整

4.编写一个servlet程序

​ 编写一个普通类

​ 实现servlet接口,这里我们直接继承HttpServlet

package com.yeshen.servlet; import javax.servlet.ServletException; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.IOException; import java.io.PrintWriter; public class HelloServlet extends HttpServlet { //由于get或post只是请求实现的不同的方式,可以互相调用,业务逻辑都一样 @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { //ServletOutputStream outputStream = 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); } }

5.编写servlet的映射

​ 为什么要映射,我们写的是Java程序,但是要通过浏览器访问,而浏览器要连接web服务器,所以需要在web服务中注册我们写的Servlet,还需要给他一个浏览器能够访问的路径

hello com.yeshen.servlet.HelloServlet hello /hello

6.配置Tomcat

7.启动测试

Servlet原理

Servlet由web服务器调用,web服务器在收到浏览器请求后,会:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1zU5W4Cy-1622964828741)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210521163301168.png)]

ServletContext

web容器在启动时,他会为每个web程序都创建一个对应的ServletContext对象,他代表当前的web应用

共享数据

在不同的Servlet中保存的数据,可以互相得到

public class HelloServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { //this.getServletContext(); Servlet上下文 //this.getServletConfig(); Servlet配置 //this.getInitParameter() 初始化参数 ServletContext context = this.getServletContext(); String username="夜深"; context.setAttribute("username",username); System.out.println("hello"); } } public class getC extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { ServletContext context = this.getServletContext(); String username=(String)context.getAttribute("username"); resp.setCharacterEncoding("utf-8"); resp.setContentType("text/html"); resp.getWriter().print("名字"+username); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { super.doPost(req, resp); } } hello com.yeshen.servlet.HelloServlet getC com.yeshen.servlet.getC hello /hello getC /getC

测试结果

首先打开getC 没有任何数据

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1YhqtzAJ-1622964828741)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210521181420392.png)]

通过hello设置ServletContext的值

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jzKHMkI0-1622964828742)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210521181529428.png)]

再次访问getC 可以得到数据

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-C4lv7suw-1622964828742)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210521181456830.png)]

获取初始化参数

url jdbc:mysql://localhost:3306/mybatis ServletContext context = this.getServletContext(); String url=context.getInitParameter("url"); resp.getWriter().print(url);

请求转发

@Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { ServletContext context = this.getServletContext(); // Re re = context.getRe("/gp");//转发的请求路径 // re.forward(req,resp);//调用forward实现请求转发 context.getRe("/gp").forward(req,resp); }

请求转发和重定向的区别

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vY4YrMQM-1622964828743)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210521184306019.png)]

读取资源文件

Properties

在java目录下新建properties在resources目录下新建properties

发现:都被打包到同一个路径下:classes,俗称类路径 classpath

思路:需要一个文件流;

public class ServlertDemo05 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("user"); String pwd=prop.getProperty("pwd"); resp.setContentType("text/html"); resp.setCharacterEncoding("utf-8"); resp.getWriter().print(user+":"+pwd); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { super.doPost(req, resp); } }

HttpServletResponse

web服务器接收到客户端的http请求,针对这个请求,分别创建一个代表请求的HttpServletRequest对象,代表响应的HttpServletResponse对象;

如果要获取客户端请求过来的参数:找HttpServletRequest如果要给客户端响应一些信息:找HttpServletResponse

简单分类

负责向浏览器发送数据的方法

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);

响应的状态码

int SC_CONTINUE = 100; int SC_SWITCHING_PROTOCOLS = 101; int SC_OK = 200; int SC_CREATED = 201; int SC_ACCEPTED = 202; int SC_NON_AUTHORITATIVE_INFORMATION = 203; int SC_NO_CONTENT = 204; int SC_RESET_CONTENT = 205; int SC_PARTIAL_CONTENT = 206; int SC_MULTIPLE_CHOICES = 300; int SC_MOVED_PERMANENTLY = 301; int SC_MOVED_TEMPORARILY = 302; int SC_FOUND = 302; int SC_SEE_OTHER = 303; int SC_NOT_MODIFIED = 304; int SC_USE_PROXY = 305; int SC_TEMPORARY_REDIRECT = 307; int SC_BAD_REQUEST = 400; int SC_UNAUTHORIZED = 401; int SC_PAYMENT_REQUIRED = 402; int SC_FORBIDDEN = 403; int SC_NOT_FOUND = 404; int SC_METHOD_NOT_ALLOWED = 405; int SC_NOT_ACCEPTABLE = 406; int SC_PROXY_AUTHENTICATION_REQUIRED = 407; int SC_REQUEST_TIMEOUT = 408; int SC_CONFLICT = 409; int SC_GONE = 410; int SC_LENGTH_REQUIRED = 411; int SC_PRECONDITION_FAILED = 412; int SC_REQUEST_ENTITY_TOO_LARGE = 413; int SC_REQUEST_URI_TOO_LONG = 414; int SC_UNSUPPORTED_MEDIA_TYPE = 415; int SC_RE_RANGE_NOT_SATISFIABLE = 416; int SC_EXPECTATION_FAILED = 417; int SC_INTERNAL_SERVER_ERROR = 500; int SC_NOT_IMPLEMENTED = 501; int SC_BAD_GATEWAY = 502; int SC_SERVICE_UNAVAILABLE = 503; int SC_GATEWAY_TIMEOUT = 504; int SC_HTTP_VERSION_NOT_SUPPORTED = 505;

下载文件

1.向浏览器输出消息

2.下载文件

​ 1.要获取下载文件的路径

​ 2.要下载的文件名

​ 3.设置让浏览器能够支持下载我们需要的东西

​ 4.获取下载文件的输入流

​ 5.创建缓冲区

​ 6.获取OutputStream对象

​ 7.将FileOutputStream流写入到buffer缓冲区

​ 8.使用OutputStream将缓冲区中的数据输出到客户端

public class FileServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { // 1.要获取下载文件的路径 String realPath = "F:\\web\\javawweb-02-servlet\\response\\src\\main\\resources\\1.png"; System.out.println("要下载文件的路径:"+realPath); // 2.要下载的文件名 String fileName=realPath.substring(realPath.lastIndexOf("\\")+1); // 3.设置让浏览器能够支持下载我们需要的东西 resp.setHeader("Content-Disposition","attachment;filename"+ URLEncoder.encode(fileName,"UTF-8")); // 4.获取下载文件的输入流 FileInputStream fis=new FileInputStream(realPath); // 5.创建缓冲区 int len=0; byte[] buffer=new byte[1024]; // 6.获取OutputStream对象 ServletOutputStream out=resp.getOutputStream(); // 7.将FileOutputStream流写入到buffer缓冲区,使用OutputStream将缓冲区中的数据输出到客户端 while ((len=fis.read(buffer))!=0){ out.write(buffer,0,len); } if(out!=null){ out.close(); } if(fis!=null){ fis.close(); } } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { super.doPost(req, resp); } }

验证码功能

验证怎么来的?

前端实现后端实现,需要用得到java的图片类生成一个图片

实现重定向

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-poXpYhNc-1622964828743)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210521205457225.png)]

一个web资源收到客户端请求,他会通知客户端去访问另一个web资源,这个过程叫重定向

A访问B,B收到A的请求后,B通知A去访问C

void sendRedirect(String var1) throws IOException; /* 重定向原理 resp.setHeader("Location","/r/img"); resp.setStatus(302); */ resp.sendRedirect("/r/img");

面试题:请你说说重定向和转发的区别?

相同点

页面都会实现跳转

不同点

请求转发时,url不会变化重定向时,url地址栏会变化

HttpServletRequest

获取前端传递的参数,请求转发

@Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { resp.setCharacterEncoding("utf-8"); req.setCharacterEncoding("utf-8"); String username = req.getParameter("username"); String password = req.getParameter("password"); String[] hobbys = req.getParameterValues("hobbys"); System.out.println("------------------------"); System.out.println(username); System.out.println(password); System.out.println(Arrays.toString(hobbys)); System.out.println("------------------------"); //请求转发 req.getRe("/success.jsp").forward(req,resp); }

Cookie、Session

会话

会话:用户打开一个浏览器,点击了很多超链接,访问了很多web资源,关闭浏览器,这个过程称之为会话

有状态会话:客户端访问过服务器,下次访问的时候,服务器知道曾经访问过

一个网站怎么证明你来过?

客户端 服务器

​ 1、服务器给客户端一个信件,客户端下次访问服务器时带上信件就可以了:cookie

​ 2、服务器登记你来过了,下次你来的时候我匹配你:session

保存会话的两种技术

cookie

客户端技术(响应,请求)

session

服务器技术,利用这个技术,可以保存用户的会话信息,我们可以把信息或数据放到session中

Cookie

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pAEDr0zN-1622964828744)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210524082906492.png)]

​ 1、从请求中获取cookie信息

​ 2、服务器响应给客户端cookie

Cookie[] cookies = req.getCookies();//从客户端获得cookie cookie.getName();//获取cookie的key cookie.getValue();//获取cookie的value Cookie cookie = new Cookie("lastLoginTime",System.currentTimeMillis()+"");//新建一个cookie cookie.setMaxAge(24*60*60);//设置cookie的有效期 resp.addCookie(cookie);//响应给客户端一个cookie

cookie一般会保存在本地的用户目录下appdata

一个网站cookie是否存在上限!

一个cookie只能保存一个信息;一个web站点可以给浏览器发送多个cookie,最多存放20个cookieCookie大小有限制4kb300个cookie浏览器的上限

删除Cookie

不设置有效期,关闭浏览器,自动失效设置有效期时间为0

编码,解码

Cookie cookie=new Cookie("name", URLEncoder.encode("厄加特","UTF-8"));//编码 out.write(URLDecoder.decode(cookie.getValue(),"UTF-8"));//解码

Session

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6F2Zsx4S-1622964828744)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210524083349728.png)]

什么是Session:

服务器会给每个用户(浏览器)创建一个Session一个Session独占一个浏览器,只要浏览器没关闭,这个Session就存在用户登录之后,整个网站他都可以访问—> 保存用户信息;保存购物车信息。。。

Session和Cookie的区别:

Cookie是把用户的数据写给浏览器,浏览器保存(可以保存多个)Session把用户的数据写到用户独占Session中,服务器端保存(保存重要的信息,减少服务器资源的浪费)Session对象由服务创建

使用场景:

保存一个登录用户的信息保存购物车信息在整个网站中经常使用的数据,我们把它保存在Session中

使用Session

package com.yeshen.servlet; import com.yeshen.pojo.Person; import javax.servlet.ServletException; import javax.servlet.http.*; import java.io.IOException; public class SessionDemo01 extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { //解决乱码问题 resp.setCharacterEncoding("UTF-8"); req.setCharacterEncoding("UTF-8"); resp.setContentType("text/html;charset=utf-8");//设置浏览器 //得到Session HttpSession session=req.getSession(); //给Session存东西 session.setAttribute("name",new Person("夜深",5)); //获取Session的id String sessionId = session.getId(); //判断Session是不是新创建的 if(session.isNew()){ resp.getWriter().write("session创建成功,sessionID:"+sessionId); }else{ resp.getWriter().write("session已经在服务器中创建了,sessionID:"+sessionId); } //session创建的时候做了什么 Cookie cookie = new Cookie("JESSSIONID", sessionId); resp.addCookie(cookie); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doGet(req, resp); } } //得到Session HttpSession session=req.getSession(); // String name =(String)session.getAttribute("name"); // System.out.println(name); Person person=(Person) session.getAttribute("name"); System.out.println(person.toString()); HttpSession session = req.getSession(); session.removeAttribute("name"); //手动注销session session.invalidate();

会话自动过期,web.xml配置

15

JSP

JSP是什么

我电脑的地址

C:\Users\10586\AppData\Local\JetBrains\IntelliJIdea2020.3\tomcat\0caab4f5-fc63-4815-8079-a1064720dc81\work\Catalina\localhost\ROOT\org\apache\jsp

jsp页面转变成了java程序

浏览器向服务器发送请求,不管访问什么资源,,其实都是在访问Servlet!

JSP最终也会被转成一个Java类

JSP本质就是一个Servlet

//初始化 public void _jspInit() { } //销毁 public void _jspDestroy() { } //JSP Service public void _jspService(final javax.servlet.http.HttpServletRequest request, final javax.servlet.http.HttpServletResponse response){ }

1.判断请求

2.内置对象

final javax.servlet.jsp.PageContext pageContext; //页面上下文 javax.servlet.http.HttpSession session = null; //session final javax.servlet.ServletContext application; //application final javax.servlet.ServletConfig config; //config javax.servlet.jsp.JspWriter out = null; //out final java.lang.Object page = this; //page 当前页面 HttpServletRequest request //请求 HTTPServletResponse response //响应

3.输出页面前加的代码

response.setContentType("text/html"); //设置响应的页面类型 pageContext = _jspxFactory.getPageContext(this, request, response, null, true, 8192, true); _jspx_page_context = pageContext; application = pageContext.getServletContext(); config = pageContext.getServletConfig(); session = pageContext.getSession(); out = pageContext.getOut(); _jspx_out = out;

以上的这些对象 可以在JSP页面直接使用

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ow6y4Ouk-1622964828745)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210524124315740.png)]

JSP语法

JSP表达式

hello,

jsp脚本片段

jsp声明

JSP声明:会被编译到JSP生成的Java类中,其他的会被生成到jspService方法中

在JSP中嵌入java代码

JSP注释不会再客户端显示,HTML的会

JSP指令

指令

网页主体

网页主体

9大内置对象

PageContext 存东西Request 存东西ResponseSession 存东西Application [ServletContext] 存东西config [ServletConfig]outpageexceptionrequest.setAttribute("name1","yeshen1");//保存的数据在页面中有效 pageContext.setAttribute("name2","yeshen2");//保存的数据在一次请求中有效,请求转发会携带数据 session.setAttribute("name3","yeshen3"); //保存的数据在一次会话中有效,从浏览器开启到关闭 application.setAttribute("name4","yeshen4"); //保存的数据在服务器中有效,从服务器开启到关闭

JSP标签,JSTL标签,EL表达式

javax.servlet.jsp.jstl jstl-api 1.2 taglibs standard 1.1.2

EL表达式:${}

获取数据执行运算获取web开发的常用对象

JSP标签

JSTL表达式

JSTL标签库的使用是为了弥补HTML标签的不足

格式化标签

SQL标签

XML标签

核心标签(掌握部分)

JSTL标签库使用步骤

引入对应的taglib使用其中的方法Tomcat也需要引入jstl的包,不然会报错,jstl解析错误 Title

if测试

JavaBean

实体类

JavaBean有特定的写法:

必须要有一个无参构造属性必须私有化必须有对应的set/get方法

一般用来和数据库的字段做映射 ORM

ORM:对象关系映射

表–>类字段–>属性行记录–>对象

MVC三层架构

什么是MVC:Model View Controller 模型 视图 控制器

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-SVS13kNY-1622964828746)(C:\Users\10586\AppData\Roaming\Typora\typora-user-images\image-20210524195920826.png)]

Model:

业务处理:业务逻辑(Service)数据持久层:CRUD (Dao)

View:

展示数据提供链接,发起Servlet请求(a,form,img…)

Controller(Servlet):

接收用户的请求:(req:请求参数,Session信息)

交给业务层处理对应的代码

控制视图的跳转

登录--->接收用户的登录请求--->处理用户的请求(获取用户登陆的参数,username,password。。。。)--->交给业务层处理登录业务(判断用户名,密码是否正确:事务)--->Dao层查询用户名,密码是否正确--->数据库

Filter

Filter:过滤器,用来过滤网站的数据

处理中文乱码登录验证

Filter开发步骤:

​ 1.导包

​ 2.编写过滤器

​ 1)导包不要错,java.servlet

​ 2)实现Filter接口,重写对应方法即可

package com.yeshen.filter; import javax.servlet.*; import java.io.IOException; public class CharacterEncodingFilter implements Filter { //初始化:web服务器启动时,就已经初始化了,随时等待过滤对象的出现 @Override public void init(FilterConfig filterConfig) throws ServletException { System.out.println("初始化"); } //Chain:链 @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { request.setCharacterEncoding("utf-8"); response.setCharacterEncoding("utf-8"); response.setContentType("text/html"); System.out.println("CharacterEncodingFilter执行前。。。"); chain.doFilter(request,response);//让请求继续走,如果不写,程序到这里被拦截停止 System.out.println("CharacterEncodingFilter执行后。。。"); } //销毁:web服务器关闭的时候,过滤器销毁 @Override public void destroy() { System.out.println("销毁"); } }

​ 3)在web.xml中配置filter

CharacterEncodingFilter com.yeshen.filter.CharacterEncodingFilter CharacterEncodingFilter /servlet/*

过滤器,监听器常见应用

用户登录之后才能进入主页,用户注销就不能进入主页

1.用户登录之后,向Session中放入用户的数据

2.进入主页的时候,判断用户是否已经登录;要求:在过滤器中实现

HttpServletRequest request=(HttpServletRequest) req; HttpServletResponse response=(HttpServletResponse) resp; if(request.getSession().getAttribute(Constant.USER_SESSION)==null){ response.sendRedirect("/error.jsp"); } chain.doFilter(request,response);

JDBC

导入数据库依赖

mysql mysql-connector-java 5.1.47

idea连接数据库

JDBC固定步骤

1.加载驱动

2.连接数据库

3.向数据库发送sql的对象statement:CRUD

4.编写sql

5.执行sql

6.关闭连接

package com.yeshen.test; import java.sql.*; public class TestJdbc { public static void main(String[] args) throws ClassNotFoundException, S { //配置信息 //useUnicode=true&characterEncoding=utf-8 解决中文乱码 String url="jdbc:mysql://localhost:3306/jdbc?useUnicode=true&characterEncoding=utf-8"; String username="root"; String password="hadoop"; //1.加载驱动 Class.forName("com.mysql.jdbc.Driver"); //2.连接数据库 Connection conn = DriverManager.getConnection(url, username, password); //3.向数据库发送sql的对线 Statement CRUD PreparedStatement ps=conn.prepareStatement(sql);(安全,预编译) Statement statement = conn.createStatement(); //PreparedStatement ps=conn.prepareStatement(sql); //4.编写sql String sql="select * from users"; //5.执行sql 返回一个resultset结果集 ResultSet rs = statement.executeQuery(sql); while (rs.next()){ System.out.print("id"+rs.getObject("id")+"\t"); System.out.print("name"+rs.getObject("name")+"\t"); System.out.print("pwd"+rs.getObject("pwd")+"\t"); System.out.print("email"+rs.getObject("email")+"\t"); System.out.print("birthday"+rs.getObject("birthday")); System.out.println(); } //6.关闭连接,释放资源 rs.close(); statement.close(); conn.close(); } }

增删改都使用statement.executeUpdate(sql)

//增删改都使用statement.executeUpdate(sql); int i = statement.executeUpdate(sql); package com.yeshen.test; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.util.Date; public class Test2 { public static void main(String[] args) throws Exception { String url="jdbc:mysql://localhost:3306/jdbc?useUnicode=true&characterEncoding=utf-8&useSSL=false"; String username="root"; String password="hadoop"; Class.forName("com.mysql.jdbc.Driver"); Connection conn = DriverManager.getConnection(url, username, password); String sql="insert into users(id, name, pwd, email, birthday) values (?,?,?,?,?)"; PreparedStatement ps = conn.prepareStatement(sql); ps.setObject(1,3); ps.setObject(2,"yeshen"); ps.setObject(3,"12346"); ps.setObject(4,"564@qq.com"); ps.setObject(5,new Date(new java.util.Date().getTime())); int i = ps.executeUpdate(); if (i>0){ System.out.println("执行成功"); } ps.close(); conn.close(); } }

Junit单元测试

测试依赖

junit junit 4.11 test

@Test只能在方法上使用,只要加了这个注解的方法就可以直接运行

@Test public void test(){ }

事务

@Test public void test(){ Connection conn=null; try { //配置信息 //useUnicode=true&characterEncoding=utf-8 解决中文乱码 String url="jdbc:mysql://localhost:3306/jdbc?useUnicode=true&characterEncoding=utf-8&useSSL=false"; String username="root"; String password="hadoop"; //1.加载驱动 Class.forName("com.mysql.jdbc.Driver"); //2.连接数据库 conn = DriverManager.getConnection(url, username, password); // 开启事务(取消自动提交) conn.setAutoCommit(false); String sql="update account set money=money-100 where name='a'"; conn.prepareStatement(sql).executeUpdate(); //制造错误 int i=1/0; String sql2="update account set money=money+100 where name='b'"; conn.prepareStatement(sql2).executeUpdate(); conn.commit(); } catch (ClassNotFoundException e) { try { conn.rollback(); } catch (S throwables) { throwables.printStackTrace(); } e.printStackTrace(); } catch (S e) { try { conn.rollback(); } catch (S throwables) { throwables.printStackTrace(); } e.printStackTrace(); }finally { try { conn.close(); } catch (S e) { e.printStackTrace(); } } }

功能扩展

文件上传

常用方法介绍:

//isFormFile方法用于判断FileItem类对象封装的数据是一个普通文本表单 //还是一个文件表单,如果时普通表单字段则返回true,否则返回false boolean isField(); //getFieldName方法用于返回表单标签name属性的值 String getFieldName(); //getString方法用于将FileItem对象中保存的数据流内容以一个字符串返回 String getString(); //getName方法用于获得文件上传字段中的文件名。 String getName(); //以流的形式返回上传文件的数据内容。 InputStream getInputStream(); //delete方法用来清空FileItem类对象中存放的主体内容 //如果主体内容被保存在临时文件中,delete方法将删除该临时文件 void delete();

具体代码实现

package com.hao.servlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.util.List; import java.util.UUID; import org.apache.commons.fileupload.FileItem; import org.apache.commons.fileupload.FileUploadException; import org.apache.commons.fileupload.ProgressListener; import org.apache.commons.fileupload.disk.DiskFileItemFactory; import org.apache.commons.fileupload.servlet.ServletFileUpload; public class FileServlet extends HttpServlet { protected void doPost(HttpServletRequest request, HttpServletResponse response) throws javax.servlet.ServletException, IOException { //判断上传的表单是普通表单还是带文件的表单,是返回true,否返回false; if (!ServletFileUpload.isMultipartContent(request)){ return;//如果这是一个普通文件我们直接返回 }//如果通过了这个if,说明我们的表单是带文件上传的 //创建上传文件的保存目录,为了安全建议在WEB-INF目录下,用户无法访问 String uploadpath = this.getServletContext().getRealPath("WEB-INF/Upload");//获取上传文件的保存路径 File uploadfile = new File(uploadpath); if (!uploadfile.exists()){ uploadfile.mkdir();//如果目录不存在就创建这样一个目录 } //临时文件 //临时路径,如果上传的文件超过预期的大小,我们将它存放到一个临时目录中,过几天自动删除,或者提醒用户转存为永久 String tmppath = this.getServletContext().getRealPath("WEB-INF/tmp"); File file = new File(tmppath); if (!file.exists()){ file.mkdir();//如果目录不存在就创建这样临时目录 } //处理上传的文件一般需要通过流来获取,我们可以通过request.getInputstream(),原生态文件上传流获取,十分麻烦 //但是我们都建议使用Apache的文件上传组件来实现,common-fileupload,它需要依赖于common-io组件; try { //1、创建DiskFileItemFactory对象,处理文件上传路径或限制文件大小 DiskFileItemFactory factory = gteDiskFileItemFactory(file); //2、获取ServletFileUpload ServletFileUpload upload = getServletFileUpload(factory); //3、处理上传文件 String msg = uploadParseRequest(upload,request,uploadpath); //Servlet请求转发消息 request.setAttribute("msg",msg); request.getRe("/info.jsp").forward(request,response); }catch (FileUploadException e){ e.printStackTrace(); } } public static DiskFileItemFactory gteDiskFileItemFactory(File file){ //1、创建DiskFileItemFactory对象,处理文件上传路径或限制文件大小 DiskFileItemFactory factory = new DiskFileItemFactory(); //通过这个工厂设置一个缓冲区,当上传的文件大小大于缓冲区的时候,将它放到临时文件中; factory.setSizeThreshold(1024 * 1024);//缓冲区大小为1M factory.setRepository(file); return factory; } public static ServletFileUpload getServletFileUpload(DiskFileItemFactory factory){ //2、获取ServletFileUpload ServletFileUpload upload = new ServletFileUpload(factory); //监听文件上传进度 upload.setProgressListener(new ProgressListener() { public void update(long pBytesRead, long lpContentLenght, int i) { //pBytesRead:已读取到的文件大小 //pContentLenght:文件大小 System.out.println("总大小:"+lpContentLenght+"已上传:"+pBytesRead); } }); //处理乱码问题 upload.setHeaderEncoding("UTF-8"); //设置单个文件的最大值 upload.setFileSizeMax(1024 * 1024 * 10); //设置总共能够上传文件的大小 //1024 = 1kb * 1024 = 1M * 10 = 10M upload.setSizeMax(1024 * 1024 * 10); return upload; } public static String uploadParseRequest(ServletFileUpload upload,HttpServletRequest request,String uploadpath) throws IOException, FileUploadException { String msg = ""; //3、处理上传文件 //把前端的请求解析,封装成一个FileItem对象 List fileItems = upload.parseRequest(request); for (FileItem fileItem : fileItems) { if (fileItem.isFormField()){ //判断是普通表单还是带文件的表单 //getFieldName指的是前端表单控件的name String name = fileItem.getFieldName(); String value = fileItem.getString("UTF-8");//处理乱码 System.out.println(name+":"+value); }else {//判断它是带文件的表单 //======================处理文件=======================// //拿到文件的名字 String uploadFileName = fileItem.getName(); System.out.println("上传的文件名:"+uploadFileName); if (uploadFileName.trim().equals("") || uploadFileName == null){ continue; } //获得上传的文件名,例如/img/girl/ooa.jpg,只需要ooa,其前面的后面的都不需要 String fileName = uploadFileName.substring(uploadFileName.lastIndexOf("/") + 1); //获得文件的后缀名 String fileExtName = uploadFileName.substring(uploadFileName.lastIndexOf(".") + 1); /* 如果文件后缀名fileExtName不是我们所需要的 就直接return,不处理,告诉用户文件类型不对 */ //可以使用UUID(唯一识别的通用码),保证文件名唯一 //UUID.randomUUID,随机生一个唯一识别的通用码 //网络传输中的东西,都需要序列化 //pojo,实体类,如果想要在多个电脑运行,传输--->需要吧对象都序列化了 //JNI=java Native Interface //implements Serializable :标记接口,JVM--->java栈 本地方法栈 native-->c++ String uuidPath= UUID.randomUUID().toString(); System.out.println("文件信息【文件名:"+fileName+"文件类型:"+fileExtName+"】"); //可以使用UUID(唯一通用识别码)来保证文件名的统一 String uuidFileName = UUID.randomUUID().toString(); //=======================传输文件=========================// //获得文件上传的流 InputStream inputStream = fileItem.getInputStream(); //创建一个文件输出流 FileOutputStream fos = new FileOutputStream(uploadpath + "/" + uuidFileName +"."+ fileExtName); //创建一个缓冲区 byte[] buffer = new byte[1024 * 1024]; //判断是否读取完毕 int len = 0; //如果大于0,说明还存在数据 while ((len=inputStream.read(buffer))>0){ fos.write(buffer,0,len); } //关闭流 fos.close(); inputStream.close(); msg = "文件上传成功!"; fileItem.delete();//上传成功,清除临时文件 } } return msg; } }

jsp

Title 上传用户: | Title ${msg}

xml

FileServlet com.hao.servlet.FileServlet FileServlet /upload.do ———————————————— 版权声明:本文为CSDN博主「蟹小黄」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。 原文链接:https://blog.csdn.net/qq_45879460/article/details/107544819

如果大于0,说明还存在数据
while ((len=inputStream.read(buffer))>0){
fos.write(buffer,0,len);
}

//关闭流 fos.close(); inputStream.close(); msg = "文件上传成功!"; fileItem.delete();//上传成功,清除临时文件 } } return msg; }

}

jsp ```javascript Title 上传用户:

|

Title ${msg}

xml

FileServlet com.hao.servlet.FileServlet FileServlet /upload.do ———————————————— 版权声明:本文为CSDN博主「蟹小黄」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。 原文链接:https://blog.csdn.net/qq_45879460/article/details/107544819
收藏
  • 人气文章
  • 最新文章
  • 下载排行榜
  • 热门排行榜