11.OkHttp之java网络编程

简介: 1.TCP/IP协议家族HTTP,FTP,DNS,TCP,UDP,IPOSI七层模型:应用层,表示层,会话层,传输层,网络层,数据链路层,物理层五层协议: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

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

相关文章
|
3月前
|
存储 人工智能 Java
java之通过Http下载文件
本文介绍了使用Java实现通过文件链接下载文件到本地的方法,主要涉及URL、HttpURLConnection及输入输出流的操作。
198 0
|
7月前
|
XML JavaScript Android开发
【Android】网络技术知识总结之WebView,HttpURLConnection,OKHttp,XML的pull解析方式
本文总结了Android中几种常用的网络技术,包括WebView、HttpURLConnection、OKHttp和XML的Pull解析方式。每种技术都有其独特的特点和适用场景。理解并熟练运用这些技术,可以帮助开发者构建高效、可靠的网络应用程序。通过示例代码和详细解释,本文为开发者提供了实用的参考和指导。
184 15
|
7月前
|
存储 网络协议 安全
Java网络编程,多线程,IO流综合小项目一一ChatBoxes
**项目介绍**:本项目实现了一个基于TCP协议的C/S架构控制台聊天室,支持局域网内多客户端同时聊天。用户需注册并登录,用户名唯一,密码格式为字母开头加纯数字。登录后可实时聊天,服务端负责验证用户信息并转发消息。 **项目亮点**: - **C/S架构**:客户端与服务端通过TCP连接通信。 - **多线程**:采用多线程处理多个客户端的并发请求,确保实时交互。 - **IO流**:使用BufferedReader和BufferedWriter进行数据传输,确保高效稳定的通信。 - **线程安全**:通过同步代码块和锁机制保证共享数据的安全性。
254 23
|
8月前
|
缓存 网络协议 Java
JAVA网络IO之NIO/BIO
本文介绍了Java网络编程的基础与历史演进,重点阐述了IO和Socket的概念。Java的IO分为设备和接口两部分,通过流、字节、字符等方式实现与外部的交互。
239 0
|
8月前
|
安全 网络协议 Java
Java网络编程封装
Java网络编程封装原理旨在隐藏底层通信细节,提供简洁、安全的高层接口。通过简化开发、提高安全性和增强可维护性,封装使开发者能更高效地进行网络应用开发。常见的封装层次包括套接字层(如Socket和ServerSocket类),以及更高层次的HTTP请求封装(如RestTemplate)。示例代码展示了如何使用RestTemplate简化HTTP请求的发送与处理,确保代码清晰易维护。
|
10月前
|
存储 监控 安全
单位网络监控软件:Java 技术驱动的高效网络监管体系构建
在数字化办公时代,构建基于Java技术的单位网络监控软件至关重要。该软件能精准监管单位网络活动,保障信息安全,提升工作效率。通过网络流量监测、访问控制及连接状态监控等模块,实现高效网络监管,确保网络稳定、安全、高效运行。
214 11
|
10月前
|
JSON Java 数据格式
java操作http请求针对不同提交方式(application/json和application/x-www-form-urlencoded)
java操作http请求针对不同提交方式(application/json和application/x-www-form-urlencoded)
219 25
java操作http请求针对不同提交方式(application/json和application/x-www-form-urlencoded)
|
11月前
|
数据采集 Java API
java怎么设置代理ip:简单步骤,实现高效网络请求
本文介绍了在Java中设置代理IP的方法,包括使用系统属性设置HTTP和HTTPS代理、在URL连接中设置代理、设置身份验证代理,以及使用第三方库如Apache HttpClient进行更复杂的代理配置。这些方法有助于提高网络请求的安全性和灵活性。
452 0
|
11月前
|
网络协议 Java 物联网
Java网络编程知识点
Java网络编程知识点
143 13
|
11月前
|
安全 Java API
深入探索Java网络编程中的HttpURLConnection:从基础到进阶
本文介绍了Java网络编程中HttpURLConnection的高级特性,包括灵活使用不同HTTP方法、处理重定向、管理Cookie、优化安全性以及处理大文件上传和下载。通过解答五个常见问题,帮助开发者提升网络编程的效率和安全性。
475 9