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代码,会读过来后执行响应的逻辑后再自己的位置打印到浏览器。
原文地址:https://www.cnblogs.com/li-yan-long/p/10699419.html