JavaEE(2)

Servlet

创建一个类继承HttpServlet,重写doget dopost 方法,并在web.xml中配置

Servlet作用

1.接收用户发送的请求数据

2.调用其他的Java程序来处理请求

3.向前端做出响应

请求地址

ip:端口/项目名/servlet程序地址

IP和端口找服务器

Servlet生命周期

创建:

第一次访问Servlet程序时,由服务器创建

初始化:

在构造方法执行完成后,调用init()执行一些初始化操作

服务:

每次请求调用service()

销毁:服务器关闭时,会销毁servlet对象,并且在销毁servlet对象时,会自动调用destroy(),执行销毁操作

每个用于前后端交互的Servlet需要在src.main.webapp.WEB-INT.web.xml中注册

<servlet>
    <servlet-name>login</servlet-name>
    <servlet-class>com.ffyc.dormserver.web.LoginServlet</servlet-class>
</servlet>
<servlet-mapping>
    <servlet-name>login</servlet-name>
    <url-pattern>/login</url-pattern>
</servlet-mapping>

http请求

前端向后端发送http请求,超链接,提交表单等都是发送http请求

http请求的三部分

1.请求行:包含请求的方式,请求的资源地址等

2.请求头:包含客户端的一些环境信息,这些信息都是由浏览器自动发送的,以键值对显示传递

3.请求体:表单post方式提交数据

请求分类

get请求

特点:传少量数据,获得大量数据

传递的参数,在请求地址?后面 键=值&键=值

"http://127.0.0.1:8088/demo/check?account="+account+"\&password="+password;

后端在Servlet中使用doget()方法接收

post请求:

特点:传大量数据,不在地址中显示

后端在Servlet中使用dopost()方法接收

过滤器

是javaEE中对请求和响应进行拦截的技术

可以让请求到达目标servlet之前,先进入到过滤器中,在过滤器中统一进行一些拦截处理,当处理完成后,可以向后执行到达目标servlet,如果配置了多个过滤器,也可以进入到下一个过滤器

创建过滤器方法:定义一个类,实现Filter接口,重写doFilter()方法,并在web.xml中配置

<!--注册编码过滤器-->
    <filter>
        <filter-name>encoding</filter-name>
        <filter-class>com.ffyc.dormserver.filter.EncodingFilter</filter-class>
        <init-param>
            <param-name>reqencod</param-name>
            <param-value>utf-8</param-value>
        </init-param>
        <init-param>
            <param-name>respencod</param-name>
            <param-value>text/html;charset=utf-8</param-value>
        </init-param>
    </filter>
    <!--配置哪些地址可以进入到编码过滤器-->
    <filter-mapping>
        <filter-name>encoding</filter-name>
        <url-pattern>/*</url-pattern><!--  /* 表示所有向后端发送的请求,都进入到编码过滤器中 -->
    </filter-mapping>

可以让某些请求地址在到达servlet之前进入到指定的过滤器中

从而实现统一处理 例如编码过滤 权限等进行统一过滤

过滤器使用场景

统一编码过滤

权限验证

词汇过滤

跨域过滤

......

    String reqencod ="";
    String respencod ="";
    //在init方法中,可以通过filterConfig获得配置文件中的初始化参数
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        System.out.println("初始化过滤器");
        reqencod = filterConfig.getInitParameter("reqencod");
        respencod = filterConfig.getInitParameter("respencod");
    }

    //执行过滤操作
    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        //设置请求编码集
        servletRequest.setCharacterEncoding(reqencod);
        //设置响应编码集
        servletResponse.setContentType(respencod);
        //让请求离开过滤器,继续向下执行,下一个可能是过滤器,也可能是目标访问的serlvet
        filterChain.doFilter(servletRequest, servletResponse);
        //filterChain 过滤链
    }

同步异步

同步

同时只能做一件事

同步请求

当前端向后端发送请求时,此时客户端一切操作都会终止,服务器响应回来的内容会覆盖当前网

页中的内容

使用表单交互

这种请求方式在前后端交互时不太友好

异步

同时做多件事

异步请求

当客户端与服务区交互时,不影响客户端页面的其他操作,同时做多件事情

服务器响应回来的内容不会覆盖整个页面

现在的前后端交互都是异步的,由于页面不用覆盖,体验感更好

如何实现发送异步请求
1.原始的方式

在前端用一个js对象 XMLhttpRequest 发送请求 接收响应

//创建请求对象
var httpobj = new XMLHttpRequest();
httpobj.open("get","http://127.0.0.1:8088/dormServer/check?account="+account);//封装请求
httpobj.send(null);//发送请求
                    
//执行回调函数  接收响应的结果
httpobj.onreadystatechange = function(){
    document.getElementById("msg").innerHTML = httpobj.responseText;//后端响应的内容
}
2.用异步框架

axios异步框架

http://axios-js.com/zh-cn/docs/

axios.get("http://127.0.0.1:8088/demoServer/check?account="+account).then((resp)=>{
    if(resp.status==200){
        document.getElementById("msg").innerHTML = resp.data;//resp.data取出后端响应的内容
    }
});

跨域问题

前后端异步交互会出现跨域问题

1.定义

不同的服务器间进行访问时,浏览器不允许js接收来自其他服务器响应的数据

只要协议,域名,端口其中一个不同,都属于跨域访问

跨域问题是一个前端问题,可以在前端解决,也可以在后端解决

2.为什么要跨域访问

前后端分离开发(前端和后端各自在不同的服务中)

同一家公司不同项目之间要交互

3.浏览器为什么要阻止跨域访问

为了安全,不能让其他服务器的内容肆意的响应到自己的服务中

4.如何解决跨域问题:前端解决 后端解决

后端解决:在响应式告知浏览器允许来自某些指定服务响应的内容

//创建过滤器在后端解决跨域问题
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

/*后端向前端响应时,告诉前端本次响应是安全的*/

@WebFilter(urlPatterns = "/*")
public class CorsFilter implements Filter {
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)
            throws IOException, ServletException {
        HttpServletResponse httpResponse = (HttpServletResponse) servletResponse;
        HttpServletRequest httpRequest = (HttpServletRequest) servletRequest;
        //允许携带Cookie时不能设置为* 否则前端报错
        httpResponse.setHeader("Access-Control-Allow-Origin", httpRequest.getHeader("origin"));//允许所有请求跨域 测试时使用,以后需要更改
        httpResponse.setHeader("Access-Control-Allow-Methods", "*");//允许跨域的请求方法GET, POST, HEAD 等
        httpResponse.setHeader("Access-Control-Allow-Headers", "*");//允许跨域的请求头
        httpResponse.setHeader("Access-Control-Allow-Credentials", "true");//是否携带cookie

        filterChain.doFilter(servletRequest, servletResponse);
    }
}

json(javaScript object notation)

后端一般情况下将数据封装到对象中,但是js并不认识java对象

java中使用toString方法将对象转为字符串后,js接收到的也只是普通的字符串

为了让js能够方便的进行操作,在java中将对象转为json格式的字符串,传递给前端js

json格式的字符串 {属性:值,属性:值...}

是一种通用的数据格式 java和js都认识,是现在前后端交互的数据标准格式

后端标准响应数据格式(Result类)

三个属性

code:状态码

desc:提示

data:内容

相关推荐
代码小鑫1 分钟前
A032-基于Spring Boot的健康医院门诊在线挂号系统
java·开发语言·spring boot·后端·spring·毕业设计
训山9 分钟前
4000字浅谈Java网络编程
java·开发语言·网络
VertexGeek15 分钟前
Rust学习(四):作用域、所有权和生命周期:
java·学习·rust
喔喔咿哈哈31 分钟前
【手撕 Spring】 -- Bean 的创建以及获取
java·后端·spring·面试·开源·github
码农小丘33 分钟前
了解springboot国际化用途以及使用
java·spring boot·spring
卡皮巴拉吖37 分钟前
【JavaEE初阶】多线程上部
java·jvm·java-ee
tian-ming38 分钟前
JavaWeb后端开发知识储备1
java·spring boot·nginx·spring·maven
spy47_39 分钟前
JavaEE 重要的API阅读
java·笔记·java-ee·api文档阅读
夏微凉.42 分钟前
【JavaEE进阶】Spring AOP 原理
java·spring boot·后端·spring·java-ee·maven
只因在人海中多看了你一眼44 分钟前
Java EE 技术基础知识体系梳理
java·java-ee