zoukankan      html  css  js  c++  java
  • IDEA HTTP Client(史上最全)

    文章很长,建议收藏起来,慢慢读! 疯狂创客圈为小伙伴奉上以下珍贵的学习资源:


    史上最全 Java 面试题 21 专题

    史上最全 Java 面试题 21 专题 阿里、京东、美团、头条.... 随意挑、横着走!!!
    1.Java算法面试题(史上最强、持续更新、吐血推荐) https://www.cnblogs.com/crazymakercircle/p/14377410.html
    2.JVM面试题(史上最强、持续更新、吐血推荐) https://www.cnblogs.com/crazymakercircle/p/14365820.html
    3.Java基础面试题(史上最全、持续更新、吐血推荐) https://www.cnblogs.com/crazymakercircle/p/14366081.html
    4.死锁面试题(史上最强、持续更新) https://www.cnblogs.com/crazymakercircle/p/14323919.html
    5.多线程、线程池、内置锁 面试题 (史上最强、持续更新) https://www.cnblogs.com/crazymakercircle/p/13903850.html
    6.JUC并发包与容器类 - 面试题(史上最强、持续更新) https://www.cnblogs.com/crazymakercircle/p/13904029.html
    7.SpringBoot - 面试题(史上最强、持续更新) https://www.cnblogs.com/crazymakercircle/p/14365487.html
    8.Linux面试题(史上最全、持续更新、吐血推荐) https://www.cnblogs.com/crazymakercircle/p/14366893.html
    9.网络协议面试题(史上最全、持续更新、吐血推荐) https://www.cnblogs.com/crazymakercircle/p/14370335.html
    10、Zookeeper 面试题(史上最强、持续更新) https://www.cnblogs.com/crazymakercircle/p/13900183.html
    11、Mysql 面试题(史上最强、持续更新) https://www.cnblogs.com/crazymakercircle/p/13900186.html
    12、Redis 面试题 - 收藏版(史上最强、持续更新) https://www.cnblogs.com/crazymakercircle/p/13900198.html
    13、SpringCloud 面试题 - 收藏版(史上最强、持续更新) https://www.cnblogs.com/crazymakercircle/p/13900212.html
    14、Netty 面试题 (史上最强、持续更新) https://www.cnblogs.com/crazymakercircle/p/13903625.html
    15、消息队列、RabbitMQ、Kafka、RocketMQ面试题 (史上最全、持续更新) https://www.cnblogs.com/crazymakercircle/p/14367425.html
    16、分布式事务面试题 (史上最全、持续更新、吐血推荐) https://www.cnblogs.com/crazymakercircle/p/14375424.html
    17、设计模式面试题 (史上最全、持续更新、吐血推荐) https://www.cnblogs.com/crazymakercircle/p/14367101.html
    18、架构设计面试题 (史上最全、持续更新、吐血推荐) https://www.cnblogs.com/crazymakercircle/p/14367907.html
    19、Spring面试题 专题部分 https://www.cnblogs.com/crazymakercircle/p/14465630.html
    20、SpringMVC面试题 专题部分 https://www.cnblogs.com/crazymakercircle/p/14465630.html
    21、Tomcat面试题 专题部分 https://www.cnblogs.com/crazymakercircle/p/14465630.html

    IDEA HTTP Client 优点

    (1)脚本化 mock

    (2)免复制 token

    ..... 一大堆

    总之,IDEA HTTP Client调试工具真是太好用了

    与Postman 的PK

    以前用Postman的场景是这样的:

    img

    实际远远不止这几个文件夹来归类多个产品线的接口,Postman的功能非常强大,但是面对以下这些状况时,我觉得调试一个接口太麻烦了 (这里不讨论工具的好坏,工具是帮助我们提高效率的,每个人的需求也不一样,我只说明我个人遇到的一些情况,不喜请勿喷)

    • 查找配置多数要通过鼠标点来点去, 与习惯文本和快捷键操作的便捷方式违背
    • 调试别人接口要导入他们的一些数据,比较麻烦
    • 多个产品线环境变量查看不直观
    • 写完接口要来回切换应用进行测试,比如(IDEA <——> Postman)
    • 快速定位接口比较麻烦
    • ......

    IntelliJ IDEA 的 HTTP Client 工具刚好能解决上面提到的一些问题,

    Http Client 验处之旅

    官方的演示小动图:

    img

    对于企业版, HTTP Client 是 IDEA 默认安装,并且启用的插件,具体如下:

    看起来: 宝贝就在我们电脑里,只是没有发现!

    在这里插入图片描述

    如果看不明白,那么, 首先来验一下处:

    点击菜单:ToolsHTTP ClientTest RESTful Web Service

    在这里插入图片描述

    接下来进入下面的界面:

    在这里插入图片描述

    填好 ip,端口, 路径,点击执行,可以看到结果

    在这里插入图片描述

    是不是解决了经常idea和postman切换的问题,postman 就可以扔掉了。

    然后,这仅仅是 Http Client 组件使用的开始!!!!!!

    !!!!!!

    上图的根据详细的说明:

    在这里插入图片描述

    Rest 接口可执行文件

    看到标题了吗? 没有错,就是使用一个.http后缀(或.rest后缀)的文本文件,将可执行的Rest 接口和参数,统一管理起来, 组成一个Rest 接口可执行文件

    Http Client 组件的牛逼之处,就是这个 :Rest 接口可执行文件

    方式1: 通过工具按钮创建

    在这里插入图片描述

    默认会创建一个名为 rest-api.http 的文件,该文件被存储在 用户目录的 Scratches 文件夹下。

    接下来就可以改rest-api.http 的文件中执行 Rest 接口, 效果如下:

    在这里插入图片描述

    方式2:直接创建 HTTP request 文件

    • 史上最为简单的创建方式:

    通过菜单操作 File—New—HTTP Request

    在这里插入图片描述

    所文件存放在我们指定的目录下,就和我们平时创建class/package是一样一样滴

    • 史上最为直接的创建方式:

    直接创建一个扩展名为 .http 或者 .rest 的普通文件,over

    在这里插入图片描述

    HTTP request 文件的最大优势:

    它可以作为项目文件,通过 Git 提交到仓库,大家共享文件,共同维护接口请求数据,自然就不会出现调试别人接口还要导入他人数据的情况啦

    总之,就是方便 测试用例、测试参数、测试数据的 共享,明白了吗?

    Rest 接口可执行文件的接口语法

    请求的语法基本上和 http 协议内容是一致的,结构如下

    ### 使用三个 # 来分隔多个请求
    
    GET/POST 请求地址(可拼接查询参数)
    请求头键值对
    
    请求体
    
    > {% %}
    
    # 响应处理
    # 使用 >符号 打头,和 shell 很像,然后用 {% %} 括起来的脚本内容
    # 在脚本中可以使用 javascript 原生语法,这就很强大了
    # 脚本中有几个内置对象 client 表示当前客户端,response 表示响应结果
    

    发送请求:

    对于 .http 文件中的一些简单语法 :

    1. 注释 : // 或者 #
    2. 使用三个 # 号分割 request 请求 : ###
    3. web 的 basic 或者 digest 认证

    eg: 普通请求体

    POST http://example.com:8080/api/html/post
    Content-Type: application/json 
    
    { "key" : "value", "list": [1, 2, 3] }
    
    

    eg: 不添加执行日志

    // @no-log
    GET example.com/api
    

    eg: web 的 basic 或者 digest 认证

    // Basic authentication
    GET http://example.com
    Authorization: Basic username password
    
    ###
    
    // Digest authentication
    GET http://example.com
    Authorization: Digest username password
    
    

    处理响应:

    将脚本插入请求中

    > 开头,然后把脚本包装在 {%%} 里面。

    断言 client.assert

    GET https://example.com/status/200
    
    > {%
            client.test("Request executed successfully", function() {
            client.assert(response.status === 200, "Response status is not 200");
        });
    %}
    
    

    脚本日志 client.log

    client.log("this is log");
    
    

    在这里插入图片描述

    存储变量

    通过 client.global.set 存储全局变量,通过 client.global.get 获取变量。可以通过 client 对象在内存中存储数据,可以保留到 idea 关闭之前。

    除了 get 获取值外,还可以通过变量获取值,如图:

    在这里插入图片描述

    那么在一处存储了变量, 就可以在其他地方调用了,非常适合处理 token,就有点像浏览器登录了…

    辅助功能说明

    RestfulToolkit

    RestfulToolkit 同样是个插件,在插件市场搜索安装即可

    在这里插入图片描述

    安装了这个插件后,打开侧边栏,项目的所有接口信息都会展现在此处:

    在这里插入图片描述

    我常用的功能就是把指定接口生成的JSON数据拷贝到 HTTP request 文件中,免去手写的麻烦了,你说方便不?

    Live Template

    项目中请求内容各有不同,IDEA标准提供的GET POST 请求案例可能还不能满足我们的需求,这时我们就可以利用 Live Template 定制自己的模版,迅速生成request 内容,像这样:

    img

    JSON Viewer

    JSON Viewer是一款 Chrome浏览器插件,在浏览器 Omini-box 中输入 json-viewer + Tab, 粘贴json在此处,就可以对json数据进行格式化了

    img

    打开开发者工具,在Network下双击某个HTTP请求,会自动在 new tab下格式化返回的json数据,免去了粘贴数据然后格式化的烦恼

    常用示例

    配置环境信息

    这也是它比较强大的一方面,使用一个 json 来配置所有环境,只要在请求脚本目录下就可以读到,遵循约定大于配置的原则,文件名 http-client.env.json 表示普通变量可放的地方 http-client.private.env.json 表示密码等私有变量配置的地方,配置大致如下。在运行请求脚本的时候,idea 会提示你要选哪个环境

    {
      "local":{
        "baseUrl": "http://localhost:8083/",
        "checkCode": "http://localhost:8081/sanritools/company/token?env=dev",
      },
      "dev": {
        "baseUrl": "http://devhost:port/",
        "checkCode": "http://localhost:8081/sanritools/company/token?env=dev",
      },
      "sit": {
        "baseUrl": "http://sithost:port/",
        "checkCode": "http://localhost:8081/sanritools/company/token?env=sit",
      }
    }
    

    上面的文件,放在rest接口文件的同一个目录下。

    上面的文件, 定义了三个环境类型: sit, local,dev,执行的时候,需要选择 环境 的 类型:

    在这里插入图片描述

    登录 token 示例

    网上的示例基本上都是在说,用一个接口获取到 token ,然后保存到全局变量中,然后后面的接口就可以直接使用了,代码如下,但是本人试了无数次都没成功,再者,你们项目都没验证码的吗。

    ### 获取 token 值
    GET {{checkCode}}
    Content-Type: application/json
    
    > {%
    client.global.set("token", response.body.token);
    %}
    
    ### 获取素材列表
    POST {{baseUrl}}/media/list
    Content-Type: application/json
    Authorization: {{token}}
    
    {
      "pageNo": 1,
      "pageSize": 10
    }
    

    上面这个是有问题的,返回值 response.body 其它是个 json 字符串并非 javascript 对象,需要解析一下,前面也说了,这里可以使用原生 javascript 脚本,所以 JSON.parse(response.body).token 才能正确获取到 token ,

    第二个问题,我们现在这个 token 是存在 redis 的,所以我可以绕过验证码,另写一个接口去 redis 直接获取 token ,脚本最终如下

    ### 获取 token 值
    GET {{checkCode}}
    Content-Type: application/json
    
    > {%
    client.global.set("token", JSON.parse(response.body).token);
    %}
    
    ### 获取素材列表
    POST {{baseUrl}}/media/list
    Content-Type: application/json
    Authorization: {{token}}
    
    {
      "pageNo": 1,
      "pageSize": 10
    }
    

    文件传输实践

    前面说了,输入输出和 shell 中很像,所以这里输入一个文件使用 < 文件地址,随便找个 multipart/form-data 的数据格式查看一下,就知道文件怎么传了,其实在示例中也有,如下面脚本所示,它使用一个 boundary 的 key 绑定当前所要提交多个 part 的数据,每个 part 可以是不同的数据格式 ;

    ### 测试发送文件信息(文件元数据信息查询)
    POST {{baseUrl}}/media/upload/fileMetaData
    Content-Type: multipart/form-data; boundary=WebAppBoundary
    Authorization: {{token}}
    
    --WebAppBoundary
    Content-Disposition: form-data; name="fileSize"
    Content-Type: application/json
    
    1024
    --WebAppBoundary
    Content-Disposition: form-data; name="md5"
    Content-Type: application/json
    
    sdafasdfasfd
    --WebAppBoundary
    Content-Disposition: form-data; name="partFile"; filename="zhongwenbuxin.avi"
    Content-Type: application/octet-stream
    
    < C:Users91795960Videos/V0106_1024KB.avi
    --WebAppBoundary--
    

    对于返回信息乱码我没有碰到,也没有设置网上说的消息头和启动配置,返回消息是正常编码的;我只碰到了上传上去的文件名是乱码的,怎么设置都不生效,没找到解决办法,但自测的话,取个英文名也没关系,有哪位大神解决了可以告诉我一下。

    关于其它断言的使用,和日志的使用可以找其它的博客,这里列一篇以供参考

  • 相关阅读:
    POJ 1166 The Clocks 高斯消元 + exgcd(纯属瞎搞)
    防止登录页面出如今frame中
    android--显式跳转和隐式跳转的差别使用方法
    卫星照片
    poj 2586 Y2K Accounting Bug (贪心)
    【转】关于Python脚本开头两行的:#!/usr/bin/python和# -*- coding: utf-8 -*-的作用 – 指定文件编码类型
    【转】在Eclipse中使用PyDev进行Python开发
    【转】eclipse + Pydev 配置Python开发环境
    【转】Python自动化测试 (一) Eclipse+Pydev 搭建开发环境
    【转】Eclipse的启动问题【an error has occurred see the log file】
  • 原文地址:https://www.cnblogs.com/crazymakercircle/p/14317222.html
Copyright © 2011-2022 走看看