java get请求传参_Requests库(十)接口请求认证

4400c551f80cffac30d365b401fc98a7.png

由于微信公众号推送改为了信息流的形式,防止走丢,请给加个星标 ⭐,你就可以第一时间接收到本公众号的推送!

    Requests库分享系列:

             Requests库(一)

             Requests库(二)

             Requests库(三)如何获取接口传参参数

             Requests库(四)如何传递不一样的参数

             Requests库(五)接口返回状态码

             Requests库(六)接口返回响应头和请求Cookies

             Requests库(七)重定向和超时

             Requests(八)代理和会话对象

             Requests库(九)准备的请求和SSL 证书验证


    许多要求身份认证的web服务都接受 HTTP Basic Auth。这是最简单的一种身份认证,并且 Requests 对这种认证方式的支持是直接开箱即可用。

以 HTTP Basic Auth 发送请求非常简单:

from requests.auth import HTTPBasicAuthimport requestsreponese=requests.get('https://test.leizi.com/user',      auth=HTTPBasicAuth('user', 'pass'))

事实上,HTTP Basic Auth 如此常见,Requests 就提供了一种简写的使用方式:

requests.get('https://test.leizi.com/user',

            auth=('user', 'pass'))

    OAuth 1 认证

     Oauth 也是一种常见的 Web API 认证方式。 requests-oauthlib 库可以让 Requests 用户简单地创建 OAuth 认证的请求

import requestsfrom requests_oauthlib import OAuth1url = 'https://api.testleizi.com/'auth = OAuth1('key', 'YOUR_APP_SECRET',  'token', 'USER_OAUTH_TOKEN_SECRET')requests.get(url, auth=auth)

       在我们在实际的测试中呢,还会有在headers里面增加token校验是否是正常用户,还有请求内容需要key的,为了增加请求的可信性,在一些软件API中,还会遇到一些接口,除了正常的验证,还会在请求头增加一些特殊的验证,也有一些API的提供者需要token,还需要关键词,或者key的校验。为了安全性,开发者还增加了很多特殊的校验, 我们在正常的接口测试中需要校验即可。这样的接口,校验失败,不会有正常的返回值,甚至直接会被拉黑一段时间,都是开发者制定的规则。


如果觉得这篇文章还不错,来个【分享、点赞、在看】三连吧,让更多的人也看到~

36c9dd36bb1b71356ca91c9bef8d43b9.gif

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java的世界里,HttpClient 是一个功能强大的Http请求,然而接口非常复杂,设计上遵从正交性,简单的请求也需要写比较多的代码,更不要说隐藏在各种细节里面的高级用法了。Requests,  是一个模仿python requests 模块来设计的Http lib,拥有简单而灵活的API,在容易使用的同时,又能够满足各种高级定制的使用,可是说是当前最好用的Java Http Client Lib。 简单的请求示例:String url = ...; Response resp = Requests.get(url).text(); // post 和其他方法 resp = Requests.post(url).text(); resp = Requests.head(url).text(); //读取Http Response  int statusCode = resp.getStatusCode(); Headers headers = resp.getHeaders(); Cookies cookies = resp.getCookies(); String body = resp.getBody(); //response 返回其他类型 resp = Requests.get(url).text("UTF-8"); // get response as bytes Response resp1 = Requests.get(url).bytes(); // save response as file  Response resp2 = Requests.get(url).file("/path/to/save/file"); // url 数: Map map = new HashMap(); map.put("k1", "v1"); map.put("k2", "v2"); Response resp = Requests.get(url).param("key1", "value1").params(map)         //.params(new Parameter(...), new Parameter(...))         .text(); // 请求头 Response resp = Requests.get(url).header("key1", "value1").headers(map)         //.headers(new Header(...), new Header(...))         .text(); // 添加Cookie: Map cookies = new HashMap(); Response resp = Requests.get(url).cookie("key1", "value1").cookies(map)         //.cookies(new Cookie(...), new Cookie(...))         .text(); //  设置 userAgent Response resp = Requests.get(url).userAgent(userAgent).text(); // 增加请求数据(post, put, patch方法) // send form-encoded data. x-www-form-urlencoded header will be send automatically Response resp = Requests.post(url).data(map).text(); // send string data String str = ...; resp = Requests.post(url).data(str, "UTF-8").text(); // send from inputStream InputStream in = ... resp = Requests.post(url).data(in).text(); // multipart 请求, 用于文件上: Response resp = Requests.post(url).data(map).multiPart("ufile", "/path/to/file")         .multiPart(..., ...).text();请求设置://禁止自动重定向

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值