95 lines
1.6 KiB
Markdown
95 lines
1.6 KiB
Markdown
|
||
## 简介
|
||
|
||
一般来讲,对于RESTful API都会有认证(Authentication)和授权(Authorization)过程,保证API的安全性。
|
||
|
||
采用TOKEN认证,这种方式也是再HTTP头中,使用Authorization: Bearer <token>,使用最广泛的TOKEN是JWT,通过签名过的TOKEN。
|
||
|
||
基于Shiro+JWT可实现Token认证方式
|
||
|
||
## 测试
|
||
|
||
启动应用后
|
||
|
||
1. 先访问登录接口/login
|
||
|
||
*URL*
|
||
|
||
```
|
||
POST http://localhost:9095/login
|
||
```
|
||
|
||
*Header参数*
|
||
|
||
```
|
||
Content-Type: application/json
|
||
```
|
||
|
||
*Body参数*
|
||
|
||
``` json
|
||
{
|
||
"username": "admin",
|
||
"password": "12345678",
|
||
"appid": "111",
|
||
"imei": "imei"
|
||
}
|
||
```
|
||
|
||
返回值:
|
||
|
||
``` json
|
||
{
|
||
"success": true,
|
||
"msg": "Login success",
|
||
"data": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJhcHBpZCI6IjExMSIsImltZWkiOiJpbWVpIiwiZXhwIjoxNTM2NDg3NTM1LCJ1c2VybmFtZSI6ImFkbWluIn0.uat7rvVLwC7bcM-jRs329RWdHIFC6P-YN7YdJrdRUHE"
|
||
}
|
||
```
|
||
|
||
2. 使用token再去访问接口
|
||
|
||
上面的"data"对应的一长串字符串就是返回的token值
|
||
|
||
*URL*
|
||
|
||
```
|
||
GET http://localhost:9095/api/v1/join?imei=imei
|
||
```
|
||
|
||
*Header参数*
|
||
|
||
```
|
||
Content-Type: application/json
|
||
Authorization: 'Bearer ' + token
|
||
```
|
||
|
||
*Body参数*
|
||
|
||
``` json
|
||
{
|
||
"username": "admin",
|
||
"password": "12345678",
|
||
"appid": "111",
|
||
"imei": "imei"
|
||
}
|
||
```
|
||
|
||
返回值:
|
||
|
||
``` json
|
||
{
|
||
"success": true,
|
||
"msg": "Login success",
|
||
"data": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJhcHBpZCI6IjExMSIsImltZWkiOiJpbWVpIiwiZXhwIjoxNTM2NDg3NTM1LCJ1c2VybmFtZSI6ImFkbWluIn0.uat7rvVLwC7bcM-jRs329RWdHIFC6P-YN7YdJrdRUHE"
|
||
}
|
||
```
|
||
|
||
|
||
## 许可证
|
||
|
||
Copyright (c) 2018 Xiong Neng
|
||
|
||
基于 MIT 协议发布: <http://www.opensource.org/licenses/MIT>
|
||
|
||
|