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:内容

  • 10
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值