zoukankan      html  css  js  c++  java
  • Editor REST Client

    Editor REST Client

    制作一个http请求

    请求行

    GET https://example.com/comments/1 HTTP/1.1
    
    POST https://example.com/comments/1
    
    https://example.com/comments/1
    

    如果省略request方法,请求将被视为GET

    GET https://example.com/comments?page=2&pageSize=10
    

    有时在单个请求中可能有多个查询参数,将所有查询参数放在请求行中很难阅读和修改。所以我们允许你将查询参数传播到多行(一行一个查询参数),我们将在请求行开始后立即解析行,?并且&像

    GET https://example.com/comments
        ?page=2
        &pageSize=10
    

    请求头

    紧接在第一个空行的请求行之后的行被解析为请求标题。请提供标准field-name: field-value格式的标题,
    每行代表一个标题。默认情况下,如果未明确指定,则会在请求中REST Client Extension

    添加`User-Agent`带有值的标头`vscode-restclient`。
    您还可以在设置中更改默认值`rest-client.defaultHeaders`。以下是请求标头的示例:
        User-Agent: rest-client
        Accept-Language: en-GB,en-US;q=0.8,en;q=0.6,zh-CN;q=0.4
        Content-Type: application/json
    

    请求体

    如果你想提供请求主体,请添加请求行和请求头后,一个空行,之后它会被视为所有内容的请求体。以下是请求正文的示例:

    POST https://example.com/comments HTTP/1.1
    Content-Type: application/xml
    Authorization: token xxx
    
    <request>
        <name>sample</name>
        <time>Wed, 21 Oct 2015 18:27:50 GMT</time>
    </request>
    

    如果请求体内容很大,可以将请求体写在文件中,然后引用这个文件
    示例

    POST http://dev.avatarinternalapi.jd.com/alarm/alarm-info
    Content-Type: {{contentType}}
    
    < ./alarm.json
    

    变量

    自定义变量

     自定义变量包含 环境变量  文件变量  请求变量
    
    环境变量

    不同环境下可以切换使用不同的变量

    在哪定义:设置->工作区设置

    {"rest-client.environmentVariables": {
        "$shared": {  //共享变量
            "version": "v1"
        },
        "local": {   //本地变量
            "version": "v2",
            "host": "dev.avatarinternalapi.jd.com",
            "token": "test token"
        },
        "production": {
            "host": "example.com",
            "token": "product token"
        }
    }}
    

    production 中没有version时,调用production环境时,回去找$shared 中的version

    文件变量
    • 对于文件变量,定义遵循@variableName = variableValue占用完整行的语法。
    • 变量名称不得包含任何空格。至于变量值,它可以由任何字符组成,甚至允许空格(前导和尾随空格将被剥离)。
    • 如果你想保留一些像换行符这样的特殊字符,你可以使用反斜杠
    • 无论您在何处定义文件变量http文件,它们可以在整个文件的任何请求中引用
    @host = dev.avatarinternalapi.jd.com
    @contentType = application/json
    
    GET  http://{{host}}/alarm/email-info?pin=zhangkaixuan100,zhangkaixuan1002
    
    Content-Type: {{contentType}}
    
    请求变量

    求变量的定义语法就像单行注释一样,在所需的请求URL之前 # @name newname

    使用场景:当一个请求需要其他请求的值,作为请求的参数时

    请求变量引用语法如下{{requestName.(response|request).(body|headers).(JSONPath|XPath|Header Name)}}
    您有两个参考部分选择响应或请求:正文和标题。对于正文部分,它只适用于JSONXML响应,您可以使用JSONPathXPath
    来提取特定的属性或属性。例如,如果JSON响应返回body {"id": "mock"}
    则可以将JSONPath部分设置$.id为引用id

    示例:

    ###
    
    # @name createComment
    POST {{baseUrl}}/comments HTTP/1.1
    Content-Type: application/json
    
    ###
    
    # @name getCreatedComment
    
    GET {{baseUrl}}/comments/{{createComment.response.body.$.id}} HTTP/1.1
    
    Authorization: {{login.response.headers.X-AuthToken}}
    

    系统变量

    系统自带的一些变量,使用系统变量需要有 $符号

    • {{$guid}} 唯一识别号
    • {{$randomInt min max}} 返回一个minmax 之间的随机数
    • {{$timestamp [offset option]}}:添加UTC时间戳。
    • {{$timestamp number option}},例如3小时前{{$timestamp -3 h}};代表后天{{$timestamp 2 d}}

    更多系统变量用法请参考 官方文档

    系统设置

    可以用户设置中,覆盖系统设置

    示例: "editor.fontSize": 13, 将系统默认的字体大小改为13

    更多用户设置用法请参考 官方文档

    rest editor 和 postman对比

    安装和启动
    • postman 属于一个pc端的应用,需要下载和安装,每次使用需要启动应用
    • rest editor 属于一个插件,高版本的phpstorm自带,可以在phpstom中直接使用,无需单独启动新应用
    • 结论:在安装和启动上,rest editor 更加快捷
    操做使用
    • postman 有功能强大的操做界面,使用起来方便,支持全局变量的定义。对于一个http请求中所需的所有参数,几乎都可以在界面中定义。
    • rest editor 没有操做界面,需要定义一个.http后缀的文件,在文件中编写请求。一个http请求的所需参数,都需要手动编写,一般编辑器会有参数联想功能。
    • 结论: 在编写一个完整的http请求的过程中,postman显得更加方便一点;二者都可以保存编写的http请求
    学习成本
    • 结论: 相比而言rest editor 学习成本更高,应为是纯手动编写http请求,需要学习rest editorhttp请求的编写规则,并且需要熟练掌握http协议。
    团队协作
    • postman: 与他人共享编写过的的http请求需要付费
    • rest editor 可以将编写的文件同步到代码仓库,实现团队共享
    • 结论: rest editor 更甚一筹

    其他

    制作curl

    鼠标放置到请求上,邮件单击选择Copy Request As cURL

    curl --request POST --url http://dev.avatarinternalapi.jd.com/alarm/alarm-info --header 'content-type: application/json' --data '< ./alarm.json'
    

    快捷键的使用

    • Ctrl+Alt+L(Cmd+Alt+L对于macOS) 重新重新运行上一个请求
    • Ctrl+Alt+K(Cmd+Alt+K对于macOS) 停止请求
    • Ctrl+Alt+E(Cmd+Alt+E对于macOS) 选择一个环境

    更多快捷键用法请参考 官方文档

    保存响应

    保存完整的响应

    左上角保存的图表

    保存响应正文

    左上角保存正文图表

    生成原始的请求代码段

    选中一次请求的所有代码后 ->点击右键 -> 选择Generate Code Sinppet ->选择你想要的语言

    相关资料

    官方文档
    转载:https://segmentfault.com/a/1190000016300254

  • 相关阅读:
    RPD Volume 168 Issue 4 March 2016 评论1
    初步接触CERNVM
    java中重载与重写的区别
    第三节 java 函数
    第二节 java流程控制(循环结构)
    第二节 java流程控制(判断结构+选择结构)
    JAVA 对象引用,以及对象赋值
    Java学习笔记整理第一章 java基本数据类型、修饰符、运算符
    plantuml的使用
    力扣 第210题
  • 原文地址:https://www.cnblogs.com/LOVEYU/p/11457887.html
Copyright © 2011-2022 走看看