JavaEE(1):web后端开发环境搭建和创建一个Servlet项目

web后端(javaEE)程序需要运行在服务器的,这样前端才可以访问得到

 web后端开发:

服务器?

        解释1:服务器就是一款软件,可以向其发送请求,服务器会作出一个响应。可以在服务器中部署文件,让他人访问

        解释2:也可以把运行服务器软件的计算机也可以称为服务器

首先:

        要安装服务器软件

        1、安装Tomcat

        去官网下载:http://tomcat.apache.org

        2、安装JDK

        去官网下载:Java Downloads | Oracle

        

        配置两个环境变量

        第一种:PATH环境变量(bin目录)

        1.打开设置,找到系统里的系统信息,再点开高级系统设置

        

        

        2.再在第二个的系统变量中找到path并单击path后打开编辑

        

        3.然后点击新建将自己的jdk的路径目录(bin目录的上一级根路径)加到环境变量即可(一定要点应用按钮)

        

       第二种:JAVA_HOME环境变量(bin的根目录)

        1.还是按照上面步骤先找到环境变量

        2.在系统变量直接点击新建

        变量名就是:JAVA_HOME

        

        解压安装tomcat

 Tomcat的目录层次结构

        

        1.在bin目录中 双击 startup.bat文件启动Tomcat服务器

        2.在浏览器输入 http://localhost:端口号(初始值:8080)

           或http:127.0.0.1:端口号

           或局域网ip:端口号

        若出现此页面,安装完成!

其次:

       创建web后端项目

        1.创建javaWeb项目

        2.发布web应用到服务器

                发布web后端项目到tomcat中

                在idea中集成tomcat(修改代码后,会自动重新部署到tomcat中)

        Servlet是Server Applet的简称,意思为用Java编写的服务器端的程序. 它运行在web服务器中,web服务器负责Servlet和客户的通信以及调用 Servlet方法。

         javaEE程序(Servlet)的作用:

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

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

                3.根据处理结果,将结果响应给客户端

创建javaEE程序

        创建一个类 继承 HttpServlet,我们这个类就是一个javaEE程序

        在web.xml文件配置,向外提供一个访问地址,就可以在浏览器中访问,找到相应的javaEE程序

四个要重写方法:

        1.无参构造方法,默认是存在,初始化创建的对象

           只被调用一次(始终只创建了一个对象),在第一次访问servlet程序由服务器创建执行

        2.init() 初始化 在构造方法执行完成后,立即被调用执行,完成一些servlet程序的初始化(例如,读取配置文件中的参数) 只执行一次

        3.service() 用来接收前端请求,为前端提供服务的

           每次前端发送的请求,都会调用service(),多次调用

           HttpServletRequest req:表示请求对象,前端提交过来所有的数据,都由服务器封装在此对象中。 HttpServletResponse resp:表示响应对象,用来向前端响应数据

        4.destroy() 在服务器关闭时,如果我们的程序想要执行某些操作,就可以在destroy方法中实现

        web.xml文件配置:

       <servlet>元素用于注册Servlet,它包含有两个主要的子元素:<servlet-name>和<servlet-class>,分别用于设置Servlet的注册名称和 Servlet的完整类名。 一个<servlet-mapping>元素用于映射一个已注册的Servlet的一个对外访问路径,它包含有两个子元素:<servlet-name>和<url-pattern>,分别用于指定 Servlet的注册名称和Servlet的对外访问路径。

        url-pattern配置模式:”/”代表当前web应用的根目录

Web.xml文件为web应用的配置文件,它必须放在web应用目录WEB-INF目录下。

Web.xml文件用于对web应用下的web资源进行配置,服务器在启动时会读取web.xml文件中的内容。

servlet生命周期

        创建(无参构造方法):

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

        初始化:

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

        服务:

                每次请求调用service()

        销毁:

                服务关闭时,会销毁servlet对象

                并且在销毁servlet对象时,会自动调用destroy(),执行一些最终操作

前端向后端发送http请求

        超链接、提交表单 都是发送http请求

http请求包含三部分:

        请求行:包含http请求方式,请求资源名称,http版本

        请求头:包含主机地址,以及客户端的一些环境信息,以键值对的形式传递.

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

请求分为:

        get请求:传少量数据,获得大量数据

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

        post请求:用表单向后端携带大量数据的,不在地址中显示

Get方式与post方式的区别:

        Get方式主要是从服务器获取信息;POST方式主要是想服务器提交信息

        Get方式,在通过URL提交数据,数据在URL中可以看到;POST方式,数据放置在请求体中提交。

        GET方式提交的数据大小受限制一般1kb(不同浏览器也会有不同);而 POST方式则没有此限制。

过滤器:

        过滤器是javaEE规范中定义的一种技术,可以让请求到达目标servlet之前,先进入到过滤器中,在过滤器中统一进行一些拦截处理,当处理完成后,可以继续向后进行,到达目标servlet,如果配置了多个过滤器,也可以进入到下一个过滤器。

        作用:对服务器web资源进行拦截(权限控制,通过拦截资源进行权限控制,是否可以访问)

过滤器的使用场景:

        1.统一进行编码过滤

/*
    定义统一编码的过滤器
 */

public class EncodFilter implements Filter {
    String reqencod = "";
    String respencod = "";
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        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);
        //让请求离开当前过滤器,向后执行
        filterChain.doFilter(servletRequest, servletResponse);
    }
}

          在web.xml文件中配置注册统一编码过滤器

 <!--配置统一编码过滤器-->
    <filter>
        <filter-name>encodfilter</filter-name>
        <filter-class>com.ffyc.dormServer.filter.EncodFilter</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>encodfilter</filter-name>
        <url-pattern>/*</url-pattern><!--让所有的请求都进入到过滤器中-->
    </filter-mapping>

        2.权限验证

                后续说到token校验码则会用到过滤器,再去细说

        3.跨域过滤

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"));//"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);
    }
}

        在web.xml文件中配置注册跨域过滤器

<!--配置允许跨域过滤器-->
    <filter>
        <filter-name>corsfilter</filter-name>
        <filter-class>com.ffyc.dormServer.filter.CorsFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>corsfilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

过滤器用来实现通用的功能,减少代码冗余,提高可维护性

        一个过滤器可以配置给多个资源使用

        一个资源也可以配置多个过滤器,按照配置顺序调用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值