11.OkHttp之java网络编程

简介: 1.TCP/IP协议家族 HTTP,FTP,DNS,TCP,UDP,IP OSI七层模型:应用层,表示层,会话层,传输层,网络层,数据链路层,物理层 五层协议: TCP三次握手(建立连接)和四次挥手(断开连接) HTTP请求:以报文形式通信 客户端请求...
+关注继续查看

1.TCP/IP协议家族

HTTP,FTP,DNS,TCP,UDP,IP
OSI七层模型:应用层,表示层,会话层,传输层,网络层,数据链路层,物理层
五层协议:
TCP三次握手(建立连接)和四次挥手(断开连接)

HTTP请求:以报文形式通信

客户端请求Request:请求报文=请求头+空行+请求数据
Accept:客户端可以处理的数据格式
Cookie:服务端发送给客户端的cookie

服务端响应Response:响应报文=响应头+空行+响应数据
Content-Type:响应返回的类型(text/html;charset=utf-8)
Set-Cookie:服务端给我们的cookie,要保存起来下次带过去

2.接口测试

搭建服务器:
1.下载Eclipse+Tomcat

Eclipse Version: Luna Service Release 2 (4.4.2)
Tomcat 7.0

2.配置Tomcat


img_e1e297ba2a96dc74ddaaae0c6d4e1430.png
配置tomcat.png

可能会存在的错误

Could not load the Tomcat server configuration at \Servers\Tomcat v5.5 
Server at localhost-config. The configuration may be corrupt or incomplete.
img_8479e3c7d57617b586573f79cdf4a091.png
tomcat配置.png

其实主要是路径问题。解决方法就是将原来的server删掉,在添加一个server,设置server runtime ,tomcat安装目录设对

3.新建一个web工程
右键->new project选择web工程


img_71e80ca638c50fa6c4520f282f1d9a72.png
新建web工程.png

4.将工程发布到tomcat,Add之后,start或者restart tomcat


img_f795a4ad8ff43447d383a940a86a8610.png
部署项目到服务器.png

5.用浏览器测试项目工程
在web工程的WebContent目录下创建index.html

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
Hello OkHttp!
</body>
</html>

在浏览器中输入http://192.168.1.107:8080/OkHttpServer,如果浏览器打印出Hello OkHttp!则证明成功
6.创建测试接口

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * 为什么eclipse不识别HttpServlet,因为没有servlet架包,要在项目中导入这个架包。
 * 工程上右键,选择properties,然后选择java build path,library选项卡,add external jars,
 * 在tomcat的lib目录下找到servlet-api.jar,加载进来就可以了
 * @author renzhenming
 */
@WebServlet("/TestServlet")//TestServlet前边这里如果不加"/"服务器启动不了(start failed)
public class TestServlet extends HttpServlet{

    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        doPost(req, resp);
    }
    
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        //super.doPost(req, resp);
        PrintWriter writer = resp.getWriter();
        writer.write("server data is coming");
        writer.flush();
        writer.close();
    }
}

这时候重新执行上一步骤,如果打印出server data is coming则证明测试接口成功,我们来详细看一下当这个请求发出时,两端的交互情况。在浏览器输入http://localhost:8080/OkHttpServer/TestServlet,右键

-->查看元素-->选择网络,此时我们回车浏览器会发送一次请求到服务端,也就是我们的本地服务器,看看此时网络中显示的,这些字段就不一一解释了,可以自己百度


img_1ab1356867dc90f67160e5d4841d7a87.png
网络请求头响应头.png

我们切换到cookie,可以看到此请求无cookie,那么cookie是什么,如果一个请求有cookie会怎样显示,这是接下来要说的内容

3.Cookie

cookie是存放在客户端的信息,来自服务器,当客户端发送请求到服务器时,会携带cookie过去,如果用户离开网站,cookie会在一定时间内过期(相对危险)

Session是存放在服务器上面的客户端的临时信息,用户离开网站会被清除(相对安全,但是会耗费资源)

Token(令牌):用户身份验证,有点类似Cookie,相对来说更安全,一般流程:
1)客户端向服务端申请token
2)服务端收到请求,验证用户信息,签发一个token给客户端,自己保存token
3)客户端收到token会保存起来,每次请求带上token
4)服务器收到其他请求,会去验证客户端token,成功返回数据

创建一个用户登录servlet,模拟登录过程,当等成功之后,设置cookie返回给客户端,给cookie设置过期时间

import javax.servlet.annotation.WebServlet;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.alibaba.fastjson.JSON;
import bean.ResponseEntity;
import bean.UserInfoEntity;

@WebServlet("/LoginServlet")
public class LoginServlet extends BaseJsonServlet{
    private static final long serialVersionUID = 1L;
 
    @Override
    protected ResponseEntity onHandle(HttpServletRequest req,
            HttpServletResponse resp) throws Exception {            
        ResponseEntity entity = new ResponseEntity();
        entity.code = "0022";
        entity.msg = "用户名或密码错误";
        
        String userName = req.getParameter("userName");
        if ("rzm".equals(userName)) {
            entity.code = "0000";
            entity.msg = "登录成功";
            
            UserInfoEntity usEntity = new UserInfoEntity();
            usEntity.userName = userName;
            usEntity.userSex = "男";
            
            entity.data = JSON.toJSONString(usEntity);
            Cookie cookie = new Cookie("userName", "rzm");
            //设置cookie过期时间为一小时
            cookie.setMaxAge(60*60);
            resp.addCookie(cookie);
        }
        return entity;
    }
}

重新部署服务器,在浏览器中请求登录

http://localhost:8080/OkHttpServer/LoginServlet?userName=rzm

注意,这样设置的话,登录成功的提示会是乱码,我们需要设置content-type给响应头,这样就可以正常显示中文了

resp.setContentType("text/html;charset=utf-8");

我们打开网页元素,看看此时的请求头和响应头有什么变化,第一次登录后服务器会返回一个cookie到客户端,此时由于本地没有cookie,所以请求头中不含有cookie,当第一次请求之后再次请求会携带cookie到服务器,前提是这个cookie没有过期,如果过期则不携带


img_e768632bafa59e59067bb55c5b42b6b6.png
cookie.png
模拟cookie过期的情况

创建一个用户评论servlet,当cookie存在且未过期时,评论成功,如果不存在或过期,提示用户未登录

import javax.servlet.annotation.WebServlet;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import bean.ResponseEntity;

@WebServlet("/UserCommentServlet")
public class UserCommentServlet extends BaseJsonServlet{
    private static final long serialVersionUID = 1L;

    @Override
    protected ResponseEntity onHandle(HttpServletRequest req,
            HttpServletResponse resp) throws Exception {
        //判断该用户有没有登录,没有或cookie过期都不让评论
        ResponseEntity entity = new ResponseEntity();
        entity.code = "0033";
        entity.msg = "评论失败,用户未登录";
        Cookie cookies[] = req.getCookies();
        if (cookies != null) {
            for(Cookie cookie:cookies){
                String userName = cookie.getName();
                if (userName != null) {
                    entity.code = "0000";
                    entity.msg = "评论成功";
                }
            }
        }       
        return entity;
    }
}

当用户登录之后由于本地已经保存了cookie,所以当调用评论接口的时候会检查cookie是否过期(过期则为null),如果过期则需要重新登录,我们把登录servlet中cookie过期的时间设置为10秒,登录之后10秒内调用评论接口

http://localhost:8080/OkHttpServer/UserCommentServlet

会告诉我们评论成功,但是如果超过十秒,那么就会返回用户未登录的提示

相关文章
|
4天前
|
前端开发 Java
java在过滤器中为http请求加请求头header
现在有一个需求场景是,每一个请求我都需要在请求头里面加上token这个请求头,作为一种校验机制,传统的接口可以通过设置一个全局的变量,然后通过页面携带过来(大概就是先将我们的token放在session中,写一个服务用来获取session中的token,然后主页面用ajax调用接口,将token放在隐藏域中,然后将请求头放进来,用ajax方法,这里不想洗说了),但是有一种情况是通过页面传递的并不一定都会适用所有接口,比如上传和下载的接口有时候头里面就没有token参数,可能是上传和下载是用表单提交的 这个时候如何将请求头通过后台的方法加进来? 想到用过滤器,用后台方法强制加入请求头。
14 0
|
2月前
|
SQL Java 数据处理
Java中的HttpServletRequest:解析与处理HTTP请求
在现代的Java Web应用开发中,与客户端的数据交互是至关重要的一部分。Spring框架中的`HttpServletRequest`对象为我们提供了处理和解析HTTP请求的能力。本文将引导您深入了解`HttpServletRequest`对象,探讨其特点、用法、实现方式以及在实际应用中的优势。
|
2月前
|
JSON 自然语言处理 Java
Java中的HttpServletResponse:构建定制化的HTTP响应
在现代的Java Web应用开发中,与客户端的数据交互不仅限于请求,同样重要的是如何构建并发送适当的HTTP响应。在Spring框架中,`HttpServletResponse` 对象为我们提供了处理和定制HTTP响应的能力。本文将引导您深入了解`HttpServletResponse`对象,探讨其特点、用法、实现方式以及在实际应用中的优势。
|
2月前
|
Java
Java HTTP请求 如何获取并解析返回的HTML内容
在Java开发中,经常会遇到需要获取网页内容的情况。而HTTP请求是实现这一目标的常用方法之一。本文将介绍如何使用Java进行HTTP请求,并解析返回的HTML内容。
101 0
|
2月前
|
Java API Apache
Java HTTP请求封装的方法及实现
在Java开发中,我们经常需要与服务器进行数据交互,发送HTTP请求是其中常见的一种方式。为了简化开发过程,我们可以封装HTTP请求的方法,让调用者只需要关注业务逻辑而不用关心底层的细节实现。本文将介绍一种基于Java的HTTP请求封装方法及其实现。
91 2
|
2月前
|
Java
Java HTTP多线程下载实现方法
在如今互联网高速发展的时代,对于下载来说,速度是一个非常重要的因素。而多线程下载是一种提高下载速度的常见方法。本文将介绍如何使用Java编程实现HTTP多线程下载功能。
39 0
|
2月前
|
Java
Java Web应用开发案例|用过滤器解决HTTP请求导致的乱码问题
在Web应用开发中经常会遇到乱码问题,使用过滤器解决HTTP 请求导致的乱码问题,是十分有效的解决方案。
51 0
Java Web应用开发案例|用过滤器解决HTTP请求导致的乱码问题
|
3月前
|
Java
JAVA Http的Post请求传参
JAVA Http的Post请求传参
68 0
|
4月前
|
缓存 Java
Java中HTTP响应状态码
Java中HTTP响应状态码
|
4月前
|
JSON 网络协议 Java
java发送Http请求
java发送Http请求
相关产品
云迁移中心
推荐文章
更多