http介绍:http是一套规范,一种网络数据交互的标准协议,不同的语言,不同的数据想要实现合理的数据交互(例如:浏览器和服务器数据交互),就得按照他所规定的协议来,这样就会形成标准的(大家都认识的)数据交互。

http交互流程:

  1.客户端和服务器建立起连接通道。

  2.客户端发送请求给服务器。

  3.服务器处理请求后将结果响应给客户端。

  4.客户端和服务器的连接通道关闭。http1.1会等待一段时间如果没有请求进来就会关闭。

特点:

  1.数据结构:他是以键值对的形式描述数据结构的。

  2.无连接:一次请求一次响应,当本次请求得到响应时即本次数据交互结束(客户端和服务器断开连接)。在http1.1中请求处理完成响应后,客户端和服务器不会立即断开连接而是在等待一定时间后再断开,如果等待期间有请求过来那么等待时间会重新开始(延长)。

  3.无状态:第一次请求处理完成后,要发送第二次请求,但即使两次请求用的是相同的数据,在http中也是没有任何关系的,所以二次请求任然需要重复第一次的流程,http他是没有记忆功能的,所以哪怕两次请求一模一样,各自的请求还是要发送全部的请求数据,这就是无状态。

  4.http是基于TCP协议发送数据的,所谓TCP大概意思为:即两端连通以后再进行数据请求和数据响应。UDP:即连接和请求一起发送过去,不会等到双方连接通畅之后再进行,所以UDP协议不会保证数据一定发送到另一端,但效率比TCP要快。

http请求格式:

  1.请求头内容: 请求方式(get、post...)  请求地址(https://i.cnblogs.com/EditPosts.aspx?opt=1) http协议(1.0/1.1)

  2.请求行、消息报头:这里面规范了服务器需要额外信息,一般浏览器会自动封装,如:能解析的数据格式等,客户端需要的Cookie数据。

  3.空行

  4.请求数据

在实际请求中浏览器为了方便展示观看:会将上面请求格式中的内容给分开展示,像get请求会将请求数据带到请求地址后面。

http响应格式:

  1.响应行:http版本 状态码 状态消息

  2.响应头:消息报头:服务器和浏览器之间的额外数据,例如:本次响应的消息类型...等等。

  3.空行

  4.响应实体:具体响应的数据。

额外解释:

  1.消息报头:消息报头中的信息和请求头响应头中的信息,这些信息中主要说明本次数据交互所采的各个属性:例如本次数据的格式:xml/json...这些数据都是服务器和浏览器自动处理的不需要开发者关心,开发者只管将自己需要的数据添加进去即可:例如Cookie,服务器中对这些常用配置已经做了处理,而浏览器的各个厂商也对浏览器做了处理,所以程序员只需要关心请求数据和响应数据即可。

上面对http的大概介绍就这么多,下面主要介绍Servlet:

客户端向浏览器请求的流程:前端网页源码 -> 浏览器请求封装(主要是消息报头以及版本信息等) -> 服务器处理 -> 根据请求的不同(get post...) -> 分配到后端相应的接口逻辑中

Servlet的请求流程: 网页请求 -> 服务器收到请求后寻找对应的Servlet -> 然后将请求信息以及要响应的信息封装成request response对象传入响应的Servlet对象的Service方法中去调用此方法。

好了,说了这么多,开始上代码:

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
     <!--配置Servlet  -->
         <!--配置servlet类路径  -->
         <servlet>
             <servlet-name>my</servlet-name>
             <servlet-class>cn.mr.li.MyServlet</servlet-class>
         </servlet>
         <!--配置访问方式  -->
         <servlet-mapping>
             <servlet-name>my</servlet-name>
             <url-pattern>/my</url-pattern>
         </servlet-mapping>
</web-app>

servlet:

1.request作用域:一次请求一个数据作用域仅限本次请求所用到逻辑范围,但通过请求转发的方式可实现多个Servlet之间数据共享,一次请求,一次响应。

2.Cookie:客户端数据存储技术,并用于请求自动携带,至于带什么,请求哪些路径时带,生命周期等都是服务器设置的。然后由response对象通知客户端去执行具体的操作。

3.重定向:response.sendRedirfect(uri),只能防止重复刷新重复请求,但是不能数据共享,如果将所有数据都放在Cookie中将不安全,而且也无法验证当前Cookie就是此人。

4.session作用域:同一个对象请求多次数据共享。

5.sessionContext作用域:不同对象请求多次数据共享。

6.tomcat服务器下的web.xml文件中的全局变量将是所有服务器都共享的数据范围。

package cn.mr.li;

import java.io.IOException;

import javax.servlet.ServletConfig;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

public class MyServlet extends HttpServlet{

    private static final long serialVersionUID = 8834328433966095720L;

    @Override
    public void service(HttpServletRequest request, HttpServletResponse response ) throws ServletException, IOException {
        //编码,从iso8859-1编码后再转换成utf-8,uname字符串是请求的变量名
        String uname = new String(request.getParameter("uname").getBytes("iso8859-1"), "utf-8");
        //新建Cookie:将Cookie放到客户端的消息报头中
        Cookie cookie = new Cookie("id", uname);
        //此Cookie的最大生命周期,设置了客户端就会存到他自己的硬盘中,生命周期一到就会删除,默认有效期期是本次会话,会话一旦关闭则失效
        cookie.setMaxAge(24 * 3600);
        //往响应中添加Cookie,这样才会通知到客户端下次请求会带上本次存放的数据
        response.addCookie(cookie);
        //设置访问哪些路径、目录先时可以带cookie
        cookie.setPath("/端口号后的链接");
        
        /** 请求转发 一次访问 后端逻辑跑多个Servlet, 记得要加return*/
        //给Requset添加自定义属性
        request.setAttribute("key", "value:给下个流程的参数,此值是本流程产生的,这里是可以放一个Object对象的");
        //演示请求转发,意思是本Servlet处理完了本此Servlet管理的业务,将自动转向下一个Servlet处理后序流程(原子性),
        //但如果客户端网页一刷新就重新开始一次请求,如果是转钱业务用请求转发就完犊子了,他会转了因为页面刷新再次请求又会转,所以还是要看具体业务的。
        request.getRequestDispatcher("其他sevlet的别名url-pattern标签中的").forward(request, response);
        
        /** 重定向 多次访问 头端通知前端,此时前端会自动访问多个Servlet, 
         * 但是request中如果有属性值得话request.setAttribute,就无法在下次请求中带了,因为是不同的requset对象,不过session可以解决*/
        //因为请求转发用户一但刷新页面将会不安全,会重复跑流程,所以有了重定向,
        //相当于本次Servlet处理业务完成后直接通知客户端访问下个Servlet此时客户端会自动访问下个Servlet
        response.sendRedirect("直接传下次要访问的uri");
        
        /** Session 一个request在服务器上的对象,一个很全的对象,例如:某个用户访问了服务器:服务器将此用户的User信息
         * 查询出来放到Session中,那么此用户下次请求Servlet是甚至只传很少的参数即可  */
        //创建Session此方法会从Requset的Cookie中取出他自己的SessionId,如果没有或者没取到则会创建一个新的Session对象
        //并且将SessionId重新放到Cookie中,默认SessionId的生命周期30分钟,一旦断开连接则会销毁
        HttpSession session = request.getSession();//此session是用请求对象的sessionid取出来的。
        //给session对象赋值属性值
        session.setAttribute("key", "Object类型");
        //设置session的生命周期,时间单位:秒
        session.setMaxInactiveInterval(123);
        //强制让session过期
        session.invalidate();
        
        /** ServletContext对象:此对象的数据整个服务器共享,也就是说存放在此对象中的数据整个服务器上都能拿到,前提是要能得到此对象  */
        ServletContext sc1 = this.getServletContext();//方式1
        sc1 = this.getServletConfig().getServletContext();//方式2
        sc1 = request.getServletContext();//方式3
        //同样赋值
        sc1.setAttribute("key", "Objcet");
        //获取全局配置web.xml
        sc1.getInitParameter("hahhahah");
        //获取全局配置的所有key名
        sc1.getInitParameterNames();
        
        /**ServletConfig专门读取某个Servlet下的配置的,有次方法后所有的key都将不需要硬编码*/
        ServletConfig config = this.getServletConfig();
        //读取Servlet专属变量名
        String value = config.getInitParameter("key");//web.xml init-param标签中
        
        
        //给浏览器打印文本
        response.getWriter().write("hello world!!!");
    }
//    @Override
//    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//        resp.getWriter().write("do get!!!");
//    }
//    
//    @Override
//    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//        resp.getWriter().write("do post!!!");
//    }
//    
//    @Override
//    protected void doPut(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//        resp.getWriter().write("do put!!!");
//    }
}

顺带提一下jsp:jsp的原理就是讲html文件中的所有代码全部读进Servlet中转为输出语句打印到控制台上,而其中的java代码,会读过来后执行响应的逻辑后再自己的位置打印到浏览器。

 

内容来源于网络如有侵权请私信删除
你还没有登录,请先登录注册
  • 还没有人评论,欢迎说说您的想法!