Compare commits
246 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 02674049d0 | |||
| f1714726f5 | |||
| a3108caccf | |||
| e134dd06b0 | |||
| 172ba7be55 | |||
| f9e3053ecc | |||
| 99c9ba2854 | |||
| 544ffd5372 | |||
| 522ebbfa7f | |||
| 497498dbf4 | |||
| 62cd7af619 | |||
| 3a3f69692c | |||
| c87015e34f | |||
| 96773dd92d | |||
| 644ef02264 | |||
| 4c205a9957 | |||
| ea70c5fc81 | |||
| 9ced525309 | |||
| 2de0ad5013 | |||
| 23b7bcf43d | |||
| 976b7d8b2b | |||
| 80132b69e7 | |||
| 95158654a9 | |||
| f2e609192a | |||
| 8c8f7a27a2 | |||
| 8283124c57 | |||
| 39b113b194 | |||
| e45ef2ec31 | |||
| d114368a0d | |||
| 0047cde50e | |||
| f2c1c0f8a6 | |||
| 21e23aadb9 | |||
| db3f7da181 | |||
| 004e5a180f | |||
| 50c31e5dea | |||
| 7d6049da67 | |||
| 9a24553acd | |||
| d75d91db0d | |||
| e1a4688ac0 | |||
| b1d3790ae1 | |||
| e5548b0173 | |||
| ebf39627dd | |||
| 74ee17b242 | |||
| b77de0bd0c | |||
| e55033f4f5 | |||
| 37b7784f89 | |||
| 7cdc719166 | |||
| 5073f82897 | |||
| 9971793f0c | |||
| 9fc3131640 | |||
| 3f4436bcb6 | |||
| 0678202baa | |||
| af8fda700b | |||
| 881a87ed95 | |||
| 4c8fdbae49 | |||
| e8db2dd282 | |||
| 90374762e4 | |||
| e5d44e91b8 | |||
| 41559fc954 | |||
| d354278e7d | |||
| c2d6661a76 | |||
| 5ee87760be | |||
| 94f6540338 | |||
| 7bc7a92efb | |||
| b5920872d5 | |||
| 0bdf881849 | |||
| 46f7c72744 | |||
| 4a662ba5cd | |||
| 040587d5b2 | |||
| c81411fd39 | |||
| 0e1b000bd8 | |||
| f9b30c735b | |||
| 0f42457d91 | |||
| fa75568996 | |||
| f44ceeeeeb | |||
| ec4c009ed8 | |||
| 03fbbe0d3a | |||
| e64e9def63 | |||
| 25f99f7560 | |||
| 0433f54564 | |||
| 423d9f45b6 | |||
| 7a9e6214de | |||
| 3753e3b9bc | |||
| bc3af96328 | |||
| b700902c04 | |||
| 2d0ae7cc27 | |||
| 3e4faa75fe | |||
| 6a36ad6af2 | |||
| 13514d6a92 | |||
| 6a479d9c1d | |||
| 2e64fb9693 | |||
| 0e8308e6c9 | |||
| 3933b3b7ee | |||
| a99b818810 | |||
| cd324cc7c1 | |||
| 3e890f2c2a | |||
| ba56f5ab5a | |||
| 132a7f4338 | |||
| c79b97a0d0 | |||
| 66df3ac027 | |||
| 11df93ad44 | |||
| e3f5f49ec8 | |||
| 23eb2cfcc8 | |||
| 30461e62f9 | |||
| dfbbd9ae0d | |||
| 05b7746f26 | |||
| 21422b02aa | |||
| 10e445e87c | |||
| d6cbcecaab | |||
| 050459e616 | |||
| 9fd2b9b919 | |||
| 2ff5570399 | |||
| 1bec384525 | |||
| 824c68356d | |||
| f5e3c225f6 | |||
| 0259669288 | |||
| edc9d1a3c3 | |||
| d886bc95a2 | |||
| 7aaf52e953 | |||
| e84bd7cdb5 | |||
| 28e19960f2 | |||
| dce2bd1e1e | |||
| bc30971482 | |||
| 9bd6d88049 | |||
| 442332be57 | |||
| d4bfa8e75f | |||
| fb90fbdcb8 | |||
| 5f6cb2954f | |||
| 906ae659a2 | |||
| cebfd99703 | |||
| 71b6080156 | |||
| 492ffdbbf8 | |||
| dc4093bdf3 | |||
| b71b081c96 | |||
| 6b00783cd9 | |||
| 2723f0dc3d | |||
| abbfb73337 | |||
| 960892eec3 | |||
| 4a6216f7d9 | |||
| ce689362ac | |||
| e39d1dd0f8 | |||
| f5f1b1ccc0 | |||
| d4104dd124 | |||
| c17e56865b | |||
| 8b55195225 | |||
| 0398698657 | |||
| e15ecbe91e | |||
| 9c332d6d16 | |||
| d645224071 | |||
| 272d1ac8a0 | |||
| 162a16820d | |||
| 2abef3dc64 | |||
| e9fa31bc0d | |||
| 753774b193 | |||
| b01ebcaf48 | |||
| 45e1195974 | |||
| 72bb1d826f | |||
| a85d9797a7 | |||
| 6354182335 | |||
| df11fcbd4c | |||
| 36d4f89595 | |||
| d787ba7346 | |||
| 2d52e010da | |||
| 8440b0606e | |||
| cb30ddfa2f | |||
| a1ceb9bc7e | |||
| 7df2c9af23 | |||
| f2c1c2f0ee | |||
| cc04c1b616 | |||
| e02fcf895f | |||
| d338e1bb98 | |||
| e11b8aff09 | |||
| 6defde8283 | |||
| 8b3bc42678 | |||
| 164e12de1f | |||
| 369388c11d | |||
| a1200b2510 | |||
| 6ea1d41211 | |||
| ddde4ef1f5 | |||
| 26884f7218 | |||
| 7f9c12d5bf | |||
| fbeb4c68ab | |||
| 179287f720 | |||
| 8a47735208 | |||
| 0feb859f68 | |||
| 441dda3970 | |||
| b564ce8a89 | |||
| 5e0065508a | |||
| cf6f42b586 | |||
| 89b5fe4543 | |||
| 6f313fa91a | |||
| 36bcebdd46 | |||
| 99b8680fd2 | |||
| 2717d9cf7a | |||
| 166ddffaf4 | |||
| 33385fd30a | |||
| 8e5a679129 | |||
| 5ab2e87157 | |||
| c34e226a54 | |||
| e4985c63f3 | |||
| e93ad07c5f | |||
| 4ca1f46722 | |||
| 571c3438e4 | |||
| 2497519ec1 | |||
| 278a435cdb | |||
| e75df92080 | |||
| 9e6a4c61b0 | |||
| d355699cc3 | |||
| 28466f8ab5 | |||
| c6bd5d9e5d | |||
| d0ae0f2c7a | |||
| 521a423e26 | |||
| 1f1d61fe4e | |||
| ec87ea145c | |||
| b1121ba545 | |||
| 41d0d01329 | |||
| 77603cf7db | |||
| 7be51f1d33 | |||
| e71af6b2e6 | |||
| 54779ab26a | |||
| be1e23e2ab | |||
| 739e7dfd39 | |||
| 58c8aa9010 | |||
| 93aae33f0a | |||
| 268a9b477b | |||
| adaf9d59cd | |||
| 7f0f1e17d2 | |||
| 65b2db32b5 | |||
| 9e79dd7cb3 | |||
| 30f29a49d1 | |||
| 129d1d57ed | |||
| 3da90736c4 | |||
| 05891e48e9 | |||
| 9ef19b1d54 | |||
| 2de19a3824 | |||
| bccf3279af | |||
| 6b4a8b78b1 | |||
| 5a94ff82c1 | |||
| 7b03751a8d | |||
| 823a43b1e2 | |||
| db6e88173a | |||
| c6481a681e | |||
| 1e1038fbd4 | |||
| 7cb0f8dbb6 | |||
| 469558bddc | |||
| d9952968d1 |
@@ -0,0 +1,12 @@
|
|||||||
|
# These are supported funding model platforms
|
||||||
|
|
||||||
|
github: # Replace with up to 4 GitHub Sponsors-enabled usernames e.g., [user1, user2]
|
||||||
|
patreon: # Replace with a single Patreon username
|
||||||
|
open_collective: # Replace with a single Open Collective username
|
||||||
|
ko_fi: # Replace with a single Ko-fi username
|
||||||
|
tidelift: # Replace with a single Tidelift platform-name/package-name e.g., npm/babel
|
||||||
|
community_bridge: # Replace with a single Community Bridge project-name e.g., cloud-foundry
|
||||||
|
liberapay: # Replace with a single Liberapay username
|
||||||
|
issuehunt: # Replace with a single IssueHunt username
|
||||||
|
otechie: # Replace with a single Otechie username
|
||||||
|
custom: ['https://justauth.wiki/sponsor.html']
|
||||||
@@ -0,0 +1,32 @@
|
|||||||
|
---
|
||||||
|
name: Bug report template
|
||||||
|
about: Please use this template for reporting suspected bugs.
|
||||||
|
title: 'bug:'
|
||||||
|
labels: 'bug'
|
||||||
|
assignees: ''
|
||||||
|
---
|
||||||
|
|
||||||
|
## Pre-submission checklist:
|
||||||
|
|
||||||
|
- [ ] I have searched the relevant information in the existing list of Issues.
|
||||||
|
- [ ] I have searched the developer documentation for that information: https://justauth.wiki
|
||||||
|
- [ ] I have read the relevant Q&A: https://justauth.wiki
|
||||||
|
|
||||||
|
## Issue description
|
||||||
|
|
||||||
|
## Environment
|
||||||
|
|
||||||
|
- JustAuth version(e.g. `1.15.1`):
|
||||||
|
|
||||||
|
### Minimal test code / Steps to reproduce the issue
|
||||||
|
1.
|
||||||
|
2.
|
||||||
|
3.
|
||||||
|
|
||||||
|
## What's the actual result? (including assertion message & call stack if applicable)
|
||||||
|
|
||||||
|
> Be sure to provide a complete and detailed exception stack.
|
||||||
|
|
||||||
|
|
||||||
|
## What's the expected result?
|
||||||
|
|
||||||
@@ -0,0 +1,15 @@
|
|||||||
|
---
|
||||||
|
name: Feature Request
|
||||||
|
about: Please use this template for describing new features.
|
||||||
|
title: 'feat: '
|
||||||
|
labels: 'Feature Request'
|
||||||
|
assignees: ''
|
||||||
|
---
|
||||||
|
|
||||||
|
## Why did you add this feature?
|
||||||
|
|
||||||
|
## Feature description
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -0,0 +1,15 @@
|
|||||||
|
---
|
||||||
|
name: Request help template
|
||||||
|
about: Please use this template for requesting help.
|
||||||
|
title: 'request help:'
|
||||||
|
labels: 'question'
|
||||||
|
assignees: ''
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
|
||||||
|
## Issue description
|
||||||
|
|
||||||
|
## Environment
|
||||||
|
|
||||||
|
- JustAuth version(e.g. `1.15.1`):
|
||||||
@@ -0,0 +1,13 @@
|
|||||||
|
## What this PR does / why we need it:
|
||||||
|
|
||||||
|
|
||||||
|
## Pre-submission checklist:
|
||||||
|
- [ ] Did you explain what problem does this PR solve?
|
||||||
|
- [ ] What new features have been added?
|
||||||
|
- [ ] Have you added corresponding test cases?
|
||||||
|
- [ ] Have you modified the corresponding document?
|
||||||
|
- [ ] Is this PR backward compatible?
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -0,0 +1,65 @@
|
|||||||
|
name: Deploy
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: [ dev ]
|
||||||
|
paths:
|
||||||
|
- src/**
|
||||||
|
- pom.xml
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
test:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2.2.0
|
||||||
|
- name: Set up Java and Maven
|
||||||
|
uses: actions/setup-java@v2
|
||||||
|
with:
|
||||||
|
java-version: '8'
|
||||||
|
distribution: 'zulu'
|
||||||
|
- name: Cache m2 package
|
||||||
|
uses: actions/cache@v2
|
||||||
|
with:
|
||||||
|
path: ~/.m2/repository
|
||||||
|
key: ${{ runner.os }}-maven-${{ hashFiles('pom.xml') }}
|
||||||
|
restore-keys: |
|
||||||
|
${{ runner.os }}-maven-
|
||||||
|
- run: mvn test
|
||||||
|
|
||||||
|
deploy-snapshot:
|
||||||
|
needs: test
|
||||||
|
if: ${{ success() }}
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2.2.0
|
||||||
|
- name: Set up Java and Maven
|
||||||
|
uses: actions/setup-java@v2
|
||||||
|
with:
|
||||||
|
java-version: '8'
|
||||||
|
distribution: 'zulu'
|
||||||
|
server-id: ossrh
|
||||||
|
server-username: MAVEN_USERNAME
|
||||||
|
server-password: MAVEN_PASSWORD
|
||||||
|
- name: Cache m2 package
|
||||||
|
uses: actions/cache@v2
|
||||||
|
with:
|
||||||
|
path: ~/.m2/repository
|
||||||
|
key: ${{ runner.os }}-maven-${{ hashFiles('pom.xml') }}
|
||||||
|
restore-keys: |
|
||||||
|
${{ runner.os }}-maven-
|
||||||
|
- name: setting snapshot version
|
||||||
|
run: |
|
||||||
|
import xml.etree.ElementTree as ET
|
||||||
|
tree = ET.parse("pom.xml")
|
||||||
|
version = tree.find("{http://maven.apache.org/POM/4.0.0}version")
|
||||||
|
print(version.text + "-SNAPSHOT")
|
||||||
|
if version.text.endswith("-SNAPSHOT") == False:
|
||||||
|
tree.find("{http://maven.apache.org/POM/4.0.0}version").text = version.text + "-SNAPSHOT"
|
||||||
|
ET.register_namespace("", "http://maven.apache.org/POM/4.0.0")
|
||||||
|
tree.write("pom.xml", "utf-8", True)
|
||||||
|
shell: python
|
||||||
|
- name: deploy snapshot to ossrh repository
|
||||||
|
run: mvn -B deploy -P snapshot -DskipTests
|
||||||
|
env:
|
||||||
|
MAVEN_USERNAME: ${{ secrets.OSSRH_USERNAME }}
|
||||||
|
MAVEN_PASSWORD: ${{ secrets.OSSRH_TOKEN }}
|
||||||
@@ -0,0 +1,26 @@
|
|||||||
|
name: test pull_request
|
||||||
|
|
||||||
|
on:
|
||||||
|
pull_request:
|
||||||
|
paths:
|
||||||
|
- src/**
|
||||||
|
- pom.xml
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
test:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2.2.0
|
||||||
|
- name: Set up Java and Maven
|
||||||
|
uses: actions/setup-java@v2
|
||||||
|
with:
|
||||||
|
java-version: '8'
|
||||||
|
distribution: 'zulu'
|
||||||
|
- name: Cache m2 package
|
||||||
|
uses: actions/cache@v2
|
||||||
|
with:
|
||||||
|
path: ~/.m2/repository
|
||||||
|
key: ${{ runner.os }}-maven-${{ hashFiles('pom.xml') }}
|
||||||
|
restore-keys: |
|
||||||
|
${{ runner.os }}-maven-
|
||||||
|
- run: mvn test
|
||||||
@@ -28,8 +28,8 @@ hs_err_pid*
|
|||||||
bin/codecov.sh
|
bin/codecov.sh
|
||||||
bin/deploy.sh
|
bin/deploy.sh
|
||||||
bin/docsify-cli.sh
|
bin/docsify-cli.sh
|
||||||
bin/push.sh
|
|
||||||
bin/push-dev.sh
|
|
||||||
|
|
||||||
target
|
target
|
||||||
/pom.xml.versionsBackup
|
/pom.xml.versionsBackup
|
||||||
|
/gpg
|
||||||
|
/PLAN.md
|
||||||
|
|||||||
@@ -0,0 +1,541 @@
|
|||||||
|
## 1.16.5
|
||||||
|
|
||||||
|
### 2021/10/18
|
||||||
|
|
||||||
|
- 合并 PR [Github #138](https://github.com/justauth/JustAuth/pull/138)
|
||||||
|
- 升级alipay-sdk-version的依赖版本
|
||||||
|
- 修改用户logo的尺寸
|
||||||
|
- 修复 alipay 登录失败的 BUG [Gitee Issue #I4E4ML](https://gitee.com/yadong.zhang/JustAuth/issues/I4E4ML)
|
||||||
|
|
||||||
|
|
||||||
|
## 1.16.4
|
||||||
|
|
||||||
|
### 2021/9/22
|
||||||
|
|
||||||
|
- 合并 PR
|
||||||
|
- [Github #134](https://github.com/justauth/JustAuth/pull/134)
|
||||||
|
- [Github #133](https://github.com/justauth/JustAuth/pull/133)
|
||||||
|
- [Github #132](https://github.com/justauth/JustAuth/pull/132)
|
||||||
|
- [Github #131](https://github.com/justauth/JustAuth/pull/131)
|
||||||
|
- 添加微软中国(世纪华联)第三方登录,新增微软方式登录的redirectUri校验。[Gitee PR #28](https://gitee.com/yadong.zhang/JustAuth/pulls/28)
|
||||||
|
- 升级第三方的依赖
|
||||||
|
- simple-http > 1.0.5
|
||||||
|
- lombok > 1.18.20
|
||||||
|
- junit > 4.13.2
|
||||||
|
- fastjson > 1.2.78
|
||||||
|
- alipay-sdk > 4.16.38.ALL
|
||||||
|
|
||||||
|
## 1.16.3
|
||||||
|
|
||||||
|
### 2021/8/15
|
||||||
|
|
||||||
|
- 发布 v1.16.3
|
||||||
|
- 新增
|
||||||
|
- 集成“企业微信的第三方应用”平台登录
|
||||||
|
- PR
|
||||||
|
- `AuthRequst` 增加 `Builder` 构建方式,使用起来更简单。 ([#27](https://gitee.com/yadong.zhang/JustAuth/pulls/27))
|
||||||
|
- 使用 Github Action 添加发布快照的 workflow。 ([#126](https://github.com/justauth/JustAuth/pull/126))
|
||||||
|
- 新增了企业微信的第三方应用登录,`AuthWeChatEnterpriseThirdQrcodeRequest`。 ([#127](https://github.com/justauth/JustAuth/pull/127))
|
||||||
|
- 添加快照版本对应更详细的文档。 ([#128](https://github.com/justauth/JustAuth/pull/128))
|
||||||
|
- 修改
|
||||||
|
- 在 Gitee PR ([#27](https://gitee.com/yadong.zhang/JustAuth/pulls/27)) 的基础上重构代码,增加 Builder 方式创建 AuthRequest
|
||||||
|
- 解决 Line 登录的错误。[#122](https://github.com/justauth/JustAuth/issues/122)
|
||||||
|
|
||||||
|
|
||||||
|
## 1.16.2
|
||||||
|
|
||||||
|
### 2021/7/28
|
||||||
|
|
||||||
|
- 发布 v1.16.2
|
||||||
|
- 新增
|
||||||
|
- 集成“程序员客栈”平台登录
|
||||||
|
- 修改
|
||||||
|
- 更新文档
|
||||||
|
- 修复“淘宝”平台授权登录后没有`uid`的问题、增加刷新token的功能
|
||||||
|
- 修复“Twitter”平台授权登录后获取不到用户邮箱的问题
|
||||||
|
|
||||||
|
## 1.16.1
|
||||||
|
|
||||||
|
### 2021/4/19
|
||||||
|
|
||||||
|
- 发布 v1.16.1
|
||||||
|
- Fix Github issue [#114](https://github.com/justauth/JustAuth/issues/114): 解决企业微信授权后,回调地址中原有的参数丢失的问题
|
||||||
|
- Fix Github issue [#82](https://github.com/justauth/JustAuth/issues/82): 抖音平台支持自定义 scope
|
||||||
|
- Fix Github issue [#92](https://github.com/justauth/JustAuth/issues/92): 增加忽略校验 redirectUri 的配置
|
||||||
|
- Merge Github PR [#115](https://github.com/justauth/JustAuth/pull/115)
|
||||||
|
- 升级 `fastjson` 到 `v1.2.76`
|
||||||
|
|
||||||
|
## 1.16.0
|
||||||
|
|
||||||
|
### 2021/4/7
|
||||||
|
|
||||||
|
- 发布 v1.16.0
|
||||||
|
- 新增
|
||||||
|
- 集成 Amazon 平台登录
|
||||||
|
- 集成 Slack 平台登录
|
||||||
|
- 集成 LINE 平台登录
|
||||||
|
- 集成 Okta 平台登录
|
||||||
|
- 集成钉钉账号登录
|
||||||
|
- 修改
|
||||||
|
- 【**重要**】 `AuthConfig`中的`codingGroupName`参数更名为`domainPrefix`,针对此类平台提供通用的配置。
|
||||||
|
- 修改 `AuthFacebookScope` 中的默认 scope,解决 justauth-demo 项目中使用 facebook 报错的问题
|
||||||
|
- 升级 facebook 的 api 到 v10.0 版本
|
||||||
|
- 优化部分代码
|
||||||
|
- 优化 Map 声明时的初始容量,避免频繁扩容
|
||||||
|
- 更新 README 文档
|
||||||
|
- PR
|
||||||
|
- 合并 [Github #110](https://github.com/justauth/JustAuth/pull/110)
|
||||||
|
- 合并 [Gitee #22](https://gitee.com/yadong.zhang/JustAuth/pulls/22)
|
||||||
|
|
||||||
|
## 1.15.9
|
||||||
|
|
||||||
|
### 2021/1/1
|
||||||
|
|
||||||
|
- 发布 v1.15.9
|
||||||
|
- 新增
|
||||||
|
- 修复并正式启用 飞书 平台的第三方登录
|
||||||
|
- AuthToken 类中新增 `refreshTokenExpireIn` 记录 refresh token 的有效期
|
||||||
|
- PR
|
||||||
|
- 合并 [Github #101](https://github.com/justauth/JustAuth/pull/101) :支持喜马拉雅登录
|
||||||
|
- 合并 [Github #105](https://github.com/justauth/JustAuth/pull/105) :支持企业微信网页授权登录
|
||||||
|
- 合并 [Github #107](https://github.com/justauth/JustAuth/pull/107) :添加AuthAlipayRequest网络代理构造器,解决 Github Issue [#102](https://github.com/justauth/JustAuth/issues/102)
|
||||||
|
- 修改
|
||||||
|
- 修改喜马拉雅配置参数,将`ClientOsType`参数提到 AuthConfig 中
|
||||||
|
- AuthChecker 中增加对喜马拉雅平台的校验
|
||||||
|
- 升级 facebook api 版本到 v9.0,解决 Gitee Issue [#I2AR5S](https://gitee.com/yadong.zhang/JustAuth/issues/I2AR5S)
|
||||||
|
- !!!**注意**!!!修改原来的企业微信 Request 类名为 `AuthWeChatEnterpriseQrcodeRequest`,升级后注意该点
|
||||||
|
|
||||||
|
注意:可能有些开发者对于 JA 集成的四个微信平台不太理解,这儿统一说明:
|
||||||
|
- 按照类名
|
||||||
|
- AuthWeChatEnterpriseQrcodeRequest:企业微信二维码登录
|
||||||
|
- AuthWeChatEnterpriseWebRequest:企业微信网页登录
|
||||||
|
- AuthWeChatOpenRequest:微信开放平台
|
||||||
|
- AuthWeChatMpRequest:微信公众平台
|
||||||
|
- 按照枚举
|
||||||
|
- WECHAT_ENTERPRISE:企业微信二维码登录
|
||||||
|
- WECHAT_ENTERPRISE_WEB:企业微信网页登录
|
||||||
|
- WECHAT_OPEN:微信开放平台
|
||||||
|
- WECHAT_MP:微信公众平台
|
||||||
|
|
||||||
|
## 1.15.8
|
||||||
|
|
||||||
|
### 2020/10/25
|
||||||
|
|
||||||
|
- Release version 1.15.8
|
||||||
|
- Merge the pr. [#95](https://github.com/justauth/JustAuth/pull/95) [#96](https://github.com/justauth/JustAuth/pull/96)
|
||||||
|
|
||||||
|
## 1.15.7
|
||||||
|
|
||||||
|
### 2020/09/11
|
||||||
|
|
||||||
|
- Release version 1.15.7
|
||||||
|
- Upgrade the use of access token when obtaining resources on the github platform.Reference from [Deprecating API authentication through query parameters](https://developer.github.com/changes/2020-02-10-deprecating-auth-through-query-param/)
|
||||||
|
- Fixed issue. [#89](https://github.com/justauth/JustAuth/issues/89)
|
||||||
|
|
||||||
|
## 1.15.7-beta.3
|
||||||
|
|
||||||
|
### 2020/08/24
|
||||||
|
|
||||||
|
- Fixing a bug for wechat.
|
||||||
|
- Improve the Microsoft platform's questions about scope.
|
||||||
|
|
||||||
|
## 1.15.7-beta.1
|
||||||
|
|
||||||
|
### 2020/08/05
|
||||||
|
|
||||||
|
- 新增
|
||||||
|
- 以下平台支持自定义 Scope 参数:百度、coding、Facebook、gitee、github、gitlab、google、华为、京东·宙斯、酷家乐、领英、微软、小米、Pinterest、QQ、人人网、StackOverflow、微博、微信公众平台
|
||||||
|
- 添加 PR 和 ISSUE 规范和 CODE_OF_CONDUCT 文档
|
||||||
|
- 合并
|
||||||
|
- 合并 Gitee [PR#19](https://gitee.com/yadong.zhang/JustAuth/pulls/19),修复通过google登录一次后,重新用google登录无法切换谷歌账户的问题。
|
||||||
|
|
||||||
|
## 1.15.6
|
||||||
|
|
||||||
|
### 2020/06/30
|
||||||
|
- 文档
|
||||||
|
- 新增 [百度登录](oauth/baidu.md)文档
|
||||||
|
- 新增 [钉钉登录](oauth/alipay.md)文档
|
||||||
|
- 新增 [开源中国登录](contributors.md)文档
|
||||||
|
- 新增 [领英登录](references.md)文档
|
||||||
|
- 新增 [Google 登录](references.md)文档
|
||||||
|
- 新增 [微信企业版登录](oauth/wechatEnterprise.md)文档
|
||||||
|
- 新增 [Facebook 登录](oauth/facebook.md)文档
|
||||||
|
- 完善 [JustAuth 使用者](users.md)文档
|
||||||
|
- 替换“帮助文档”域名,由[https://docs.justauth.whnb.wang](https://docs.justauth.whnb.wang)迁移到[https://justauth.wiki](https://justauth.wiki)
|
||||||
|
- 新增
|
||||||
|
- 增加阿里云授权登录中刷新授权token的接口,by “QQ群用户需求”
|
||||||
|
- AuthConfig 增加忽略校验 state 的参数,详情参考:[Github#Issue#83](https://github.com/justauth/JustAuth/issues/83)
|
||||||
|
- 移除领英刷新token的接口。参考官网:`To refresh an access token, go through the authorization process again to fetch a new token.`
|
||||||
|
|
||||||
|
## 1.15.5
|
||||||
|
### 2020/06/24
|
||||||
|
- BUG
|
||||||
|
- 解决 `Microsoft` 授权失败的 BUG
|
||||||
|
- 解决 `Coding` 个人账号授权失败的 BUG(目前只能使用团队模式进行授权,需要传入团队名,参考`AuthConfig#codingGroupName`)
|
||||||
|
- 解决 `AuthLinkedinRequest#getAvatar` NPE 的问题。(领英用户没有头像时,原代码会报 NPE)
|
||||||
|
- 解决抖音登录获取用户地址异常的问题。
|
||||||
|
- 解决人人网登录时 token 中带有 `|` 引起的异常,[Gitee!15](https://gitee.com/yadong.zhang/JustAuth/pulls/15)
|
||||||
|
- 新增
|
||||||
|
- 支持阿里云授权登录,[Github#81](https://github.com/justauth/JustAuth/pull/81)
|
||||||
|
- AuthUser 中新增 `rawUserInfo`,用来存放第三方平台返回的原始用户数据。注:淘宝平台的`rawUserInfo`为一个空 JSON
|
||||||
|
- 支持 Http 级的代理配置,使用方式:
|
||||||
|
```java
|
||||||
|
new AuthGoogleRequest(AuthConfig.builder()
|
||||||
|
.clientId("")
|
||||||
|
.clientSecret("")
|
||||||
|
.redirectUri("http://127.0.0.1:8443/oauth/callback/google")
|
||||||
|
// 针对国外平台配置代理
|
||||||
|
.httpConfig(HttpConfig.builder()
|
||||||
|
.timeout(15000)
|
||||||
|
.proxy(new Proxy(Proxy.Type.HTTP, new InetSocketAddress("127.0.0.1", 10080)))
|
||||||
|
.build())
|
||||||
|
.build());
|
||||||
|
```
|
||||||
|
- 修改
|
||||||
|
- 升级 [simple-http](https://github.com/xkcoding/simple-http) 到 `v1.0.2`
|
||||||
|
- 升级 `fastjson` 到 `v1.2.71`
|
||||||
|
- 删除
|
||||||
|
- :boom: 删除**腾讯云登录**。coding 已并入 腾讯云,因此只保留 coding 登录 :boom:
|
||||||
|
- 文档
|
||||||
|
- 新增 [Coding登录](oauth/coding.md)文档
|
||||||
|
- 完善 [支付宝登录](oauth/alipay.md)文档
|
||||||
|
- 完善 [贡献者名单](contributors.md)文档
|
||||||
|
- 完善 [参考文档](references.md)文档
|
||||||
|
- PR
|
||||||
|
- 合并 [Gitee!17](https://gitee.com/yadong.zhang/JustAuth/pulls/17)
|
||||||
|
- 合并 [Gitee!15](https://gitee.com/yadong.zhang/JustAuth/pulls/15)
|
||||||
|
- 合并 [Github#81](https://github.com/justauth/JustAuth/pull/81)
|
||||||
|
- Issues
|
||||||
|
- 解决 [Github#80](https://github.com/justauth/JustAuth/issues/80)
|
||||||
|
- 解决 [Github#75](https://github.com/justauth/JustAuth/issues/75)
|
||||||
|
|
||||||
|
## 1.15.4-alpha
|
||||||
|
### 2020/05/13
|
||||||
|
- 修复
|
||||||
|
- 解决 Twitter 授权失败的BUG
|
||||||
|
- 文档
|
||||||
|
- 完善 [https://justauth.wiki](https://justauth.wiki/) 的404引导页内容
|
||||||
|
- 增加名词解释: `uuid`
|
||||||
|
- 补充 [Q&A](Q&A.md)
|
||||||
|
- 新增 [参考文档](references.md),包含 OAuth 授权和第三方平台的API文档等内容
|
||||||
|
- 新增 [推特登录](oauth/twitter.md) 的说明文档
|
||||||
|
|
||||||
|
> 特别注意:所有国外平台都无法直接通过java进行访问API,目前[simple-http](https://github.com/xkcoding/simple-http) Release版本,暂不支持添加代理,所以目前需要手动开启代理。
|
||||||
|
|
||||||
|
代理开启的方式:
|
||||||
|
```java
|
||||||
|
System.setProperty("proxyPort", "10080");
|
||||||
|
System.setProperty("proxyHost", "127.0.0.1");
|
||||||
|
```
|
||||||
|
以上代码可以在声明 `AuthRequest` 时创建,也可以全局执行。
|
||||||
|
|
||||||
|
本地如果支持科学上网,就用自己本地的代理端口即可,如果不支持科学上网,可以去网上找一些免费的代理IP进行测试(请自行操作)。
|
||||||
|
|
||||||
|
|
||||||
|
## 1.15.2-alpha
|
||||||
|
### 2020/05/10
|
||||||
|
- 修改
|
||||||
|
- 修复使用领英登录时无法获取token的问题
|
||||||
|
- 解决Gitee [Issue-I1GPIB](https://gitee.com/yadong.zhang/JustAuth/issues/I1GPIB)
|
||||||
|
|
||||||
|
【声明】:当引用 OkHttp 时,无法调用领英的授权登录,可能会抛出 400 异常。如遇此问题,请先切换到 hutool 或者 httpclient 依赖。
|
||||||
|
该问题尚在修复中,给各位带来的不便,深表歉意。
|
||||||
|
|
||||||
|
- hutool-http
|
||||||
|
|
||||||
|
```xml
|
||||||
|
<dependency>
|
||||||
|
<groupId>cn.hutool</groupId>
|
||||||
|
<artifactId>hutool-http</artifactId>
|
||||||
|
<version>5.2.5</version>
|
||||||
|
</dependency>
|
||||||
|
```
|
||||||
|
|
||||||
|
- httpclient
|
||||||
|
|
||||||
|
```xml
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.apache.httpcomponents</groupId>
|
||||||
|
<artifactId>httpclient</artifactId>
|
||||||
|
<version>4.5.12</version>
|
||||||
|
</dependency>
|
||||||
|
```
|
||||||
|
|
||||||
|
## v1.15.1(~~v1.15.0~~)
|
||||||
|
### 2020/04/10
|
||||||
|
- 修改
|
||||||
|
- 更新开发文档
|
||||||
|
- 合并Gitee [PR-10](https://gitee.com/yadong.zhang/JustAuth/pulls/10),集成京东登录
|
||||||
|
- 合并Gitee [PR-14](https://gitee.com/yadong.zhang/JustAuth/pulls/14),修改帮助文档,加入JA的使用者信息
|
||||||
|
- 合并Github [PR-69](https://github.com/justauth/JustAuth/pull/69),升级fastjson的最新版本
|
||||||
|
- 解决使用apache-httpclient时的403bug,升级simple-http,感谢QQ群的`不瘦十斤不改名字`反馈该问题
|
||||||
|
- 修复其他一些问题
|
||||||
|
|
||||||
|
【声明】:由于本人的失误,发布了一个错误的版本(1.15.0),目前1.15.0已发布,但是请不要使用,请直接升级到`1.15.1`。
|
||||||
|
|
||||||
|
给各位造成的不便,深表歉意。
|
||||||
|
|
||||||
|
## v1.14.0
|
||||||
|
### 2020/03/17
|
||||||
|
- 修改
|
||||||
|
- 合并[PR-59](https://github.com/justauth/JustAuth/pull/59),抽取HTTP,具体实现交给开发者,解耦 hutool-http,开发者可以视自己项目的依赖决定使用何种HTTP方式。详情请参考:https://github.com/xkcoding/simple-http
|
||||||
|
- 合并[PR-65](https://github.com/justauth/JustAuth/pull/65),修改错误文案
|
||||||
|
- 修复其他一些问题
|
||||||
|
|
||||||
|
## v1.14.0
|
||||||
|
### 2020/03/17
|
||||||
|
- 修改
|
||||||
|
- 合并[PR-59](https://github.com/justauth/JustAuth/pull/59),抽取HTTP,具体实现交给开发者,解耦 hutool-http,开发者可以视自己项目的依赖决定使用何种HTTP方式。详情请参考:https://github.com/xkcoding/simple-http
|
||||||
|
- 合并[PR-65](https://github.com/justauth/JustAuth/pull/65),修改错误文案
|
||||||
|
- 修复其他一些问题
|
||||||
|
|
||||||
|
## v1.13.2
|
||||||
|
### 2019/12/24
|
||||||
|
- 新增
|
||||||
|
- 增加微信、QQ、支付宝、微博授权登录的帮助文档
|
||||||
|
- 合并[PR#57](https://github.com/justauth/JustAuth/pull/57),增加微信公众号登录 by [@xkcoding](https://github.com/xkcoding)
|
||||||
|
- [帮助文档](https://justauth.wiki)中增加自定义的404页面
|
||||||
|
- [帮助文档](https://justauth.wiki)中增加Gittalk插件
|
||||||
|
- [帮助文档](https://justauth.wiki)中增加Java代码高亮的插件
|
||||||
|
- 增加`AuthUserGender#getWechatRealGender`方法,兼容获取微信平台的用户性别
|
||||||
|
- 修改
|
||||||
|
- 修复抖音登录取值取错层级的问题([issue#I15SIG@Gitee](https://gitee.com/yadong.zhang/JustAuth/issues/I15SIG))
|
||||||
|
- 完善异常提示的逻辑,支持传入Source(平台),发生异常时显示对应的source(平台)
|
||||||
|
- `checkState`方法从`AuthDefaultRequest`中提出到`AuthChecker`中
|
||||||
|
- `AuthResponseStatus`枚举类中增加`ILLEGAL_STATUS`、`REQUIRED_REFRESH_TOKEN`两个枚举值
|
||||||
|
- `AuthSource`接口中增加`getName`方法,用来对外提供实际`source`的字符串值
|
||||||
|
- `AuthWeiboRequest`微博授权登录中实现`revoke`方法,支持手动回收授权
|
||||||
|
- [帮助文档](https://justauth.wiki)中修复[腾讯云登录]链接错误的问题
|
||||||
|
- 升级
|
||||||
|
- 升级相关依赖:lombok@v1.18.10,hutool@5.0.5,fastjson@1.2.62,alipay@4.8.10.ALL([PR#11@Gitee](https://gitee.com/yadong.zhang/JustAuth/pulls/11))
|
||||||
|
|
||||||
|
|
||||||
|
## v1.13.1
|
||||||
|
### 2019/11/12
|
||||||
|
|
||||||
|
- 修复[Issue#52](https://github.com/justauth/JustAuth/issues/52),解决AuthCallback异常的问题。请正在使用 `v1.13.0`的朋友升级到`v1.13.1`
|
||||||
|
|
||||||
|
## v1.13.0
|
||||||
|
### 2019/11/01
|
||||||
|
|
||||||
|
- 集成“推特”
|
||||||
|
- 完善文档
|
||||||
|
|
||||||
|
## v1.12.0
|
||||||
|
### 2019/09/06
|
||||||
|
|
||||||
|
- 集成“美团”授权登录
|
||||||
|
- 集成“饿了么”授权登录
|
||||||
|
- 升级Fastjson依赖到1.2.60,预防[“Fastjson < 1.2.60 远程拒绝服务漏洞预警”](https://card.weibo.com/article/m/show/id/2309404413257925394542)
|
||||||
|
- 添加Nutzboot版的demo
|
||||||
|
- 提取公共的Source接口,支持自定义扩展第三方平台的授权登录,具体扩展例子可参考[AuthExtendRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/test/java/me/zhyd/oauth/request/AuthExtendRequest.java)
|
||||||
|
|
||||||
|
## v1.11.0
|
||||||
|
### 2019/09/03
|
||||||
|
|
||||||
|
- 集成“Gitlab”授权登录
|
||||||
|
|
||||||
|
### 2019/09/02
|
||||||
|
|
||||||
|
- 集成“酷家乐”授权登录
|
||||||
|
|
||||||
|
## v1.10.1
|
||||||
|
### 2019/08/17
|
||||||
|
|
||||||
|
- AuthUser添加构造函数,支持反序列化
|
||||||
|
|
||||||
|
### 2019/08/08
|
||||||
|
|
||||||
|
- 项目迁移到组织[justauth](https://github.com/justauth)
|
||||||
|
|
||||||
|
## v1.10.0
|
||||||
|
### 2019/08/06
|
||||||
|
|
||||||
|
- 合并[PR-34](https://github.com/zhangyd-c/JustAuth/pull/34),添加StringUtil单元测试,修复bug
|
||||||
|
- 合并[PR-35](https://github.com/zhangyd-c/JustAuth/pull/35),集成企业微信
|
||||||
|
|
||||||
|
### 2019/08/05
|
||||||
|
|
||||||
|
- 集成华为登录
|
||||||
|
- 修改`AuthChecker#checkCode`方法,对于不同平台使用不同参数接受code的情况统一做处理
|
||||||
|
|
||||||
|
### 2019/08/03
|
||||||
|
|
||||||
|
合并github上[xkcoding](https://github.com/xkcoding) 的[pr#32](https://github.com/zhangyd-c/JustAuth/pull/32),抽取 cache 接口,方便用户自行集成 cache
|
||||||
|
|
||||||
|
### 2019/08/02
|
||||||
|
|
||||||
|
- 增加`AuthCache`配置类`AuthCacheConfig.java`,可以自定义缓存有效期以及是否开启定时任务
|
||||||
|
- 去掉`slf4j`依赖,封装`Log.java`工具类
|
||||||
|
- 规范测试类
|
||||||
|
|
||||||
|
## v1.9.5
|
||||||
|
### 2019/07/31
|
||||||
|
|
||||||
|
`v1.9.4`版本发布失败,请升级到`1.9.5`版本!
|
||||||
|
|
||||||
|
由此给您带来的不便,敬请谅解!
|
||||||
|
|
||||||
|
## v1.9.4
|
||||||
|
### 2019/07/30
|
||||||
|
|
||||||
|
1. 升级`hutool-http`版本到`v4.6.1`
|
||||||
|
2. 去除`AuthCallback`中增加的默认的校验state的方法,挪到`AuthDefaultRequest`中做统一处理
|
||||||
|
3. `alipay-sdk-java`依赖改为`provided`,如果需要使用支付宝登录,需要使用方手动引入相关依赖,具体操作方式,见项目WIKI;
|
||||||
|
4. 规范注释
|
||||||
|
|
||||||
|
## v1.9.3
|
||||||
|
### 2019/07/30
|
||||||
|
|
||||||
|
1. 规范注释
|
||||||
|
2. 增加State缓存,`AuthCallback`中增加默认的校验state的方法
|
||||||
|
3. 增加默认的state生成方法,参考`AuthStateUtils.java`和`UuidUtils.java`
|
||||||
|
4. 升级`hutool-http`版本到`v4.6.0`
|
||||||
|
5. 修复其他一些问题
|
||||||
|
|
||||||
|
### 2019/07/27
|
||||||
|
|
||||||
|
1. `IpUtils.getIp`改名为`IpUtils.getLocalIp`
|
||||||
|
2. 规范注释
|
||||||
|
|
||||||
|
### 2019/07/25
|
||||||
|
|
||||||
|
1. `AuthConfig`类中去掉state参数
|
||||||
|
2. 删除`AuthState`类
|
||||||
|
3. 增加`authorize(String)`方法,并且使用`@Deprecated`标记`authorize()`方法
|
||||||
|
|
||||||
|
## v1.9.2
|
||||||
|
### 2019/07/22
|
||||||
|
1. 合并github上[xkcoding](https://github.com/xkcoding) 的[pr#26](https://github.com/zhangyd-c/JustAuth/pull/26),AuthConfig类添加lombok注解,方便 [justauth-spring-boot-starter](https://github.com/xkcoding/justauth-spring-boot-starter) 直接使用
|
||||||
|
|
||||||
|
## v1.9.1
|
||||||
|
### 2019/07/22
|
||||||
|
1. 增加`stackoverflow`参数校验
|
||||||
|
2. 解决`Pinterest`获取用户失败的问题
|
||||||
|
3. 添加注释
|
||||||
|
|
||||||
|
## v1.9.0
|
||||||
|
### 2019/07/19
|
||||||
|
|
||||||
|
1. 合并github上[@dyc12ii](https://github.com/dyc12ii) 的[pr#25](https://github.com/zhangyd-c/JustAuth/pull/25),升级fastjson版本至1.2.58,避免安全漏洞
|
||||||
|
2. `AuthUserGender`枚举类挪到`enums`包下
|
||||||
|
3. 删除`AuthBaiduErrorCode`和`AuthDingTalkErrorCode`枚举类
|
||||||
|
4. 优化百度授权流程,增加refresh token的方法
|
||||||
|
5. 优化`AuthConfig`、`AuthResponse`类,去掉不必要的lombonk注解,减少编译后的代码量
|
||||||
|
6. 使用lombok注解优化枚举类
|
||||||
|
7. `AuthQqRequest`增加refresh方法
|
||||||
|
8. 修复google登录无法获取用户信息的问题
|
||||||
|
9. 优化代码
|
||||||
|
|
||||||
|
### 2019/07/18
|
||||||
|
|
||||||
|
1. 合并github上[@pengisgood](https://github.com/pengisgood) 的[pr#19](https://github.com/zhangyd-c/JustAuth/pull/19),集成人人
|
||||||
|
2. 合并github上[@pengisgood](https://github.com/pengisgood) 的[pr#20](https://github.com/zhangyd-c/JustAuth/pull/20),集成Pinterest
|
||||||
|
3. 合并github上[@pengisgood](https://github.com/pengisgood) 的[pr#21](https://github.com/zhangyd-c/JustAuth/pull/21),集成StackOverflow
|
||||||
|
4. 合并github上[@xkcoding](https://github.com/xkcoding) 的[pr#23](https://github.com/zhangyd-c/JustAuth/pull/23),重构代码、新增编辑器规范,规范PR代码风格
|
||||||
|
|
||||||
|
### 2019/07/17
|
||||||
|
1. 优化代码
|
||||||
|
2. 集成Teambition登录
|
||||||
|
|
||||||
|
### 2019/07/16
|
||||||
|
1. 重构UrlBuilder类
|
||||||
|
2. 将CSDN相关的类置为`Deprecated`,后续可能会删除,也可能一直保留。毕竟CSDN的openAPI已经不对外开放了。
|
||||||
|
3. `BaseAuthRequest` 改名为 `AuthDefaultRequest`
|
||||||
|
4. `ResponseStatus` 改名为 `AuthResponseStatus` 并且移动到 `me.zhyd.oauth.model`
|
||||||
|
5. 合并github上[@xkcoding](https://github.com/xkcoding) 的[pr#18](https://github.com/zhangyd-c/JustAuth/pull/18),修复小米回调错误问题 同时 支持微信获取unionId
|
||||||
|
|
||||||
|
## v1.8.1
|
||||||
|
### 2019/07/15
|
||||||
|
1. 新增 `AuthState` 类,内置默认的state生成规则和校验规则
|
||||||
|
|
||||||
|
### 2019/07/12
|
||||||
|
1. 合并[Braavos96](https://github.com/Braavos96)提交的[PR#16](https://github.com/zhangyd-c/JustAuth/pull/16)
|
||||||
|
|
||||||
|
## v1.8.0
|
||||||
|
### 2019/06/28
|
||||||
|
1. 修复百度登录获取不到token失效时间的问题
|
||||||
|
2. 增加state参数校验,预防CSRF。**强烈建议启用state**!
|
||||||
|
|
||||||
|
### 2019/06/27
|
||||||
|
1. 修复百度登录获取不到token失效时间的问题
|
||||||
|
2. 增加state参数校验,预防CSRF。**强烈建议启用state**!
|
||||||
|
3. 修改login方法的参数为AuthCallback,封装回调返回的参数
|
||||||
|
4. 支持state参数
|
||||||
|
5. 增加code和state参数校验
|
||||||
|
|
||||||
|
由于state安全问题,1.8.0以前的版本都有隐藏的CSRF漏洞问题,所以强烈建议正在使用JustAuth的朋友升级到1.8.0版本!
|
||||||
|
|
||||||
|
## v1.7.1
|
||||||
|
### 2019/06/25
|
||||||
|
qq授权登录时,需要获取`openId`作为`uuid`,在`1.6.1-beta`和`1.7.0`版本中,引入了`unionId`这一属性。获取`unionid`需要单独向qq团队**发送邮件**申请权限,鉴于这一申请权限的步骤比较麻烦(需要填写的内容比较多),所以在`AuthConfig`中增加了一个`unionId`属性,当为**true**时才会获取unionid,当为false时只获取openId。如果你需要该功能, 则在自行申请了相关权限后,将该属性置为true即可。关于unionId的参考链接:[UnionID介绍](http://wiki.connect.qq.com/unionid%E4%BB%8B%E7%BB%8D)
|
||||||
|
|
||||||
|
## v1.7.0
|
||||||
|
### 2019/06/19
|
||||||
|
1. 合并[xkcoding](https://github.com/xkcoding)提交的[PR](https://github.com/zhangyd-c/JustAuth/pull/14),重构了部分代码,jar包由原来的`130+kb`优化到现在的`110+kb`
|
||||||
|
2. 合并[skqing](https://gitee.com/skqing)提交的[PR](https://gitee.com/yadong.zhang/JustAuth/pulls/3), 解决抖音登录失败问题
|
||||||
|
|
||||||
|
## v1.6.1-beta
|
||||||
|
### 2019/06/18
|
||||||
|
1. 解决Issue [#IY2HW](https://gitee.com/yadong.zhang/JustAuth/issues/IY2HW)
|
||||||
|
2. 解决Issue [#IY2OH](https://gitee.com/yadong.zhang/JustAuth/issues/IY2OH)
|
||||||
|
3. 解决Issue [#IY2FV](https://gitee.com/yadong.zhang/JustAuth/issues/IY2FV)
|
||||||
|
4. 修复部分注释、拼写错误
|
||||||
|
5. 解决Issue [#IY1QR](https://gitee.com/yadong.zhang/JustAuth/issues/IY1QR) 增加对Config属性的校验功能,主要校验redirect uri的合法性
|
||||||
|
6. 合并[skqing](https://gitee.com/skqing)提交的[PR](https://gitee.com/yadong.zhang/JustAuth/pulls/2),解决一些BUG
|
||||||
|
|
||||||
|
## v1.6.0-beta
|
||||||
|
### 2019/06/06
|
||||||
|
1. 增加今日头条的授权登陆
|
||||||
|
2. 发布1.6.0-beta版本,今日头条开发者暂时不能认证, 所以无法做测试,等测试通过后,正式发布release版本
|
||||||
|
|
||||||
|
## v1.5.0
|
||||||
|
### 2019/05/28
|
||||||
|
1. 增加小米账号和微软的授权登陆
|
||||||
|
2. 发布1.5.0版本
|
||||||
|
|
||||||
|
## v1.4.0
|
||||||
|
### 2019/05/26
|
||||||
|
1. 增加抖音和Linkedin的授权登陆
|
||||||
|
2. 修改部分图片命名
|
||||||
|
3. 优化部分代码
|
||||||
|
4. 修复`AuthSource`中腾讯云开发平台的拼写错误:`TENCEN_CLOUD`->`TENCENT_CLOUD`
|
||||||
|
5. 修复支付宝登陆时用户名为空的问题
|
||||||
|
|
||||||
|
## v1.3.3
|
||||||
|
### 2019/05/24
|
||||||
|
1. 修复一些问题
|
||||||
|
2. 升级api,在AuthUser中增加`uuid`属性,可以通过`uuid` + `source`唯一确定一个用户,此举解决了用户身份归属的问题。
|
||||||
|
3. 发布1.3.3版本的jar包到公开仓库(1.3.2忘记发布了,( ╯□╰ ))
|
||||||
|
4. 重要:经咨询官方客服得知,CSDN的授权开放平台已经下线,如果以前申请过的应用,可以继续使用,但是不再支持申请新的应用。so, 本项目中的CSDN登录只能针对少部分用户使用了
|
||||||
|
|
||||||
|
## v1.3.1
|
||||||
|
### 2019/05/23
|
||||||
|
1. 修复QQ登录的问题
|
||||||
|
2. 发布1.3.1版本的jar包到公开仓库
|
||||||
|
|
||||||
|
## v1.3.0
|
||||||
|
### 2019/05/21
|
||||||
|
1. 新增google授权登录
|
||||||
|
2. 新增facebook授权登录
|
||||||
|
3. 发布1.3.0版本的jar包到公开仓库
|
||||||
|
|
||||||
|
## v1.1.0
|
||||||
|
### 2019/05/18
|
||||||
|
1. 发布1.1.0版本的jar包到公开仓库(支持qq和微信登录)
|
||||||
|
2. 支持淘宝登录
|
||||||
|
3. 修改`AuthUser.java`类中的`accessToken`属性,由原本的~~accessToken (String)~~改为`token (AuthToken)`
|
||||||
|
4. 修复一些bug
|
||||||
|
5. 发布1.2.0版本的jar包到公开仓库(支持淘宝登录)
|
||||||
|
|
||||||
|
### 2019/05/17
|
||||||
|
1. 增加qq和微信的授权登录
|
||||||
|
2. 修改getAccessToken方法的返回值
|
||||||
|
|
||||||
|
## v1.0.1
|
||||||
|
### 2019/03/27
|
||||||
|
集成 支付宝授权登录
|
||||||
|
|
||||||
|
## v1.0.0
|
||||||
|
### 2019/03/25
|
||||||
|
史上最全的整合第三方登录的工具,目前已支持Github、Gitee、微博、钉钉和百度、Coding、腾讯云开发者平台和OSChina登录。 Login, so easy!
|
||||||
@@ -0,0 +1,76 @@
|
|||||||
|
# Contributor Covenant Code of Conduct
|
||||||
|
|
||||||
|
## Our Pledge
|
||||||
|
|
||||||
|
In the interest of fostering an open and welcoming environment, we as
|
||||||
|
contributors and maintainers pledge to making participation in our project and
|
||||||
|
our community a harassment-free experience for everyone, regardless of age, body
|
||||||
|
size, disability, ethnicity, sex characteristics, gender identity and expression,
|
||||||
|
level of experience, education, socio-economic status, nationality, personal
|
||||||
|
appearance, race, religion, or sexual identity and orientation.
|
||||||
|
|
||||||
|
## Our Standards
|
||||||
|
|
||||||
|
Examples of behavior that contributes to creating a positive environment
|
||||||
|
include:
|
||||||
|
|
||||||
|
* Using welcoming and inclusive language
|
||||||
|
* Being respectful of differing viewpoints and experiences
|
||||||
|
* Gracefully accepting constructive criticism
|
||||||
|
* Focusing on what is best for the community
|
||||||
|
* Showing empathy towards other community members
|
||||||
|
|
||||||
|
Examples of unacceptable behavior by participants include:
|
||||||
|
|
||||||
|
* The use of sexualized language or imagery and unwelcome sexual attention or
|
||||||
|
advances
|
||||||
|
* Trolling, insulting/derogatory comments, and personal or political attacks
|
||||||
|
* Public or private harassment
|
||||||
|
* Publishing others' private information, such as a physical or electronic
|
||||||
|
address, without explicit permission
|
||||||
|
* Other conduct which could reasonably be considered inappropriate in a
|
||||||
|
professional setting
|
||||||
|
|
||||||
|
## Our Responsibilities
|
||||||
|
|
||||||
|
Project maintainers are responsible for clarifying the standards of acceptable
|
||||||
|
behavior and are expected to take appropriate and fair corrective action in
|
||||||
|
response to any instances of unacceptable behavior.
|
||||||
|
|
||||||
|
Project maintainers have the right and responsibility to remove, edit, or
|
||||||
|
reject comments, commits, code, wiki edits, issues, and other contributions
|
||||||
|
that are not aligned to this Code of Conduct, or to ban temporarily or
|
||||||
|
permanently any contributor for other behaviors that they deem inappropriate,
|
||||||
|
threatening, offensive, or harmful.
|
||||||
|
|
||||||
|
## Scope
|
||||||
|
|
||||||
|
This Code of Conduct applies both within project spaces and in public spaces
|
||||||
|
when an individual is representing the project or its community. Examples of
|
||||||
|
representing a project or community include using an official project e-mail
|
||||||
|
address, posting via an official social media account, or acting as an appointed
|
||||||
|
representative at an online or offline event. Representation of a project may be
|
||||||
|
further defined and clarified by project maintainers.
|
||||||
|
|
||||||
|
## Enforcement
|
||||||
|
|
||||||
|
Instances of abusive, harassing, or otherwise unacceptable behavior may be
|
||||||
|
reported by contacting the project team at yadong.zhang0415@gmail.com. All
|
||||||
|
complaints will be reviewed and investigated and will result in a response that
|
||||||
|
is deemed necessary and appropriate to the circumstances. The project team is
|
||||||
|
obligated to maintain confidentiality with regard to the reporter of an incident.
|
||||||
|
Further details of specific enforcement policies may be posted separately.
|
||||||
|
|
||||||
|
Project maintainers who do not follow or enforce the Code of Conduct in good
|
||||||
|
faith may face temporary or permanent repercussions as determined by other
|
||||||
|
members of the project's leadership.
|
||||||
|
|
||||||
|
## Attribution
|
||||||
|
|
||||||
|
This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4,
|
||||||
|
available at https://www.contributor-covenant.org/version/1/4/code-of-conduct.html
|
||||||
|
|
||||||
|
[homepage]: https://www.contributor-covenant.org
|
||||||
|
|
||||||
|
For answers to common questions about this code of conduct, see
|
||||||
|
https://www.contributor-covenant.org/faq
|
||||||
@@ -1,12 +1,15 @@
|
|||||||
<p align="center">
|
<p align="center">
|
||||||
<a href="https://docs.justauth.whnb.wang"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/logo.png" width="400"></a>
|
<a href="https://justauth.wiki"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/Justauth.png" width="400"></a>
|
||||||
</p>
|
</p>
|
||||||
<p align="center">
|
<p align="center">
|
||||||
<strong>Login, so easy.</strong>
|
<strong>Login, so easy.</strong>
|
||||||
</p>
|
</p>
|
||||||
<p align="center">
|
<p align="center">
|
||||||
<a target="_blank" href="https://search.maven.org/search?q=JustAuth">
|
<a target="_blank" href="https://search.maven.org/search?q=JustAuth">
|
||||||
<img src="https://img.shields.io/badge/Maven Central-1.14.0-blue.svg" ></img>
|
<img src="https://img.shields.io/github/v/release/justauth/JustAuth?style=flat-square" ></img>
|
||||||
|
</a>
|
||||||
|
<a target="_blank" href="https://oss.sonatype.org/content/repositories/snapshots/me/zhyd/oauth/JustAuth/">
|
||||||
|
<img src="https://img.shields.io/nexus/s/https/oss.sonatype.org/me.zhyd.oauth/JustAuth.svg?style=flat-square" ></img>
|
||||||
</a>
|
</a>
|
||||||
<a target="_blank" href="https://gitee.com/yadong.zhang/JustAuth/blob/master/LICENSE">
|
<a target="_blank" href="https://gitee.com/yadong.zhang/JustAuth/blob/master/LICENSE">
|
||||||
<img src="https://img.shields.io/apm/l/vim-mode.svg?color=yellow" ></img>
|
<img src="https://img.shields.io/apm/l/vim-mode.svg?color=yellow" ></img>
|
||||||
@@ -14,65 +17,24 @@
|
|||||||
<a target="_blank" href="https://www.oracle.com/technetwork/java/javase/downloads/index.html">
|
<a target="_blank" href="https://www.oracle.com/technetwork/java/javase/downloads/index.html">
|
||||||
<img src="https://img.shields.io/badge/JDK-1.8+-green.svg" ></img>
|
<img src="https://img.shields.io/badge/JDK-1.8+-green.svg" ></img>
|
||||||
</a>
|
</a>
|
||||||
<a target="_blank" href="https://apidoc.gitee.com/yadong.zhang/JustAuth/" title="API文档">
|
<a target="_blank" href="https://justauth.wiki" title="参考文档">
|
||||||
<img src="https://img.shields.io/badge/Api Docs-1.14.0-orange.svg" ></img>
|
|
||||||
</a>
|
|
||||||
<a target="_blank" href="https://docs.justauth.whnb.wang" title="参考文档">
|
|
||||||
<img src="https://img.shields.io/badge/Docs-latest-blueviolet.svg" ></img>
|
<img src="https://img.shields.io/badge/Docs-latest-blueviolet.svg" ></img>
|
||||||
</a>
|
</a>
|
||||||
<a href="https://codecov.io/gh/zhangyd-c/JustAuth">
|
<a href="https://codecov.io/gh/justauth/JustAuth">
|
||||||
<img src="https://codecov.io/gh/zhangyd-c/JustAuth/branch/master/graph/badge.svg" />
|
<img src="https://codecov.io/gh/justauth/JustAuth/branch/master/graph/badge.svg?token=zYiAqd9aFz" />
|
||||||
</a>
|
</a>
|
||||||
<a href='https://gitee.com/yadong.zhang/JustAuth/stargazers'>
|
<a href='https://gitee.com/yadong.zhang/JustAuth/stargazers'>
|
||||||
<img src='https://gitee.com/yadong.zhang/JustAuth/badge/star.svg?theme=white' alt='star'></img>
|
<img src='https://gitee.com/yadong.zhang/JustAuth/badge/star.svg?theme=gvp' alt='star'></img>
|
||||||
</a>
|
</a>
|
||||||
<a target="_blank" href='https://github.com/zhangyd-c/JustAuth'>
|
<a target="_blank" href='https://github.com/zhangyd-c/JustAuth'>
|
||||||
<img src="https://img.shields.io/github/stars/zhangyd-c/JustAuth.svg?style=social" alt="github star"></img>
|
<img src="https://img.shields.io/github/stars/zhangyd-c/JustAuth.svg?style=social" alt="github star"></img>
|
||||||
</a>
|
</a>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<center>
|
-------------------------------------------------------------------------------
|
||||||
<table>
|
<p align="center">
|
||||||
<tr>
|
<img src='./docs/media/75a3c076.png' alt='star'></img>
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/gitee.png" width="20"></td>
|
</p>
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/github.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/weibo.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/dingtalk.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/baidu.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/coding.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/tencentCloud.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/oschina.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/alipay.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/qq.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/wechat.png" width="20" title="微信开放平台"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/taobao.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/google.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/facebook.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/douyin.png" width="20"></td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
<table>
|
|
||||||
<tr>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/linkedin.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/microsoft.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/mi.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/toutiao.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/teambition.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/renren.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/pinterest.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/stackoverflow.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/huawei.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/wechat.png" width="20" title="微信企业版"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/csdn.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/kujiale.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/gitlab.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/meituan.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/eleme.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/twitter.png" width="20"></td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
<center><a href="https://docs.justauth.whnb.wang/#/?id=%E5%B7%B2%E9%9B%86%E6%88%90%E7%9A%84%E5%B9%B3%E5%8F%B0" target="_blank">查看更多</a></center>
|
|
||||||
</center>
|
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
|
|
||||||
@@ -81,7 +43,7 @@
|
|||||||
`JustAuth`, as you see, It is just a Java library of third-party authorized login, It's smaller and easier to use. JustAuth is the best third-party login tool written in JAVA.
|
`JustAuth`, as you see, It is just a Java library of third-party authorized login, It's smaller and easier to use. JustAuth is the best third-party login tool written in JAVA.
|
||||||
|
|
||||||
Source Code:[gitee](https://gitee.com/yadong.zhang/JustAuth) | [github](https://github.com/zhangyd-c/JustAuth)
|
Source Code:[gitee](https://gitee.com/yadong.zhang/JustAuth) | [github](https://github.com/zhangyd-c/JustAuth)
|
||||||
Docs:[Reference Doc](https://docs.justauth.whnb.wang)
|
Docs:[Reference Doc](https://justauth.wiki)
|
||||||
|
|
||||||
## Features
|
## Features
|
||||||
|
|
||||||
@@ -90,17 +52,63 @@ Docs:[Reference Doc](https://docs.justauth.whnb.wang)
|
|||||||
|
|
||||||
## Quick start
|
## Quick start
|
||||||
|
|
||||||
- Add maven dependency
|
### Add maven dependency
|
||||||
|
|
||||||
|
- Add JustAuth dependency
|
||||||
|
|
||||||
These artifacts are available from Maven Central:
|
These artifacts are available from Maven Central:
|
||||||
```xml
|
```xml
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>me.zhyd.oauth</groupId>
|
<groupId>me.zhyd.oauth</groupId>
|
||||||
<artifactId>JustAuth</artifactId>
|
<artifactId>JustAuth</artifactId>
|
||||||
<version>1.14.0</version>
|
<version>{latest-version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
```
|
```
|
||||||
- Using JustAuth
|
|
||||||
|
> **latest-version** :
|
||||||
|
> - CURRENT: 
|
||||||
|
> - SNAPSHOT: 
|
||||||
|
|
||||||
|
|
||||||
|
- Add http dependency(Only need one)
|
||||||
|
|
||||||
|
> If there is already in the project, please ignore it. In addition, you need to pay special attention. If the low version of the dependency has been introduced in the project, please exclude the low version of the dependency first, and then introduce the high version or the latest version of the dependency
|
||||||
|
|
||||||
|
- hutool-http
|
||||||
|
|
||||||
|
```xml
|
||||||
|
<dependency>
|
||||||
|
<groupId>cn.hutool</groupId>
|
||||||
|
<artifactId>hutool-http</artifactId>
|
||||||
|
<version>5.2.5</version>
|
||||||
|
</dependency>
|
||||||
|
```
|
||||||
|
|
||||||
|
- httpclient
|
||||||
|
|
||||||
|
```xml
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.apache.httpcomponents</groupId>
|
||||||
|
<artifactId>httpclient</artifactId>
|
||||||
|
<version>4.5.12</version>
|
||||||
|
</dependency>
|
||||||
|
```
|
||||||
|
|
||||||
|
- okhttp
|
||||||
|
|
||||||
|
```xml
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.squareup.okhttp3</groupId>
|
||||||
|
<artifactId>okhttp</artifactId>
|
||||||
|
<version>4.4.1</version>
|
||||||
|
</dependency>
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
### Using JustAuth API
|
||||||
|
|
||||||
|
#### Simple
|
||||||
|
|
||||||
```java
|
```java
|
||||||
// Create authorization request
|
// Create authorization request
|
||||||
AuthRequest authRequest = new AuthGiteeRequest(AuthConfig.builder()
|
AuthRequest authRequest = new AuthGiteeRequest(AuthConfig.builder()
|
||||||
@@ -108,62 +116,55 @@ AuthRequest authRequest = new AuthGiteeRequest(AuthConfig.builder()
|
|||||||
.clientSecret("clientSecret")
|
.clientSecret("clientSecret")
|
||||||
.redirectUri("redirectUri")
|
.redirectUri("redirectUri")
|
||||||
.build());
|
.build());
|
||||||
// Generate authorization url
|
// Generate authorization page url
|
||||||
authRequest.authorize("state");
|
authRequest.authorize("state");
|
||||||
// After authorization to login, it will return: code(auth_code(Alipay only)),state, After version 1.8.0, you can use the AuthCallback as a parameter to the callback interface
|
// Get token and userinfo
|
||||||
// Note: JustAuth saves state for 3 minutes by default. If it is not used within 3 minutes, the expired state will be cleared automatically.
|
|
||||||
authRequest.login(callback);
|
authRequest.login(callback);
|
||||||
```
|
```
|
||||||
|
|
||||||
**Examples**:
|
#### Builder 1. Use unchanging `AuthConfig`
|
||||||
- [Springboot Example](https://github.com/justauth/JustAuth-demo)
|
|
||||||
- [jFinal Example](https://github.com/xkcoding/jfinal-justauth-demo): by [xkcoding](https://github.com/xkcoding)
|
|
||||||
- [ActFramework Example](https://github.com/xkcoding/act-justauth-demo): by [xkcoding](https://github.com/xkcoding)
|
|
||||||
- [Nutzboot Example](https://github.com/EggsBlue/nutzboot-justauth-demo): by [蛋蛋](https://github.com/EggsBlue)
|
|
||||||
- [Blade Example](https://github.com/justauth/blade-justauth-demo)
|
|
||||||
|
|
||||||
**Springboot Starter**
|
```java
|
||||||
|
// Create authorization request
|
||||||
|
AuthRequest authRequest = AuthRequestBuilder.builder()
|
||||||
|
.source("github")
|
||||||
|
.authConfig(AuthConfig.builder()
|
||||||
|
.clientId("clientId")
|
||||||
|
.clientSecret("clientSecret")
|
||||||
|
.redirectUri("redirectUri")
|
||||||
|
.build())
|
||||||
|
.build();
|
||||||
|
```
|
||||||
|
|
||||||
- [justauth-spring-boot-starter](https://github.com/xkcoding/justauth-spring-boot-starter): Spring Boot integrates best practices with JustAuth by [xkcoding](https://github.com/xkcoding)
|
#### Builder 2. Use dynamic `AuthConfig`
|
||||||
- [justauth-spring-boot-starter-demo](https://github.com/justauth/justauth-spring-boot-starter-demo): Justauth-spring-boot-starter demo project by [xkcoding](https://github.com/xkcoding)
|
|
||||||
|
|
||||||
#### API
|
```java
|
||||||
| :computer: platform | :coffee: API | :page_facing_up: Official document |
|
// Create authorization request
|
||||||
|:------:|:-------:|:-------:|
|
AuthRequest authRequest = AuthRequestBuilder.builder()
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/gitee.png" width="20"> | [AuthGiteeRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthGiteeRequest.java) | <a href="https://gitee.com/api/v5/oauth_doc#list_1" target="_blank">参考文档</a> |
|
.source("gitee")
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/github.png" width="20"> | [AuthGithubRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthGithubRequest.java) | <a href="https://developer.github.com/apps/building-oauth-apps/authorizing-oauth-apps/" target="_blank">参考文档</a> |
|
.authConfig((source) -> {
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/weibo.png" width="20"> | [AuthWeiboRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthWeiboRequest.java) | <a href="https://open.weibo.com/wiki/%E6%8E%88%E6%9D%83%E6%9C%BA%E5%88%B6%E8%AF%B4%E6%98%8E" target="_blank">参考文档</a> |
|
// Use source to dynamically get AuthConfig
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/dingtalk.png" width="20"> | [AuthDingTalkRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthDingTalkRequest.java) | <a href="https://open-doc.dingtalk.com/microapp/serverapi2/kymkv6" target="_blank">参考文档</a> |
|
// Here you can flexibly take the configuration from sql or take the configuration from the configuration file
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/baidu.png" width="20"> | [AuthBaiduRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthBaiduRequest.java) | <a href="http://developer.baidu.com/wiki/index.php?title=docs/oauth" target="_blank">参考文档</a> |
|
return AuthConfig.builder()
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/coding.png" width="25"> | [AuthCodingRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthCodingRequest.java) | <a href="https://open.coding.net/references/oauth/" target="_blank">参考文档</a> |
|
.clientId("clientId")
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/tencentCloud.png" width="25"> | [AuthTencentCloudRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthTencentCloudRequest.java) | <a href="https://dev.tencent.com/help/doc/faq/b4e5b7aee786/oauth" target="_blank">参考文档</a> |
|
.clientSecret("clientSecret")
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/oschina.png" width="20"> | [AuthOschinaRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthOschinaRequest.java) | <a href="https://www.oschina.net/openapi/docs/oauth2_authorize" target="_blank">参考文档</a> |
|
.redirectUri("redirectUri")
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/alipay.png" width="20"> | [AuthAlipayRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthAlipayRequest.java) | <a href="https://alipay.open.taobao.com/docs/doc.htm?spm=a219a.7629140.0.0.336d4b70GUKXOl&treeId=193&articleId=105809&docType=1" target="_blank">参考文档</a> |
|
.build();
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/qq.png" width="20"> | [AuthQqRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthQqRequest.java) | <a href="https://wiki.connect.qq.com/%E4%BD%BF%E7%94%A8authorization_code%E8%8E%B7%E5%8F%96access_token" target="_blank">参考文档</a> |
|
})
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/wechat.png" width="20" title="微信开放平台"> | [AuthWeChatOpenRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthWeChatOpenRequest.java) | <a href="https://open.weixin.qq.com/cgi-bin/showdocument?action=dir_list&t=resource/res_list&verify=1&id=open1419316505&token=&lang=zh_CN" target="_blank">参考文档</a> |
|
.build();
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/wechat.png" width="20" title="微信公众平台"> | [AuthWeChatMpRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthWeChatMpRequest.java) | <a href="https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/Wechat_webpage_authorization.html" target="_blank">参考文档</a> |
|
```
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/wechat.png" width="20" title="企业微信"> | [AuthWeChatEnterpriseRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthWeChatEnterpriseRequest.java) | <a href="https://open.work.weixin.qq.com/api/doc#90000/90135/90664" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/taobao.png" width="20"> | [AuthTaobaoRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthTaobaoRequest.java) | <a href="https://open.taobao.com/doc.htm?spm=a219a.7386797.0.0.4e00669acnkQy6&source=search&docId=105590&docType=1" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/google.png" width="20"> | [AuthGoogleRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthGoogleRequest.java) | <a href="https://developers.google.com/identity/protocols/OpenIDConnect" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/facebook.png" width="20"> | [AuthFacebookRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthFacebookRequest.java) | <a href="https://developers.facebook.com/docs/facebook-login/manually-build-a-login-flow" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/douyin.png" width="20"> | [AuthDouyinRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthDouyinRequest.java) | <a href="https://www.douyin.com/platform/doc/m-2-1-1" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/linkedin.png" width="20"> | [AuthLinkedinRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthLinkedinRequest.java) | <a href="https://docs.microsoft.com/zh-cn/linkedin/shared/authentication/authorization-code-flow?context=linkedin/context" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/microsoft.png" width="20"> | [AuthMicrosoftRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthMicrosoftRequest.java) | <a href="https://docs.microsoft.com/zh-cn/graph/auth/" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/mi.png" width="20"> | [AuthMiRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthMiRequest.java) | <a href="https://dev.mi.com/console/doc/detail?pId=711" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/toutiao.png" width="20"> | [AuthToutiaoRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthToutiaoRequest.java) | <a href="https://open.mp.toutiao.com/#/resource?_k=y7mfgk" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/teambition.png" width="20"> | [AuthTeambitionRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthTeambitionRequest.java) | <a href="https://docs.teambition.com/" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/renren.png" width="20"> | [AuthRenrenRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthRenrenRequest.java) | <a href="http://open.renren.com/wiki/OAuth2.0" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/pinterest.png" width="20"> | [AuthPinterestRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthPinterestRequest.java) | <a href="https://developers.pinterest.com/docs/api/overview/?" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/stackoverflow.png" width="20"> | [AuthStackOverflowRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthStackOverflowRequest.java) | <a href="https://api.stackexchange.com/docs/authentication" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/huawei.png" width="20"> | [AuthHuaweiRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthHuaweiRequest.java) | <a href="https://developer.huawei.com/consumer/cn/devservice/doc/30101" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/kujiale.png" width="20"> | [AuthKujialeRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthKujialeRequest.java) | <a href="https://open.kujiale.com/open/apps/2/docs?doc_id=95" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/gitlab.png" width="20"> | [AuthGitlabRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthGitlabRequest.java) | <a href="https://docs.gitlab.com/ee/api/oauth2.html" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/meituan.png" width="20"> | [AuthMeituanRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthMeituanRequest.java) | <a href="http://open.waimai.meituan.com/openapi_docs/oauth/" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/eleme.png" width="20"> | [AuthElemeRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthElemeRequest.java) | <a href="https://open.shop.ele.me/openapi/documents/khd001" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/twitter.png" width="20"> | [AuthTwitterRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthTwitterRequest.java) | <a href="https://developer.twitter.com/en/docs/twitter-for-websites/log-in-with-twitter/guides/implementing-sign-in-with-twitter" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/csdn.png" width="20"> | [AuthCsdnRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthCsdnRequest.java) | 无 |
|
|
||||||
|
|
||||||
|
#### Builder 3. Support custom platform
|
||||||
|
|
||||||
|
```java
|
||||||
|
AuthRequest authRequest = AuthRequestBuilder.builder()
|
||||||
|
// Key point: configure the custom implementation of AuthSource
|
||||||
|
.extendSource(AuthExtendSource.values())
|
||||||
|
// Enum name in AuthExtendSource
|
||||||
|
.source("other")
|
||||||
|
// ... Do other things
|
||||||
|
.build();
|
||||||
|
```
|
||||||
|
|
||||||
## Contributions
|
## Contributions
|
||||||
|
|
||||||
@@ -179,7 +180,11 @@ I look forward to your joining us.
|
|||||||
|
|
||||||
## Contributors
|
## Contributors
|
||||||
|
|
||||||
[contributors](https://docs.justauth.whnb.wang/#/contributors)
|
[contributors](https://justauth.wiki/contributors.html)
|
||||||
|
|
||||||
|
## Change Logs
|
||||||
|
|
||||||
|
[CHANGELOGS](https://justauth.wiki/update.html)
|
||||||
|
|
||||||
## Recommend
|
## Recommend
|
||||||
|
|
||||||
|
|||||||
@@ -1,12 +1,15 @@
|
|||||||
<p align="center">
|
<p align="center">
|
||||||
<a href="https://docs.justauth.whnb.wang"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/logo.png" width="400"></a>
|
<a href="https://justauth.wiki"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/Justauth.png" width="400"></a>
|
||||||
</p>
|
</p>
|
||||||
<p align="center">
|
<p align="center">
|
||||||
<strong>Login, so easy.</strong>
|
<strong>Login, so easy.</strong>
|
||||||
</p>
|
</p>
|
||||||
<p align="center">
|
<p align="center">
|
||||||
<a target="_blank" href="https://search.maven.org/search?q=JustAuth">
|
<a target="_blank" href="https://search.maven.org/search?q=JustAuth">
|
||||||
<img src="https://img.shields.io/badge/Maven Central-1.14.0-blue.svg" ></img>
|
<img src="https://img.shields.io/github/v/release/justauth/JustAuth?style=flat-square" ></img>
|
||||||
|
</a>
|
||||||
|
<a target="_blank" href="https://oss.sonatype.org/content/repositories/snapshots/me/zhyd/oauth/JustAuth/">
|
||||||
|
<img src="https://img.shields.io/nexus/s/https/oss.sonatype.org/me.zhyd.oauth/JustAuth.svg?style=flat-square" ></img>
|
||||||
</a>
|
</a>
|
||||||
<a target="_blank" href="https://gitee.com/yadong.zhang/JustAuth/blob/master/LICENSE">
|
<a target="_blank" href="https://gitee.com/yadong.zhang/JustAuth/blob/master/LICENSE">
|
||||||
<img src="https://img.shields.io/apm/l/vim-mode.svg?color=yellow" ></img>
|
<img src="https://img.shields.io/apm/l/vim-mode.svg?color=yellow" ></img>
|
||||||
@@ -14,93 +17,132 @@
|
|||||||
<a target="_blank" href="https://www.oracle.com/technetwork/java/javase/downloads/index.html">
|
<a target="_blank" href="https://www.oracle.com/technetwork/java/javase/downloads/index.html">
|
||||||
<img src="https://img.shields.io/badge/JDK-1.8+-green.svg" ></img>
|
<img src="https://img.shields.io/badge/JDK-1.8+-green.svg" ></img>
|
||||||
</a>
|
</a>
|
||||||
<a target="_blank" href="https://apidoc.gitee.com/yadong.zhang/JustAuth/" title="API文档">
|
<a target="_blank" href="https://justauth.wiki" title="参考文档">
|
||||||
<img src="https://img.shields.io/badge/Api Docs-1.14.0-orange.svg" ></img>
|
|
||||||
</a>
|
|
||||||
<a target="_blank" href="https://docs.justauth.whnb.wang" title="参考文档">
|
|
||||||
<img src="https://img.shields.io/badge/Docs-latest-blueviolet.svg" ></img>
|
<img src="https://img.shields.io/badge/Docs-latest-blueviolet.svg" ></img>
|
||||||
</a>
|
</a>
|
||||||
<a href="https://codecov.io/gh/zhangyd-c/JustAuth">
|
<a href="https://codecov.io/gh/justauth/JustAuth">
|
||||||
<img src="https://codecov.io/gh/zhangyd-c/JustAuth/branch/master/graph/badge.svg" />
|
<img src="https://codecov.io/gh/justauth/JustAuth/branch/master/graph/badge.svg?token=zYiAqd9aFz" />
|
||||||
</a>
|
</a>
|
||||||
<a href='https://gitee.com/yadong.zhang/JustAuth/stargazers'>
|
<a href='https://gitee.com/yadong.zhang/JustAuth/stargazers'>
|
||||||
<img src='https://gitee.com/yadong.zhang/JustAuth/badge/star.svg?theme=white' alt='star'></img>
|
<img src='https://gitee.com/yadong.zhang/JustAuth/badge/star.svg?theme=gvp' alt='star'></img>
|
||||||
</a>
|
</a>
|
||||||
<a target="_blank" href='https://github.com/zhangyd-c/JustAuth'>
|
<a target="_blank" href='https://github.com/zhangyd-c/JustAuth'>
|
||||||
<img src="https://img.shields.io/github/stars/zhangyd-c/JustAuth.svg?style=social" alt="github star"></img>
|
<img src="https://img.shields.io/github/stars/zhangyd-c/JustAuth.svg?style=social" alt="github star"></img>
|
||||||
</a>
|
</a>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<center>
|
-------------------------------------------------------------------------------
|
||||||
<table>
|
<p align="center">
|
||||||
<tr>
|
<img src='./docs/media/75a3c076.png' alt='star'></img>
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/gitee.png" width="20"></td>
|
</p>
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/github.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/weibo.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/dingtalk.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/baidu.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/coding.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/tencentCloud.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/oschina.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/alipay.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/qq.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/wechat.png" width="20" title="微信开放平台"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/taobao.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/google.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/facebook.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/douyin.png" width="20"></td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
<table>
|
|
||||||
<tr>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/linkedin.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/microsoft.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/mi.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/toutiao.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/teambition.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/renren.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/pinterest.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/stackoverflow.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/huawei.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/wechat.png" width="20" title="微信企业版"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/csdn.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/kujiale.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/gitlab.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/meituan.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/eleme.png" width="20"></td>
|
|
||||||
<td align="center" width="200"><img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/twitter.png" width="20"></td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
<center><a href="https://docs.justauth.whnb.wang/#/?id=%E5%B7%B2%E9%9B%86%E6%88%90%E7%9A%84%E5%B9%B3%E5%8F%B0" target="_blank">查看更多</a></center>
|
|
||||||
</center>
|
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
QQ 群:230017570
|
||||||
|
微信群:justauth (备注`justauth`或者`ja`)
|
||||||
|
帮助文档:[justauth.wiki](https://justauth.wiki)
|
||||||
|
|
||||||
|
## 什么是 JustAuth?
|
||||||
|
|
||||||
JustAuth,如你所见,它仅仅是一个**第三方授权登录**的**工具类库**,它可以让我们脱离繁琐的第三方登录SDK,让登录变得**So easy!**
|
JustAuth,如你所见,它仅仅是一个**第三方授权登录**的**工具类库**,它可以让我们脱离繁琐的第三方登录 SDK,让登录变得**So easy!**
|
||||||
|
|
||||||
项目开源地址:[gitee](https://gitee.com/yadong.zhang/JustAuth) | [github](https://github.com/zhangyd-c/JustAuth)
|
JustAuth 集成了诸如:Github、Gitee、支付宝、新浪微博、微信、Google、Facebook、Twitter、StackOverflow等国内外数十家第三方平台。更多请参考<a href="https://justauth.wiki" target="_blank">已集成的平台</a>
|
||||||
项目文档:[参考文档](https://docs.justauth.whnb.wang)
|
|
||||||
|
|
||||||
## 特点
|
## 有哪些特点?
|
||||||
|
|
||||||
废话不多说,就俩字:
|
|
||||||
|
|
||||||
1. **全**:已集成十多家第三方平台(国内外常用的基本都已包含),仍然还在持续扩展中([开发计划](https://gitee.com/yadong.zhang/JustAuth/issues/IUGRK))!
|
1. **全**:已集成十多家第三方平台(国内外常用的基本都已包含),仍然还在持续扩展中([开发计划](https://gitee.com/yadong.zhang/JustAuth/issues/IUGRK))!
|
||||||
2. **简**:API就是奔着最简单去设计的(见后面`快速开始`),尽量让您用起来没有障碍感!
|
2. **简**:API就是奔着最简单去设计的(见后面`快速开始`),尽量让您用起来没有障碍感!
|
||||||
|
|
||||||
|
## 有哪些功能?
|
||||||
|
|
||||||
|
- 集成国内外数十家第三方平台,实现快速接入。<a href="https://justauth.wiki/quickstart/how-to-use.html" target="_blank">参考文档</a>
|
||||||
|
- 自定义 State 缓存,支持各种分布式缓存组件。<a href="https://justauth.wiki/features/customize-the-state-cache.html" target="_blank">参考文档</a>
|
||||||
|
- 自定义 OAuth 平台,更容易适配自有的 OAuth 服务。<a href="https://justauth.wiki/features/customize-the-oauth.html" target="_blank">参考文档</a>
|
||||||
|
- 自定义 Http 实现,选择权完全交给开发者,不会单独依赖某一具体实现。<a href="https://justauth.wiki/quickstart/how-to-use.html#%E4%BD%BF%E7%94%A8%E6%96%B9%E5%BC%8F" target="_blank">参考文档</a>
|
||||||
|
- 自定义 Scope,支持更完善的授权体系。<a href="https://justauth.wiki/features/customize-scopes.html" target="_blank">参考文档</a>
|
||||||
|
- 更多...<a href="https://justauth.wiki" target="_blank">参考文档</a>
|
||||||
|
|
||||||
## 快速开始
|
## 快速开始
|
||||||
|
|
||||||
- 引入依赖
|
### 引入依赖
|
||||||
```xml
|
```xml
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>me.zhyd.oauth</groupId>
|
<groupId>me.zhyd.oauth</groupId>
|
||||||
<artifactId>JustAuth</artifactId>
|
<artifactId>JustAuth</artifactId>
|
||||||
<version>1.14.0</version>
|
<version>{latest-version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
```
|
```
|
||||||
- 调用api
|
|
||||||
|
> **latest-version** 可选:
|
||||||
|
> - 稳定版:
|
||||||
|
> - 快照版:
|
||||||
|
> > 注意:快照版本是功能的尝鲜,并不保证稳定性。请勿在生产环境中使用。
|
||||||
|
>
|
||||||
|
> <details>
|
||||||
|
> <summary>如何引入快照版本</summary>
|
||||||
|
>
|
||||||
|
> JustAuth 的快照版本托管在 ossrh 上,所以要指定下载地址。
|
||||||
|
>
|
||||||
|
> ```xml
|
||||||
|
> <repositories>
|
||||||
|
> <repository>
|
||||||
|
> <id>ossrh-snapshot</id>
|
||||||
|
> <url>https://oss.sonatype.org/content/repositories/snapshots</url>
|
||||||
|
> <snapshots>
|
||||||
|
> <enabled>true</enabled>
|
||||||
|
> </snapshots>
|
||||||
|
> </repository>
|
||||||
|
> </repositories>
|
||||||
|
> ```
|
||||||
|
>
|
||||||
|
> 如果你想第一时间获取 JustAuth 的最新快照,可以添加下列代码,每次构建时都检查是否有最新的快照(默认每天检查)。
|
||||||
|
>
|
||||||
|
> ```diff
|
||||||
|
> <url>https://oss.sonatype.org/content/repositories/snapshots</url>
|
||||||
|
> <snapshots>
|
||||||
|
> + <updatePolicy>always</updatePolicy>
|
||||||
|
> <enabled>true</enabled>
|
||||||
|
> </snapshots>
|
||||||
|
> ```
|
||||||
|
>
|
||||||
|
> </details>
|
||||||
|
|
||||||
|
如下**任选一种** HTTP 工具 依赖,_项目内如果已有,请忽略。另外需要特别注意,如果项目中已经引入了低版本的依赖,请先排除低版本依赖后,再引入高版本或者最新版本的依赖_
|
||||||
|
|
||||||
|
- hutool-http
|
||||||
|
|
||||||
|
```xml
|
||||||
|
<dependency>
|
||||||
|
<groupId>cn.hutool</groupId>
|
||||||
|
<artifactId>hutool-http</artifactId>
|
||||||
|
<version>5.7.7</version>
|
||||||
|
</dependency>
|
||||||
|
```
|
||||||
|
|
||||||
|
- httpclient
|
||||||
|
|
||||||
|
```xml
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.apache.httpcomponents</groupId>
|
||||||
|
<artifactId>httpclient</artifactId>
|
||||||
|
<version>4.5.13</version>
|
||||||
|
</dependency>
|
||||||
|
```
|
||||||
|
|
||||||
|
- okhttp
|
||||||
|
|
||||||
|
```xml
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.squareup.okhttp3</groupId>
|
||||||
|
<artifactId>okhttp</artifactId>
|
||||||
|
<version>4.9.1</version>
|
||||||
|
</dependency>
|
||||||
|
```
|
||||||
|
|
||||||
|
### 调用api
|
||||||
|
|
||||||
|
#### 普通方式
|
||||||
|
|
||||||
```java
|
```java
|
||||||
// 创建授权request
|
// 创建授权request
|
||||||
AuthRequest authRequest = new AuthGiteeRequest(AuthConfig.builder()
|
AuthRequest authRequest = new AuthGiteeRequest(AuthConfig.builder()
|
||||||
@@ -115,116 +157,113 @@ authRequest.authorize("state");
|
|||||||
authRequest.login(callback);
|
authRequest.login(callback);
|
||||||
```
|
```
|
||||||
|
|
||||||
**配套Demo**:
|
#### Builder 方式一
|
||||||
- [JustAuth-demo](https://github.com/justauth/JustAuth-demo)
|
|
||||||
- [jFinal版](https://github.com/xkcoding/jfinal-justauth-demo): Jfinal集成JustAuth的demo by [xkcoding](https://github.com/xkcoding)
|
|
||||||
- [ActFramework版](https://github.com/xkcoding/act-justauth-demo): ActFramework 集成 JustAuth 的 demo by [xkcoding](https://github.com/xkcoding)
|
|
||||||
- [Nutzboot版](https://github.com/EggsBlue/nutzboot-justauth-demo): NutzBoot集成JustAuth的demo by [蛋蛋](https://github.com/EggsBlue)
|
|
||||||
- [Blade版](https://github.com/justauth/blade-justauth-demo): Blade集成JustAuth的demo
|
|
||||||
|
|
||||||
## 插件
|
静态配置 `AuthConfig`
|
||||||
- [justauth-spring-boot-starter](https://github.com/xkcoding/justauth-spring-boot-starter): Spring Boot 集成 JustAuth 的最佳实践 by [xkcoding](https://github.com/xkcoding)
|
|
||||||
- [justauth-spring-boot-starter-demo](https://github.com/justauth/justauth-spring-boot-starter-demo): Spring Boot 使用 justauth-spring-boot-starter 快速集成 JustAuth by [xkcoding](https://github.com/xkcoding)
|
|
||||||
|
|
||||||
具体的例子可以参考:
|
```java
|
||||||
|
AuthRequest authRequest = AuthRequestBuilder.builder()
|
||||||
|
.source("github")
|
||||||
|
.authConfig(AuthConfig.builder()
|
||||||
|
.clientId("clientId")
|
||||||
|
.clientSecret("clientSecret")
|
||||||
|
.redirectUri("redirectUri")
|
||||||
|
.build())
|
||||||
|
.build();
|
||||||
|
// 生成授权页面
|
||||||
|
authRequest.authorize("state");
|
||||||
|
// 授权登录后会返回code(auth_code(仅限支付宝))、state,1.8.0版本后,可以用AuthCallback类作为回调接口的参数
|
||||||
|
// 注:JustAuth默认保存state的时效为3分钟,3分钟内未使用则会自动清除过期的state
|
||||||
|
authRequest.login(callback);
|
||||||
|
```
|
||||||
|
|
||||||
- [实现Gitee授权登录](http://t.cn/ExDKxQs)
|
#### Builder 方式二
|
||||||
- [实现Github授权登录](http://t.cn/EJ0Fxqo)
|
|
||||||
- [Spring Boot 快速集成第三方登录功能](http://t.cn/AiWWx5kH) : QQ、Github、微信、谷歌、微软、小米、企业微信
|
|
||||||
- [集成企业微信](https://mp.weixin.qq.com/s?__biz=MzA3NDk3OTIwMg==&mid=2450633170&idx=2&sn=456b70742a86948a193c691f3e47b72e&chksm=8892933fbfe51a29c1da386a2252d4bf91bfbd14e1ac0b99b783763a0d12e2e4b2d7c4369933&token=482455242&lang=zh_CN#rd)
|
|
||||||
|
|
||||||
#### API列表
|
动态获取并配置 `AuthConfig`
|
||||||
| :computer: 平台 | :coffee: API类 | :page_facing_up: SDK |
|
|
||||||
|:------:|:-------:|:-------:|
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/gitee.png" width="20"> | [AuthGiteeRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthGiteeRequest.java) | <a href="https://gitee.com/api/v5/oauth_doc#list_1" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/github.png" width="20"> | [AuthGithubRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthGithubRequest.java) | <a href="https://developer.github.com/apps/building-oauth-apps/authorizing-oauth-apps/" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/weibo.png" width="20"> | [AuthWeiboRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthWeiboRequest.java) | <a href="https://open.weibo.com/wiki/%E6%8E%88%E6%9D%83%E6%9C%BA%E5%88%B6%E8%AF%B4%E6%98%8E" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/dingtalk.png" width="20"> | [AuthDingTalkRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthDingTalkRequest.java) | <a href="https://open-doc.dingtalk.com/microapp/serverapi2/kymkv6" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/baidu.png" width="20"> | [AuthBaiduRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthBaiduRequest.java) | <a href="http://developer.baidu.com/wiki/index.php?title=docs/oauth" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/coding.png" width="25"> | [AuthCodingRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthCodingRequest.java) | <a href="https://open.coding.net/references/oauth/" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/tencentCloud.png" width="25"> | [AuthTencentCloudRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthTencentCloudRequest.java) | <a href="https://dev.tencent.com/help/doc/faq/b4e5b7aee786/oauth" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/oschina.png" width="20"> | [AuthOschinaRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthOschinaRequest.java) | <a href="https://www.oschina.net/openapi/docs/oauth2_authorize" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/alipay.png" width="20"> | [AuthAlipayRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthAlipayRequest.java) | <a href="https://alipay.open.taobao.com/docs/doc.htm?spm=a219a.7629140.0.0.336d4b70GUKXOl&treeId=193&articleId=105809&docType=1" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/qq.png" width="20"> | [AuthQqRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthQqRequest.java) | <a href="https://wiki.connect.qq.com/%E4%BD%BF%E7%94%A8authorization_code%E8%8E%B7%E5%8F%96access_token" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/wechat.png" width="20" title="微信开放平台"> | [AuthWeChatOpenRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthWeChatOpenRequest.java) | <a href="https://open.weixin.qq.com/cgi-bin/showdocument?action=dir_list&t=resource/res_list&verify=1&id=open1419316505&token=&lang=zh_CN" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/wechat.png" width="20" title="微信公众平台"> | [AuthWeChatMpRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthWeChatMpRequest.java) | <a href="https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/Wechat_webpage_authorization.html" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/wechat.png" width="20" title="企业微信"> | [AuthWeChatEnterpriseRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthWeChatEnterpriseRequest.java) | <a href="https://open.work.weixin.qq.com/api/doc#90000/90135/90664" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/taobao.png" width="20"> | [AuthTaobaoRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthTaobaoRequest.java) | <a href="https://open.taobao.com/doc.htm?spm=a219a.7386797.0.0.4e00669acnkQy6&source=search&docId=105590&docType=1" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/google.png" width="20"> | [AuthGoogleRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthGoogleRequest.java) | <a href="https://developers.google.com/identity/protocols/OpenIDConnect" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/facebook.png" width="20"> | [AuthFacebookRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthFacebookRequest.java) | <a href="https://developers.facebook.com/docs/facebook-login/manually-build-a-login-flow" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/douyin.png" width="20"> | [AuthDouyinRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthDouyinRequest.java) | <a href="https://www.douyin.com/platform/doc/m-2-1-1" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/linkedin.png" width="20"> | [AuthLinkedinRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthLinkedinRequest.java) | <a href="https://docs.microsoft.com/zh-cn/linkedin/shared/authentication/authorization-code-flow?context=linkedin/context" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/microsoft.png" width="20"> | [AuthMicrosoftRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthMicrosoftRequest.java) | <a href="https://docs.microsoft.com/zh-cn/graph/auth/" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/mi.png" width="20"> | [AuthMiRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthMiRequest.java) | <a href="https://dev.mi.com/console/doc/detail?pId=711" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/toutiao.png" width="20"> | [AuthToutiaoRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthToutiaoRequest.java) | <a href="https://open.mp.toutiao.com/#/resource?_k=y7mfgk" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/teambition.png" width="20"> | [AuthTeambitionRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthTeambitionRequest.java) | <a href="https://docs.teambition.com/" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/renren.png" width="20"> | [AuthRenrenRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthRenrenRequest.java) | <a href="http://open.renren.com/wiki/OAuth2.0" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/pinterest.png" width="20"> | [AuthPinterestRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthPinterestRequest.java) | <a href="https://developers.pinterest.com/docs/api/overview/?" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/stackoverflow.png" width="20"> | [AuthStackOverflowRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthStackOverflowRequest.java) | <a href="https://api.stackexchange.com/docs/authentication" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/huawei.png" width="20"> | [AuthHuaweiRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthHuaweiRequest.java) | <a href="https://developer.huawei.com/consumer/cn/devservice/doc/30101" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/kujiale.png" width="20"> | [AuthKujialeRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthKujialeRequest.java) | <a href="https://open.kujiale.com/open/apps/2/docs?doc_id=95" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/gitlab.png" width="20"> | [AuthGitlabRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthGitlabRequest.java) | <a href="https://docs.gitlab.com/ee/api/oauth2.html" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/meituan.png" width="20"> | [AuthMeituanRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthMeituanRequest.java) | <a href="http://open.waimai.meituan.com/openapi_docs/oauth/" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/eleme.png" width="20"> | [AuthElemeRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthElemeRequest.java) | <a href="https://open.shop.ele.me/openapi/documents/khd001" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/twitter.png" width="20"> | [AuthTwitterRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthTwitterRequest.java) | <a href="https://developer.twitter.com/en/docs/twitter-for-websites/log-in-with-twitter/guides/implementing-sign-in-with-twitter" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/csdn.png" width="20"> | [AuthCsdnRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthCsdnRequest.java) | 无 |
|
|
||||||
|
|
||||||
_请知悉:经咨询CSDN官方客服得知,CSDN的授权开放平台已经下线。如果以前申请过的应用,可以继续使用,但是不再支持申请新的应用。so, 本项目中的CSDN登录只能针对少部分用户使用了_
|
```java
|
||||||
|
AuthRequest authRequest = AuthRequestBuilder.builder()
|
||||||
|
.source("gitee")
|
||||||
|
.authConfig((source) -> {
|
||||||
|
// 通过 source 动态获取 AuthConfig
|
||||||
|
// 此处可以灵活的从 sql 中取配置也可以从配置文件中取配置
|
||||||
|
return AuthConfig.builder()
|
||||||
|
.clientId("clientId")
|
||||||
|
.clientSecret("clientSecret")
|
||||||
|
.redirectUri("redirectUri")
|
||||||
|
.build();
|
||||||
|
})
|
||||||
|
.build();
|
||||||
|
Assert.assertTrue(authRequest instanceof AuthGiteeRequest);
|
||||||
|
System.out.println(authRequest.authorize(AuthStateUtils.createState()));
|
||||||
|
```
|
||||||
|
|
||||||
## 后续开发计划
|
#### Builder 方式支持自定义的平台
|
||||||
|
|
||||||
参考:[[开发计划] 待扩展的第三方平台](https://gitee.com/yadong.zhang/JustAuth/issues/IUGRK)
|
```java
|
||||||
|
AuthRequest authRequest = AuthRequestBuilder.builder()
|
||||||
|
// 关键点:将自定义实现的 AuthSource 配置上
|
||||||
|
.extendSource(AuthExtendSource.values())
|
||||||
|
// source 对应 AuthExtendSource 中的枚举 name
|
||||||
|
.source("other")
|
||||||
|
// ... 其他内容不变,参考上面的示例
|
||||||
|
.build();
|
||||||
|
```
|
||||||
|
|
||||||
另外,期待您和我一起完善这个项目!
|
## 赞助和支持
|
||||||
|
|
||||||
## 贡献代码
|
感谢以下赞助商的支持:
|
||||||
|
|
||||||
1. fork本项目到自己的repo
|
[我要赞助](https://justauth.wiki/sponsor.html)
|
||||||
2. 把fork过去的项目也就是你仓库中的项目clone到你的本地
|
|
||||||
3. 修改代码
|
|
||||||
4. commit后push到自己的库
|
|
||||||
5. 发起PR(pull request) 请求,提交到`dev`分支
|
|
||||||
6. 等待作者合并
|
|
||||||
|
|
||||||
## 贡献者名单
|
## JustAuth 的用户
|
||||||
|
有很多公司、组织和个人把 JustAuth 用于学习、研究、生产环境和商业产品中,包括(但不限于):
|
||||||
|
|
||||||
[contributors](https://docs.justauth.whnb.wang/#/contributors)
|
[](https://www.mochiwang.com "给作者提供云写作的一个工具")
|
||||||
|
|
||||||
## 致谢
|

|
||||||
|
|
||||||
在项目立项初期,也对当前开源圈的一些相同类型的项目作过调研,同时本项目也参考过这些项目,再次感谢开源圈内的朋友。
|
|
||||||
|
|
||||||
- [YurunOAuthLogin](https://gitee.com/yurunsoft/YurunOAuthLogin): PHP 第三方登录授权 SDK
|
|
||||||
- [阿里妈妈MUX倾力打造的矢量图标库-iconfont](https://www.iconfont.cn/search/index): 本文档中的图标大部分取自该平台
|
怎么没有我?[登记](https://gitee.com/yadong.zhang/JustAuth/issues/IZ2T7)
|
||||||
- [mica](https://github.com/lets-mica/mica):Spring Cloud 微服务开发核心包,支持 `web `和 `webflux`。注:JustAuth项目中的[UuidUtils](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/utils/UuidUtils.java)就是直接使用的mica提供的高性能的uuid创建工具类源码[StringUtil.java](https://github.com/lets-mica/mica/blob/master/mica-core/src/main/java/net/dreamlu/mica/core/utils/StringUtil.java#L335)
|
|
||||||
- 感谢 JetBrains 提供的免费开源 License:
|
|
||||||
<img src="https://github.com/lets-mica/mica/raw/c251e176b81518a6a570bf4eb21f525c4f582a81/docs/img/jetbrains.png" alt="图片引用自lets-mica" style="float:left;">
|
|
||||||
|
|
||||||
## 开源推荐
|
## 开源推荐
|
||||||
|
|
||||||
|
- `JAP` 开源的登录认证中间件: [https://gitee.com/fujieid/jap](https://gitee.com/fujieid/jap)
|
||||||
- `spring-boot-demo` 深度学习并实战 spring boot 的项目: [https://github.com/xkcoding/spring-boot-demo](https://github.com/xkcoding/spring-boot-demo)
|
- `spring-boot-demo` 深度学习并实战 spring boot 的项目: [https://github.com/xkcoding/spring-boot-demo](https://github.com/xkcoding/spring-boot-demo)
|
||||||
- `mica` SpringBoot 微服务高效开发工具集: [https://github.com/lets-mica/mica](https://github.com/lets-mica/mica)
|
- `mica` SpringBoot 微服务高效开发工具集: [https://github.com/lets-mica/mica](https://github.com/lets-mica/mica)
|
||||||
- `pig` 宇宙最强微服务认证授权脚手架(架构师必备): [https://gitee.com/log4j/pig](https://gitee.com/log4j/pig)
|
- `sureness` 面向restful api的高性能认证鉴权框架:[sureness](https://github.com/usthe/sureness)
|
||||||
- `SpringBlade` 完整的线上解决方案(企业开发必备): https://gitee.com/smallc/SpringBlade
|
|
||||||
|
更多推荐,请参考:[JustAuth - 开源推荐](https://justauth.wiki)
|
||||||
|
|
||||||
## 关于OAuth
|
## 鸣谢
|
||||||
|
|
||||||
- [The OAuth 2.0 Authorization Framework](https://tools.ietf.org/html/rfc6749)
|
- 感谢 JetBrains 提供的免费开源 License:
|
||||||
- [OAuth 2.0](https://oauth.net/2/)
|
|
||||||
|
|
||||||
## 关注&交流
|
<p>
|
||||||
|
<img src="https://images.gitee.com/uploads/images/2020/0406/220236_f5275c90_5531506.png" alt="图片引用自lets-mica" style="float:left;">
|
||||||
|
</p>
|
||||||
|
|
||||||
| 公众号 | 微信(备注:加群) |
|
## 其他
|
||||||
| :------------: | :------------: |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/wx/wechat_account.jpg" width="200" /> | <img src="https://gitee.com/yadong.zhang/static/raw/master/wx/wx.png" width="170"/> |
|
|
||||||
|
|
||||||
**QQ群**
|
- [CONTRIBUTORS](https://justauth.wiki/contributors.html)
|
||||||
|
- [CHANGELOGS](https://justauth.wiki/update.html)
|
||||||
|
- [PLAN](https://gitee.com/yadong.zhang/JustAuth/issues/IUGRK)
|
||||||
|
|
||||||
- JustAuth交流群 (230017570):专业交流该项目
|
## 贡献者列表
|
||||||
|
|
||||||
- 开源总群 (190886500):各个开源项目的都有,也有博客建设等方面的朋友。
|
[](https://whnb.wang)
|
||||||
|
|
||||||
## 请喝咖啡
|
## Stars 趋势
|
||||||
|
|
||||||
| 支付宝 | 微信 |
|
### Gitee
|
||||||
| :------------: | :------------: |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/qrcode/zfb_code.png" width="200"/> | <img src="https://gitee.com/yadong.zhang/static/raw/master/qrcode/wx_code.png" width="200" /> |
|
[](https://whnb.wang/yadong.zhang/JustAuth?e=604800)
|
||||||
|
|
||||||
|
### Github
|
||||||
|
|
||||||
|
[](https://starchart.cc/justauth/JustAuth)
|
||||||
|
|
||||||
|
### ProductHunt
|
||||||
|
|
||||||
|
<a href="https://www.producthunt.com/posts/justauth?utm_source=badge-featured&utm_medium=badge&utm_souce=badge-justauth" target="_blank"><img src="https://api.producthunt.com/widgets/embed-image/v1/featured.svg?post_id=196886&theme=dark" alt="JustAuth - Login, so easy! | Product Hunt Embed" style="width: 250px; height: 54px;" width="250px" height="54px" /></a>
|
||||||
|
|||||||
@@ -0,0 +1 @@
|
|||||||
|
git pull origin dev && git pull github dev && git pull cc dev
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
git push origin dev && git push github dev && git push cc dev
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
git push origin master && git push github master && git push cc master
|
||||||
@@ -25,8 +25,6 @@ fi
|
|||||||
# 替换README.md等文件中的版本
|
# 替换README.md等文件中的版本
|
||||||
sed -i "s/${old_version}/${new_version}/g" $pwd/README.md
|
sed -i "s/${old_version}/${new_version}/g" $pwd/README.md
|
||||||
sed -i "s/${old_version}/${new_version}/g" $pwd/README.en-US.md
|
sed -i "s/${old_version}/${new_version}/g" $pwd/README.en-US.md
|
||||||
sed -i "s/${old_version}/${new_version}/g" $pwd/docs/README.md
|
|
||||||
sed -i "s/${old_version}/${new_version}/g" $pwd/docs/_coverpage.md
|
|
||||||
|
|
||||||
# 替换pom.xml中的版本
|
# 替换pom.xml中的版本
|
||||||
sed -i "s/${old_version}/${new_version}/g" $pwd/pom.xml
|
sed -i "s/${old_version}/${new_version}/g" $pwd/pom.xml
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
1.14.0
|
1.16.4
|
||||||
|
|||||||
@@ -1,153 +0,0 @@
|
|||||||
## 1.项目编译报错
|
|
||||||
**问题描述**
|
|
||||||
|
|
||||||
在使用JustAuth时,`AuthConfig.builder()`报错,提示没有`builder()`方法
|
|
||||||
|
|
||||||
**解决方案:**
|
|
||||||
|
|
||||||
安装完lombok插件即可
|
|
||||||
|
|
||||||
[eclipse安装lombok](https://www.zhyd.me/article/61)
|
|
||||||
|
|
||||||
**idea安装lombok:** file->settings->plugins->Browse Repositories->输入`lombok`,点击搜索->选中lombok点击install->安装完成后重启idea
|
|
||||||
|
|
||||||
**进阶版问题:**
|
|
||||||
idea中安装完lombok并重启idea之后,启动项目仍然报错:
|
|
||||||

|
|
||||||
**解决办法**
|
|
||||||

|
|
||||||
默认是eclipse 选择javac就可以了
|
|
||||||
|
|
||||||
|
|
||||||
## 2.~~升级到1.8.0后如何启用state?~~
|
|
||||||
|
|
||||||
~~在原api使用方法的基础上,为config追加一个state即可。~~
|
|
||||||
```
|
|
||||||
AuthRequest authRequest = new AuthGiteeRequest(AuthConfig.builder()
|
|
||||||
.clientId("clientId")
|
|
||||||
.clientSecret("clientSecret")
|
|
||||||
.redirectUri("redirectUri")
|
|
||||||
.state("state") // 就是这儿
|
|
||||||
.build());
|
|
||||||
```
|
|
||||||
|
|
||||||
## 3.~~升级到1.8.0后login方法报错?~~
|
|
||||||
|
|
||||||
~~这是因为1.8.0版本中新增了[AuthCallback](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/model/AuthCallback.java)类,这个类封装了所有可能的回调参数。目前包含以下三个参数:~~
|
|
||||||
- ~~`code`: 访问AuthorizeUrl后回调时带的参数code,用来换取token~~
|
|
||||||
- ~~`auth_code`: 支付宝授权登陆时不会返回code而是返回`auth_code`参数~~
|
|
||||||
- ~~`state`: 访问AuthorizeUrl后回调时带的参数state,用于和请求AuthorizeUrl前的state比较,防止CSRF攻击~~
|
|
||||||
|
|
||||||
~~1.8.0版本之后的api,可以直接用AuthCallback类作为回调方法的入参,比如:~~
|
|
||||||
```
|
|
||||||
@RequestMapping("/callback/{source}")
|
|
||||||
public Object login(@PathVariable("source") String source, AuthCallback callback) {
|
|
||||||
System.out.println("进入callback:" + source + " callback params:" + JSONObject.toJSONString(callback));
|
|
||||||
AuthRequest authRequest = getAuthRequest(source);
|
|
||||||
AuthResponse response = authRequest.login(callback);
|
|
||||||
System.out.println(JSONObject.toJSONString(response));
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
```
|
|
||||||
~~_代码截取自_ :https://github.com/justauth/JustAuth-demo~~
|
|
||||||
|
|
||||||
## 4.~~升级到1.8.0后对于state参数有什么特殊要求吗?~~
|
|
||||||
|
|
||||||
~~理论上没有,stata只是用来保持会话状态,因为http协议的无状态性,从授权到回调,无法感知具体是哪个用户触发的。所以可以使用state作为校验。注:state参数每次完整的授权链中只可用一次!(也是为了防止不必要的危险)~~
|
|
||||||
|
|
||||||
~~作者建议state命名格式如下:~~
|
|
||||||
- ~~授权登录:`{source}_{ip}_{random}`~~
|
|
||||||
- ~~账号绑定:`{source}_{userId}_{ip}_{random}`~~
|
|
||||||
|
|
||||||
~~其中`source`表示授权平台,可以直接去JustAuth中的source,`ip`为当前用户的ip(部分情况可能不适用),`random`为随机字符串,`userId`为当前登录用户的id。~~
|
|
||||||
|
|
||||||
~~注:`authorize`和`login`(不是指回调传回的`state`,而是声明`request`时传入的`state`)中传的`state`务必保证一致~~
|
|
||||||
|
|
||||||
## 5.升级到1.9.3+版本后编译失败
|
|
||||||
|
|
||||||
主要明显的就是`IpUtils.getIp`和request的`.state`报错。
|
|
||||||
|
|
||||||
这是因为从`v1.9.3`版本开始,对项目进行了一些优化,具体优化内容参考:[v1.9.3](https://gitee.com/yadong.zhang/JustAuth/releases/v1.9.3)和[v1.9.4](https://gitee.com/yadong.zhang/JustAuth/releases/v1.9.4)。
|
|
||||||
|
|
||||||
新版本的使用方式,参考[JustAuth-demo](https://github.com/justauth/JustAuth-demo/blob/master/src/main/java/me/zhyd/justauth/RestAuthController.java)
|
|
||||||
```
|
|
||||||
@RequestMapping("/render/{source}")
|
|
||||||
public void renderAuth(@PathVariable("source") String source, HttpServletResponse response) throws IOException {
|
|
||||||
AuthRequest authRequest = getAuthRequest(source);
|
|
||||||
String authorizeUrl = authRequest.authorize(AuthStateUtils.createState());
|
|
||||||
response.sendRedirect(authorizeUrl);
|
|
||||||
}
|
|
||||||
@RequestMapping("/callback/{source}")
|
|
||||||
public Object login(@PathVariable("source") String source, AuthCallback callback) {
|
|
||||||
AuthRequest authRequest = getAuthRequest(source);
|
|
||||||
AuthResponse response = authRequest.login(callback);
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
## 6.升级到最新版本后为什么支付宝登录不能用了?
|
|
||||||
|
|
||||||
在升级到新版后,使用支付宝登录会提示`ClassNotFoundExcption`异常,这是因为从`1.9.4`版本开始,JustAuth将不在强依赖`alipay-sdk-java`,如果你需要用到Alipay的授权登陆,那么你还需要添加以下依赖:
|
|
||||||
|
|
||||||
```
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.alipay.sdk</groupId>
|
|
||||||
<artifactId>alipay-sdk-java</artifactId>
|
|
||||||
<version>3.7.4.ALL</version>
|
|
||||||
</dependency>
|
|
||||||
```
|
|
||||||
|
|
||||||
## 7.“Scope参数错误或者Scope没有权限”是怎么回事?
|
|
||||||
|
|
||||||
微信开放平台授权登录提示“Scope参数错误或者Scope没有权限”
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
解决办法:请检查微信开放平台的应用是否有“微信登录”接口的权限。
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
“接口状态”必须为“已获得”!
|
|
||||||
|
|
||||||
## 8.微信登录时能在微信端提示登录成功吗?
|
|
||||||
|
|
||||||
不可以,这是**微信公众平台**的功能,截至到目前(JustAuth v1.12.0)为止,暂不支持**微信公众平台**的授权登录
|
|
||||||
|
|
||||||
## 9.微信登录时能不需要手机确认吗?扫码后就自动登录
|
|
||||||
|
|
||||||
不可以,微信开放平台不支持这种操作。可以把微信扫码登录理解成qq用账号密码登录,扫完码后不手动点确认,微信怎么知道用户是否同意了授权?
|
|
||||||
当然,**微信公众平台**的授权流程可以越过这个限制,只要关注了公众号,后续扫码成功后就会自动登录,但是这是**微信公众平台**的功能,截至到目前(JustAuth v1.12.0)为止,暂不支持**微信公众平台**的授权登录
|
|
||||||
|
|
||||||
## 10.本地如何测那些*不支持本地地址回调*的授权登录?
|
|
||||||
|
|
||||||
推荐几种方案:
|
|
||||||
1. 改`hosts`,然后将测试程序的端口改为`80`
|
|
||||||
2. 使用`Nginx`/`Apache`做代理
|
|
||||||
3. FRP内网穿透,参考地址:[使用内网穿透的方式集成第三方登录](https://xkcoding.com/2019/05/22/spring-boot-login-with-oauth.html)
|
|
||||||
|
|
||||||
## 11.如何获取QQ登录的`unionId`?
|
|
||||||
|
|
||||||
在AuthConfig中设备`unionId`为`true`
|
|
||||||
|
|
||||||
```java
|
|
||||||
AuthRequest authRequest = new AuthQqRequest(AuthConfig.builder()
|
|
||||||
.clientId("clientId")
|
|
||||||
.clientSecret("clientSecret")
|
|
||||||
.redirectUri("redirectUri")
|
|
||||||
.unionId(true)
|
|
||||||
.build());
|
|
||||||
```
|
|
||||||
> 注:使用unionId要求开发者必须已在qq开放平台申请了获取unionId的权限,否则可能会发生错误!切记!参考链接:[unionid介绍](http://wiki.connect.qq.com/unionid%E4%BB%8B%E7%BB%8D)
|
|
||||||
|
|
||||||
## 12. `AuthCallback`报错?
|
|
||||||
|
|
||||||
在使用JustAuth 1.13.0时,遇到如下所示错误:
|
|
||||||

|
|
||||||
|
|
||||||
这是因为我没有做好代码审查和测试,所以才导致的问题。我检讨!深刻的检讨!
|
|
||||||
|
|
||||||
请遇到该问题的朋友及时升级到最新版本(`1.13.1`修复该问题)
|
|
||||||
|
|
||||||
ps: 我要去祭天了
|
|
||||||
|
|
||||||
|
|
||||||
@@ -1,171 +0,0 @@
|
|||||||
<p align="center">
|
|
||||||
<a href="https://docs.justauth.whnb.wang"><img src="./_media/cover.png" width="400"></a>
|
|
||||||
</p>
|
|
||||||
<p align="center">
|
|
||||||
<strong>Login, so easy!</strong>
|
|
||||||
</p>
|
|
||||||
<p align="center">
|
|
||||||
<strong>史上最全的整合第三方登录的开源库</strong>
|
|
||||||
</p>
|
|
||||||
<p align="center">
|
|
||||||
<a target="_blank" href="https://search.maven.org/search?q=JustAuth">
|
|
||||||
<img src="https://img.shields.io/badge/Maven Central-1.14.0-blue.svg" ></img>
|
|
||||||
</a>
|
|
||||||
<a target="_blank" href="https://gitee.com/yadong.zhang/JustAuth/blob/master/LICENSE">
|
|
||||||
<img src="https://img.shields.io/apm/l/vim-mode.svg?color=yellow" ></img>
|
|
||||||
</a>
|
|
||||||
<a target="_blank" href="https://www.oracle.com/technetwork/java/javase/downloads/index.html">
|
|
||||||
<img src="https://img.shields.io/badge/JDK-1.8+-green.svg" ></img>
|
|
||||||
</a>
|
|
||||||
<a target="_blank" href="https://apidoc.gitee.com/yadong.zhang/JustAuth/" title="API文档">
|
|
||||||
<img src="https://img.shields.io/badge/Api Docs-1.14.0-orange.svg" ></img>
|
|
||||||
</a>
|
|
||||||
<a target="_blank" href="https://docs.justauth.whnb.wang" title="参考文档">
|
|
||||||
<img src="https://img.shields.io/badge/Docs-latest-blueviolet.svg" ></img>
|
|
||||||
</a>
|
|
||||||
<a href="https://codecov.io/gh/zhangyd-c/JustAuth">
|
|
||||||
<img src="https://codecov.io/gh/zhangyd-c/JustAuth/branch/master/graph/badge.svg" />
|
|
||||||
</a>
|
|
||||||
<a href='https://gitee.com/yadong.zhang/JustAuth/stargazers'>
|
|
||||||
<img src='https://gitee.com/yadong.zhang/JustAuth/badge/star.svg?theme=white' alt='star'></img>
|
|
||||||
</a>
|
|
||||||
<a target="_blank" href='https://github.com/zhangyd-c/JustAuth'>
|
|
||||||
<img src="https://img.shields.io/github/stars/zhangyd-c/JustAuth.svg?style=social" alt="github star"></img>
|
|
||||||
</a>
|
|
||||||
</p>
|
|
||||||
<p align="center">
|
|
||||||
<strong>开源地址:</strong> <a target="_blank" href='https://gitee.com/yadong.zhang/JustAuth'>Gitee</a> | <a target="_blank" href='https://github.com/zhangyd-c/JustAuth'>Github</a>
|
|
||||||
</p>
|
|
||||||
<p align="center">
|
|
||||||
<strong>QQ群:</strong>230017570
|
|
||||||
</p>
|
|
||||||
<p align="center">
|
|
||||||
<strong>文档更新日期:</strong> {docsify-updated}
|
|
||||||
</p>
|
|
||||||
|
|
||||||
## 简介
|
|
||||||
|
|
||||||
JustAuth,如你所见,它仅仅是一个**第三方授权登录**的**工具类库**,它可以让我们脱离繁琐的第三方登录SDK,让登录变得**So easy!**
|
|
||||||
|
|
||||||
## 特点
|
|
||||||
|
|
||||||
废话不多说,就俩字:
|
|
||||||
|
|
||||||
1. **全**:已集成十多家第三方平台(国内外常用的基本都已包含),仍然还在持续扩展中([开发计划](https://gitee.com/yadong.zhang/JustAuth/issues/IUGRK))!
|
|
||||||
2. **简**:API就是奔着最简单去设计的,尽量让您用起来没有障碍感!
|
|
||||||
|
|
||||||
## 项目关注度趋势
|
|
||||||
|
|
||||||
[](https://starchart.cc/justauth/JustAuth)
|
|
||||||
|
|
||||||
## 已集成的平台
|
|
||||||
|
|
||||||
| :computer: 平台 | :coffee: API类 | :page_facing_up: SDK |
|
|
||||||
|:------:|:-------:|:-------:|
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/gitee.png" width="20"> | [AuthGiteeRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthGiteeRequest.java) | <a href="https://gitee.com/api/v5/oauth_doc#list_1" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/github.png" width="20"> | [AuthGithubRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthGithubRequest.java) | <a href="https://developer.github.com/apps/building-oauth-apps/authorizing-oauth-apps/" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/weibo.png" width="20"> | [AuthWeiboRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthWeiboRequest.java) | <a href="https://open.weibo.com/wiki/%E6%8E%88%E6%9D%83%E6%9C%BA%E5%88%B6%E8%AF%B4%E6%98%8E" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/dingtalk.png" width="20"> | [AuthDingTalkRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthDingTalkRequest.java) | <a href="https://open-doc.dingtalk.com/microapp/serverapi2/kymkv6" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/baidu.png" width="20"> | [AuthBaiduRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthBaiduRequest.java) | <a href="http://developer.baidu.com/wiki/index.php?title=docs/oauth" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/coding.png" width="25"> | [AuthCodingRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthCodingRequest.java) | <a href="https://open.coding.net/references/oauth/" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/tencentCloud.png" width="25"> | [AuthTencentCloudRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthTencentCloudRequest.java) | <a href="https://dev.tencent.com/help/doc/faq/b4e5b7aee786/oauth" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/oschina.png" width="20"> | [AuthOschinaRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthOschinaRequest.java) | <a href="https://www.oschina.net/openapi/docs/oauth2_authorize" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/alipay.png" width="20"> | [AuthAlipayRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthAlipayRequest.java) | <a href="https://alipay.open.taobao.com/docs/doc.htm?spm=a219a.7629140.0.0.336d4b70GUKXOl&treeId=193&articleId=105809&docType=1" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/qq.png" width="20"> | [AuthQqRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthQqRequest.java) | <a href="https://wiki.connect.qq.com/%E4%BD%BF%E7%94%A8authorization_code%E8%8E%B7%E5%8F%96access_token" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/wechat.png" width="20" title="微信开放平台"> | [AuthWeChatOpenRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthWeChatOpenRequest.java) | <a href="https://open.weixin.qq.com/cgi-bin/showdocument?action=dir_list&t=resource/res_list&verify=1&id=open1419316505&token=&lang=zh_CN" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/wechat.png" width="20" title="微信公众平台"> | [AuthWeChatMpRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthWeChatMpRequest.java) | <a href="https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/Wechat_webpage_authorization.html" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/wechat.png" width="20" title="企业微信"> | [AuthWeChatEnterpriseRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthWeChatEnterpriseRequest.java) | <a href="https://open.work.weixin.qq.com/api/doc#90000/90135/90664" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/taobao.png" width="20"> | [AuthTaobaoRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthTaobaoRequest.java) | <a href="https://open.taobao.com/doc.htm?spm=a219a.7386797.0.0.4e00669acnkQy6&source=search&docId=105590&docType=1" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/google.png" width="20"> | [AuthGoogleRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthGoogleRequest.java) | <a href="https://developers.google.com/identity/protocols/OpenIDConnect" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/facebook.png" width="20"> | [AuthFacebookRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthFacebookRequest.java) | <a href="https://developers.facebook.com/docs/facebook-login/manually-build-a-login-flow" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/douyin.png" width="20"> | [AuthDouyinRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthDouyinRequest.java) | <a href="https://www.douyin.com/platform/doc/m-2-1-1" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/linkedin.png" width="20"> | [AuthLinkedinRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthLinkedinRequest.java) | <a href="https://docs.microsoft.com/zh-cn/linkedin/shared/authentication/authorization-code-flow?context=linkedin/context" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/microsoft.png" width="20"> | [AuthMicrosoftRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthMicrosoftRequest.java) | <a href="https://docs.microsoft.com/zh-cn/graph/auth/" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/mi.png" width="20"> | [AuthMiRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthMiRequest.java) | <a href="https://dev.mi.com/console/doc/detail?pId=711" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/toutiao.png" width="20"> | [AuthToutiaoRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthToutiaoRequest.java) | <a href="https://open.mp.toutiao.com/#/resource?_k=y7mfgk" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/teambition.png" width="20"> | [AuthTeambitionRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthTeambitionRequest.java) | <a href="https://docs.teambition.com/" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/renren.png" width="20"> | [AuthRenrenRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthRenrenRequest.java) | <a href="http://open.renren.com/wiki/OAuth2.0" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/pinterest.png" width="20"> | [AuthPinterestRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthPinterestRequest.java) | <a href="https://developers.pinterest.com/docs/api/overview/?" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/stackoverflow.png" width="20"> | [AuthStackOverflowRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthStackOverflowRequest.java) | <a href="https://api.stackexchange.com/docs/authentication" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/huawei.png" width="20"> | [AuthHuaweiRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthHuaweiRequest.java) | <a href="https://developer.huawei.com/consumer/cn/devservice/doc/30101" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/kujiale.png" width="20"> | [AuthKujialeRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthKujialeRequest.java) | <a href="https://open.kujiale.com/open/apps/2/docs?doc_id=95" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/gitlab.png" width="20"> | [AuthGitlabRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthGitlabRequest.java) | <a href="https://docs.gitlab.com/ee/api/oauth2.html" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/meituan.png" width="20"> | [AuthMeituanRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthMeituanRequest.java) | <a href="http://open.waimai.meituan.com/openapi_docs/oauth/" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/eleme.png" width="20"> | [AuthElemeRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthElemeRequest.java) | <a href="https://open.shop.ele.me/openapi/documents/khd001" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/twitter.png" width="20"> | [AuthTwitterRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthTwitterRequest.java) | <a href="https://developer.twitter.com/en/docs/twitter-for-websites/log-in-with-twitter/guides/implementing-sign-in-with-twitter" target="_blank">参考文档</a> |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/JustAuth/csdn.png" width="20"> | [AuthCsdnRequest](https://gitee.com/yadong.zhang/JustAuth/blob/master/src/main/java/me/zhyd/oauth/request/AuthCsdnRequest.java) | 无 |
|
|
||||||
|
|
||||||
|
|
||||||
## 快速开始
|
|
||||||
|
|
||||||
- 引入依赖
|
|
||||||
```xml
|
|
||||||
<dependency>
|
|
||||||
<groupId>me.zhyd.oauth</groupId>
|
|
||||||
<artifactId>JustAuth</artifactId>
|
|
||||||
<version>${latest.version}</version>
|
|
||||||
</dependency>
|
|
||||||
```
|
|
||||||
- 调用api
|
|
||||||
```java
|
|
||||||
// 创建授权request
|
|
||||||
AuthRequest authRequest = new AuthGiteeRequest(AuthConfig.builder()
|
|
||||||
.clientId("clientId")
|
|
||||||
.clientSecret("clientSecret")
|
|
||||||
.redirectUri("redirectUri")
|
|
||||||
.build());
|
|
||||||
// 生成授权页面
|
|
||||||
authRequest.authorize("state");
|
|
||||||
// 授权登录后会返回code(auth_code(仅限支付宝))、state,1.8.0版本后,可以用AuthCallback类作为回调接口的参数
|
|
||||||
// 注:JustAuth默认保存state的时效为3分钟,3分钟内未使用则会自动清除过期的state
|
|
||||||
authRequest.login(callback);
|
|
||||||
```
|
|
||||||
|
|
||||||
## 参与&贡献
|
|
||||||
|
|
||||||
JustAuth的发展离不开朋友们的支持,时至今日,JustAuth已渐趋完善,但仍有很大的改善空间。欢迎各位朋友为JustAuth贡献一份力量。
|
|
||||||
|
|
||||||
### 提供bug或建议
|
|
||||||
|
|
||||||
- [Gitee](https://gitee.com/yadong.zhang/JustAuth/issues)
|
|
||||||
- [Github](https://github.com/justauth/JustAuth/issues)
|
|
||||||
|
|
||||||
如果你正在使用JustAuth,可以在这儿留下你的足迹,获得优先推送、曝光
|
|
||||||
|
|
||||||
- [Gitee](https://gitee.com/yadong.zhang/JustAuth/issues/IZ2T7)
|
|
||||||
- [Github](https://github.com/justauth/JustAuth/issues/17)
|
|
||||||
|
|
||||||
### 贡献代码的步骤
|
|
||||||
|
|
||||||
1. fork本项目到自己的repo
|
|
||||||
2. 把fork过去的项目也就是你仓库中的项目clone到你本地
|
|
||||||
3. 修改代码(`dev`分支)
|
|
||||||
4. commit后push到自己的仓库
|
|
||||||
5. 发起PR(pull request) 请求,提交到`dev`分支
|
|
||||||
6. 等待合并
|
|
||||||
|
|
||||||
### 注意事项
|
|
||||||
|
|
||||||
1. JustAuth只接受集成**OAuth2.0**的平台
|
|
||||||
2. 建议安装“**阿里编码规约**”插件,然后进行开发
|
|
||||||
3. 提交PR前请格式化好自己的代码
|
|
||||||
4. 注释规范,自定义的方法一定要加上:方法说明、参数说明、返回值说明等
|
|
||||||
|
|
||||||
## 功能尝鲜
|
|
||||||
|
|
||||||
JustAuth一共有两个主要分支:
|
|
||||||
- 线上版分支(master):稳定版,发布版就是这个分支的代码
|
|
||||||
- 开发版分支(dev):不保证稳定,新功能都会优先推送到该分支,对于想尝鲜的朋友,可以直接下载代码,然后源码编译dev分支
|
|
||||||
|
|
||||||
## 开源推荐
|
|
||||||
- `spring-boot-demo` 深度学习并实战 spring boot 的项目: [https://github.com/xkcoding/spring-boot-demo](https://github.com/xkcoding/spring-boot-demo)
|
|
||||||
- `mica` SpringBoot 微服务高效开发工具集: [https://github.com/lets-mica/mica](https://github.com/lets-mica/mica)
|
|
||||||
- `pig` 宇宙最强微服务认证授权脚手架(架构师必备): [https://gitee.com/log4j/pig](https://gitee.com/log4j/pig)
|
|
||||||
- `SpringBlade` 完整的线上解决方案(企业开发必备): https://gitee.com/smallc/SpringBlade
|
|
||||||
|
|
||||||
## 捐赠
|
|
||||||
|
|
||||||
| 支付宝 | 微信 |
|
|
||||||
| :------------: | :------------: |
|
|
||||||
| <img src="https://gitee.com/yadong.zhang/static/raw/master/qrcode/zfb_code.png" width="200"/> | <img src="https://gitee.com/yadong.zhang/static/raw/master/qrcode/wx_code.png" width="200" /> |
|
|
||||||
|
|
||||||
@@ -1,27 +0,0 @@
|
|||||||
**非常感谢您对JustAuth的关注**,您现在查询的内容,资料库中暂时没有,我们后续会补充上。
|
|
||||||
|
|
||||||
您可能还会需要以下文档:
|
|
||||||
|
|
||||||
- [OAuth的授权流程是什么样的?](https://docs.justauth.whnb.wang/#/oauth)
|
|
||||||
- [如何使用JustAuth?](https://docs.justauth.whnb.wang/#/how-to-use)
|
|
||||||
- [提问与回答?](https://docs.justauth.whnb.wang/#/Q&A)
|
|
||||||
- [如何集成Github?](https://docs.justauth.whnb.wang/#/oauth/github)
|
|
||||||
- [如何集成Gitee?](https://docs.justauth.whnb.wang/#/oauth/gitee)
|
|
||||||
- [如何集成支付宝?](https://docs.justauth.whnb.wang/#/oauth/alipay)
|
|
||||||
- [如何自定义state?](https://docs.justauth.whnb.wang/#/customize-the-state-cache)
|
|
||||||
- [如何自定义接入自己搭建的oauth平台?](https://docs.justauth.whnb.wang/#/customize-the-oauth)
|
|
||||||
- [有哪些配套项目?](https://docs.justauth.whnb.wang/#/supporting)
|
|
||||||
|
|
||||||
### 如果还是没有您想要的内容,您可以:
|
|
||||||
|
|
||||||
1. (建议) 提Issue: 【[github](https://github.com/justauth/JustAuth/issues)】 | 【[gitee](https://gitee.com/yadong.zhang/JustAuth/issues)】
|
|
||||||
2. 本页面底部直接留言
|
|
||||||
3. 关注公众号(公众号会不定期推送相关内容),扫下方二维码关注公众号:
|
|
||||||
|
|
||||||
<img src="https://gitee.com/yadong.zhang/static/raw/master/wx/wechat_account.jpg" width="200" />
|
|
||||||
|
|
||||||
4. 加微信群(群内有各个优秀开源项目的作者和技术大神),微信扫下方二维码后加我好友(**注:一定要备注JustAUth,无备注的一律不加**):
|
|
||||||
|
|
||||||
<img src="https://gitee.com/yadong.zhang/static/raw/master/wx/wx.png" width="170"/>
|
|
||||||
|
|
||||||
5. 加QQ群:QQ搜索`230017570`(该QQ群为JustAuth官方技术讨论群,禁止群内打广告!)
|
|
||||||
@@ -1,16 +0,0 @@
|
|||||||
|
|
||||||

|
|
||||||
# JustAuth <small>1.14.0</small>
|
|
||||||
|
|
||||||
<strong>史上最全的整合第三方登录的开源库</strong>
|
|
||||||
|
|
||||||
<strong>Login, so easy</strong>
|
|
||||||
|
|
||||||
<p>已集成国内外十多家平台</p>
|
|
||||||
<p>极简的API设计</p>
|
|
||||||
|
|
||||||
|
|
||||||
[Gitee](https://gitee.com/yadong.zhang/JustAuth)
|
|
||||||
[Github](https://github.com/zhangyd-c/JustAuth)
|
|
||||||
[Get Started](#简介)
|
|
||||||
|
|
||||||
|
Before Width: | Height: | Size: 16 KiB |
|
Before Width: | Height: | Size: 19 KiB |
|
Before Width: | Height: | Size: 93 KiB |
|
Before Width: | Height: | Size: 23 KiB |
|
Before Width: | Height: | Size: 67 KiB |
|
Before Width: | Height: | Size: 158 KiB |
|
Before Width: | Height: | Size: 6.0 KiB |
|
Before Width: | Height: | Size: 1.4 KiB |
|
Before Width: | Height: | Size: 377 KiB |
|
Before Width: | Height: | Size: 103 KiB |
|
Before Width: | Height: | Size: 88 KiB |
|
Before Width: | Height: | Size: 60 KiB |
|
Before Width: | Height: | Size: 19 KiB |
|
Before Width: | Height: | Size: 86 KiB |
|
Before Width: | Height: | Size: 38 KiB |
|
Before Width: | Height: | Size: 97 KiB |
|
Before Width: | Height: | Size: 25 KiB |
|
Before Width: | Height: | Size: 9.9 KiB |
|
Before Width: | Height: | Size: 33 KiB |
|
Before Width: | Height: | Size: 46 KiB |
|
Before Width: | Height: | Size: 1.3 MiB |
|
Before Width: | Height: | Size: 62 KiB |
|
Before Width: | Height: | Size: 54 KiB |
|
Before Width: | Height: | Size: 96 KiB |
|
Before Width: | Height: | Size: 131 KiB |
|
Before Width: | Height: | Size: 162 KiB |
|
Before Width: | Height: | Size: 164 KiB |
|
Before Width: | Height: | Size: 105 KiB |
|
Before Width: | Height: | Size: 184 KiB |
|
Before Width: | Height: | Size: 26 KiB |
|
Before Width: | Height: | Size: 193 KiB |
|
Before Width: | Height: | Size: 24 KiB |
|
Before Width: | Height: | Size: 42 KiB |
|
Before Width: | Height: | Size: 38 KiB |
|
Before Width: | Height: | Size: 45 KiB |
|
Before Width: | Height: | Size: 48 KiB |
|
Before Width: | Height: | Size: 63 KiB |
|
Before Width: | Height: | Size: 56 KiB |
|
Before Width: | Height: | Size: 30 KiB |
|
Before Width: | Height: | Size: 74 KiB |
|
Before Width: | Height: | Size: 45 KiB |
|
Before Width: | Height: | Size: 30 KiB |
|
Before Width: | Height: | Size: 40 KiB |
|
Before Width: | Height: | Size: 29 KiB |
|
Before Width: | Height: | Size: 79 KiB |
|
Before Width: | Height: | Size: 34 KiB |
|
Before Width: | Height: | Size: 60 KiB |
|
Before Width: | Height: | Size: 124 KiB |
|
Before Width: | Height: | Size: 43 KiB |
|
Before Width: | Height: | Size: 183 KiB |
|
Before Width: | Height: | Size: 84 KiB |
|
Before Width: | Height: | Size: 43 KiB |
|
Before Width: | Height: | Size: 27 KiB |
|
Before Width: | Height: | Size: 4.3 KiB |
|
Before Width: | Height: | Size: 11 KiB |
@@ -1,48 +0,0 @@
|
|||||||
- [入门和使用](README.md)
|
|
||||||
- [贡献者名单](contributors.md)
|
|
||||||
- 快速开始
|
|
||||||
- [名词解释](explain.md)
|
|
||||||
- [OAuth流程](oauth.md)
|
|
||||||
- [如何使用](how-to-use.md)
|
|
||||||
- [Q&A](Q&A.md)
|
|
||||||
- 集成第三方
|
|
||||||
- [√ Gitee登录](oauth/gitee.md)
|
|
||||||
- [√ Github登录](oauth/github.md)
|
|
||||||
- [√ qq登录](oauth/qq.md)
|
|
||||||
- [√ 微信开放平台登录](oauth/wechat_open.md)
|
|
||||||
- [微信企业版登录](oauth/wechatEnterprise.md)
|
|
||||||
- [微信公众平台登录](oauth/wechat_mp.md)
|
|
||||||
- [√ 微博登录](oauth/weibo.md)
|
|
||||||
- [√ 支付宝登录](oauth/alipay.md)
|
|
||||||
- [百度登录](oauth/baidu.md)
|
|
||||||
- [Coding登录](oauth/coding.md)
|
|
||||||
- [钉钉登录](oauth/dingtalk.md)
|
|
||||||
- [开源中国登录](oauth/oschina.md)
|
|
||||||
- [淘宝登录](oauth/taobao.md)
|
|
||||||
- [腾讯云登录](oauth/tencentCloud.md)
|
|
||||||
- [Google登录](oauth/google.md)
|
|
||||||
- [Facebook登录](oauth/facebook.md)
|
|
||||||
- [抖音登录](oauth/douyin.md)
|
|
||||||
- [领英登录](oauth/linkedin.md)
|
|
||||||
- [微软登录](oauth/microsoft.md)
|
|
||||||
- [小米登录](oauth/mi.md)
|
|
||||||
- [头条登录](oauth/toutiao.md)
|
|
||||||
- [Teambition登录](oauth/teambition.md)
|
|
||||||
- [人人登录](oauth/renren.md)
|
|
||||||
- [Pinterest登录](oauth/pinterest.md)
|
|
||||||
- [Stackoverflow登录](oauth/stackoverflow.md)
|
|
||||||
- [华为登录](oauth/huawei.md)
|
|
||||||
- [√ 酷家乐登录](oauth/kujiale.md)
|
|
||||||
- [Gitlab登录](oauth/gitlab.md)
|
|
||||||
- [美团登录](oauth/meituan.md)
|
|
||||||
- [饿了么登录](oauth/eleme.md)
|
|
||||||
- [CSDN登录](oauth/csdn.md)
|
|
||||||
- [飞书登录](oauth/feishu.md)
|
|
||||||
- 高级特性
|
|
||||||
- [使用State](using-state.md)
|
|
||||||
- [自定义state缓存](customize-the-state-cache.md)
|
|
||||||
- [自定义第三方平台的OAuth](customize-the-oauth.md)
|
|
||||||
- [配套项目](supporting.md)
|
|
||||||
- [Who is using](users.md)
|
|
||||||
- [致谢](thx.md)
|
|
||||||
- [更新记录](update.md)
|
|
||||||
@@ -1,35 +0,0 @@
|
|||||||
# 项目贡献者名单
|
|
||||||
|
|
||||||
> 排序不分先后
|
|
||||||
|
|
||||||
- <img src="https://avatar.gitee.com/uploads/99/784199_yadong.zhang.png!avatar100?1462325358" width="20"> · yadong.zhang : <a href="https://github.com/zhangyd-c" target="_blank">[Github]</a> | <a href="https://gitee.com/yadong.zhang" target="_blank">[Gitee]</a> | <a href="https://www.zhyd.me" target="_blank">[个人网站]</a>
|
|
||||||
- <img src="https://avatars0.githubusercontent.com/u/10429917?s=460&v=4" width="20"> · yangkai.shen : <a href="https://github.com/xkcoding" target="_blank">[Github]</a> | <a href="https://xkcoding.com" target="_blank">[个人网站]</a>
|
|
||||||
- 集成微信登录、QQ登录、Google登录、微软登录、小米登录、企业微信登录
|
|
||||||
- 优化代码、架构,增加自定义缓存
|
|
||||||
- 提供jFinal版demo
|
|
||||||
- 提供ActFramework版demo
|
|
||||||
- 提供SpringBoot快速集成的justauth-spring-boot-starter
|
|
||||||
- <img src="https://avatars2.githubusercontent.com/u/2988765?s=115&v=4" width="20"> · pengisgood : <a href="https://github.com/pengisgood" target="_blank">[Github]</a> | <a href="https://pengisgood.github.io" target="_blank">[个人网站]</a>
|
|
||||||
- 集成人人登录、Pinterest登录、StackOverflow登录、Twitter登录
|
|
||||||
- <img src="https://avatar.gitee.com/uploads/51/1651_dolphinboy.png!avatar100?1479346570" width="20"> · skqing : <a href="https://gitee.com/skqing" target="_blank">[Gitee]</a> | <a href="https://my.oschina.net/dolphinboy" target="_blank">[个人网站]</a>
|
|
||||||
- 修复钉钉登录的部分问题
|
|
||||||
- 优化微博登录
|
|
||||||
- <img src="https://avatars1.githubusercontent.com/u/47110161?s=88&v=4" width="20"> · dyc12ii : <a href="https://github.com/dyc12ii" target="_blank">[Gitee]</a>
|
|
||||||
- 升级fastjson版本至1.2.58
|
|
||||||
- <img src="https://gitee.com/uploads/22/4981222_harryleexyz.png?1556524275" width="20"> · harrylee : <a href="https://gitee.com/harryleexyz" target="_blank">[Gitee]</a>
|
|
||||||
- 升级fastjson依赖到1.2.60
|
|
||||||
- <img src="https://avatars3.githubusercontent.com/u/32814990?s=460&v=4" width="20"> · Veigar : <a href="https://github.com/wuweiqi1993" target="_blank">[Github]</a>
|
|
||||||
- 集成酷家乐登录
|
|
||||||
- <img src="https://avatar.gitee.com/uploads/24/1280924_TopCoderMyDream.png!avatar200?1523763232" width="20"> · 蛋蛋 : <a href="https://gitee.com/TopCoderMyDream" target="_blank">[Gitee]</a> | <a href="https://github.com/EggsBlue" target="_blank">[Github]</a>
|
|
||||||
- 提供NutzBoot版的demo项目
|
|
||||||
- <img src="https://avatars0.githubusercontent.com/u/35978114?s=180&v=4" width="20"> · Braavos96 : <a href="https://github.com/Braavos96" target="_blank">[Github]</a>
|
|
||||||
- 添加测试用例:UrlBuilder 、GlobalAuthUtil
|
|
||||||
- <img src="https://avatars0.githubusercontent.com/u/283483?s=180&v=4" width="20"> · Chris Smowton : <a href="https://github.com/smowton" target="_blank">[Github]</a>
|
|
||||||
- 添加测试用例:StringUtils
|
|
||||||
- <img src="https://avatars1.githubusercontent.com/u/31759178?s=88&v=4" width="20"> · githubeacon : <a href="https://github.com/githubeacon" target="_blank">[Github]</a>
|
|
||||||
- 增加飞书授权登录
|
|
||||||
- <img src="https://avatars3.githubusercontent.com/u/20242284?s=88&u=2aeb7576bd61392e9fd94227d2b3048a9aea6f73&v=4" width="20"> · runningzyp : <a href="https://github.com/runningzyp" target="_blank">[Github]</a>
|
|
||||||
- 修改文案错误
|
|
||||||
- 千年等一回,我只为等你...
|
|
||||||
|
|
||||||
ps: 如有遗漏,请告知
|
|
||||||
@@ -1,209 +0,0 @@
|
|||||||
# 自定义第三方平台的OAuth
|
|
||||||
|
|
||||||
[JustAuth](https://github.com/justauth/JustAuth)发展到现在,基本上已经涵盖了国内外大多数知名的网站。[JustAuth](https://github.com/justauth/JustAuth)也一直以它的**全**和**简**,备受各位朋友的厚爱、支持。
|
|
||||||
|
|
||||||
但现在OAuth技术越来越成熟,越来越多的个人站长或者企业都开始搭建自己的OAuth授权平台,那么针对这种情况,[JustAuth](https://github.com/justauth/JustAuth)并不能做到面面俱到,无法去集成所有支持OAuth的网站(这也是不现实的)。
|
|
||||||
|
|
||||||
既然考虑到有这种需求,那么就要想办法解决,想办法填补漏洞,不为了自己,也为了陪伴[JustAuth](https://github.com/justauth/JustAuth)一路走来的所有朋友们。
|
|
||||||
|
|
||||||
[JustAuth](https://github.com/justauth/JustAuth)开发团队也在[v1.12.0](https://github.com/justauth/JustAuth/releases/tag/v1.12.0)版本中新加入了一大特性,就是可以支持任意支持OAuth的网站通过JustAuth实现便捷的OAuth登录!
|
|
||||||
|
|
||||||
下面我们会通过一个小例子,讲解如何使用JustAuth集成自己搭建的GitLab服务。
|
|
||||||
|
|
||||||
> 注:本节将会使用[JustAuth-demo](https://github.com/justauth/JustAuth-demo)Demo项目进行演示
|
|
||||||
|
|
||||||
## 搭建Gitlab服务
|
|
||||||
|
|
||||||
请自行解决,如果已有搭建好的Gitlab私服,请直接进入下面的步骤
|
|
||||||
|
|
||||||
## 创建应用
|
|
||||||
|
|
||||||

|
|
||||||

|
|
||||||
|
|
||||||
## 实现AuthSource接口
|
|
||||||
|
|
||||||
`AuthSource.java`是为了提供OAuth平台的API地址的统一接口,提供以下方法供实现:
|
|
||||||
- `AuthSource#authorize()`: 获取授权url. 必须实现
|
|
||||||
- `AuthSource#accessToken()`: 获取accessToken的url. 必须实现
|
|
||||||
- `AuthSource#userInfo()`: 获取用户信息的url. 必须实现
|
|
||||||
- `AuthSource#revoke()`: 获取取消授权的url. 非必须实现接口(部分平台不支持)
|
|
||||||
- `AuthSource#refresh()`: 获取刷新授权的url. 非必须实现接口(部分平台不支持)
|
|
||||||
|
|
||||||
**注:**
|
|
||||||
- 当通过JustAuth扩展实现第三方授权时,请参考`AuthDefaultSource`自行创建对应的枚举类并实现`AuthSource`接口
|
|
||||||
- 如果不是使用的枚举类,那么在授权成功后获取用户信息时,需要**单独处理source字段**的赋值
|
|
||||||
- 如果扩展了对应枚举类时,在`me.zhyd.oauth.request.AuthRequest#login(AuthCallback)`中可以通过`xx.toString()`获取对应的source
|
|
||||||
|
|
||||||
```java
|
|
||||||
package me.zhyd.justauth;
|
|
||||||
|
|
||||||
import me.zhyd.oauth.config.AuthSource;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author yadong.zhang (yadong.zhang0415(a)gmail.com)
|
|
||||||
* @version 1.0
|
|
||||||
* @website https://www.zhyd.me
|
|
||||||
* @date 2019/10/26 16:54
|
|
||||||
* @since 1.8
|
|
||||||
*/
|
|
||||||
public enum AuthCustomSource implements AuthSource {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 自己搭建的gitlab私服
|
|
||||||
*/
|
|
||||||
MYGITLAB {
|
|
||||||
/**
|
|
||||||
* 授权的api
|
|
||||||
*
|
|
||||||
* @return url
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public String authorize() {
|
|
||||||
return "http://gitlab.xxx.com/oauth/authorize";
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 获取accessToken的api
|
|
||||||
*
|
|
||||||
* @return url
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public String accessToken() {
|
|
||||||
return "http://gitlab.xxx.com/oauth/token";
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 获取用户信息的api
|
|
||||||
*
|
|
||||||
* @return url
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public String userInfo() {
|
|
||||||
return "http://gitlab.xxx.com/api/v4/user";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
## 创建自定义的Request
|
|
||||||
|
|
||||||
```java
|
|
||||||
package me.zhyd.justauth;
|
|
||||||
|
|
||||||
import cn.hutool.http.HttpResponse;
|
|
||||||
import com.alibaba.fastjson.JSONObject;
|
|
||||||
import me.zhyd.oauth.cache.AuthStateCache;
|
|
||||||
import me.zhyd.oauth.config.AuthConfig;
|
|
||||||
import me.zhyd.oauth.enums.AuthUserGender;
|
|
||||||
import me.zhyd.oauth.exception.AuthException;
|
|
||||||
import me.zhyd.oauth.model.AuthCallback;
|
|
||||||
import me.zhyd.oauth.model.AuthToken;
|
|
||||||
import me.zhyd.oauth.model.AuthUser;
|
|
||||||
import me.zhyd.oauth.request.AuthDefaultRequest;
|
|
||||||
import me.zhyd.oauth.utils.UrlBuilder;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author yadong.zhang (yadong.zhang0415(a)gmail.com)
|
|
||||||
* @version 1.0
|
|
||||||
* @website https://www.zhyd.me
|
|
||||||
* @date 2019/10/26 17:00
|
|
||||||
* @since 1.8
|
|
||||||
*/
|
|
||||||
public class AuthMyGitlabRequest extends AuthDefaultRequest {
|
|
||||||
|
|
||||||
|
|
||||||
public AuthMyGitlabRequest(AuthConfig config) {
|
|
||||||
super(config, AuthCustomSource.MYGITLAB);
|
|
||||||
}
|
|
||||||
|
|
||||||
public AuthMyGitlabRequest(AuthConfig config, AuthStateCache authStateCache) {
|
|
||||||
super(config, AuthCustomSource.MYGITLAB, authStateCache);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected AuthToken getAccessToken(AuthCallback authCallback) {
|
|
||||||
HttpResponse response = doPostAuthorizationCode(authCallback.getCode());
|
|
||||||
JSONObject object = JSONObject.parseObject(response.body());
|
|
||||||
|
|
||||||
this.checkResponse(object);
|
|
||||||
|
|
||||||
return AuthToken.builder()
|
|
||||||
.accessToken(object.getString("access_token"))
|
|
||||||
.refreshToken(object.getString("refresh_token"))
|
|
||||||
.idToken(object.getString("id_token"))
|
|
||||||
.tokenType(object.getString("token_type"))
|
|
||||||
.scope(object.getString("scope"))
|
|
||||||
.build();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected AuthUser getUserInfo(AuthToken authToken) {
|
|
||||||
HttpResponse response = doGetUserInfo(authToken);
|
|
||||||
JSONObject object = JSONObject.parseObject(response.body());
|
|
||||||
|
|
||||||
this.checkResponse(object);
|
|
||||||
|
|
||||||
return AuthUser.builder()
|
|
||||||
.uuid(object.getString("id"))
|
|
||||||
.username(object.getString("username"))
|
|
||||||
.nickname(object.getString("name"))
|
|
||||||
.avatar(object.getString("avatar_url"))
|
|
||||||
.blog(object.getString("web_url"))
|
|
||||||
.company(object.getString("organization"))
|
|
||||||
.location(object.getString("location"))
|
|
||||||
.email(object.getString("email"))
|
|
||||||
.remark(object.getString("bio"))
|
|
||||||
.gender(AuthUserGender.UNKNOWN)
|
|
||||||
.token(authToken)
|
|
||||||
.source(source.toString())
|
|
||||||
.build();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void checkResponse(JSONObject object) {
|
|
||||||
// oauth/token 验证异常
|
|
||||||
if (object.containsKey("error")) {
|
|
||||||
throw new AuthException(object.getString("error_description"));
|
|
||||||
}
|
|
||||||
// user 验证异常
|
|
||||||
if (object.containsKey("message")) {
|
|
||||||
throw new AuthException(object.getString("message"));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 返回带{@code state}参数的授权url,授权回调时会带上这个{@code state}
|
|
||||||
*
|
|
||||||
* @param state state 验证授权流程的参数,可以防止csrf
|
|
||||||
* @return 返回授权地址
|
|
||||||
* @since 1.11.0
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public String authorize(String state) {
|
|
||||||
return UrlBuilder.fromBaseUrl(super.authorize(state))
|
|
||||||
.queryParam("scope", "read_user+openid")
|
|
||||||
.build();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
## 测试效果
|
|
||||||
|
|
||||||
创建`AuthMyGitlabRequest`
|
|
||||||
```java
|
|
||||||
AuthRequest authRequest = new AuthMyGitlabRequest(AuthConfig.builder()
|
|
||||||
.clientId("63398e403231d4aa7e856cf5413620d536a876cb94e8d10ced0d3191b5d1d246")
|
|
||||||
.clientSecret("65b0eba68fff019e682e6755882a24dfdbf0a61be55de119cb8970320186c8eb")
|
|
||||||
.redirectUri("http://127.0.0.1:8443/oauth/callback/mygitlab")
|
|
||||||
.build());
|
|
||||||
```
|
|
||||||
|
|
||||||
> 注:完整代码都在[JustAuth-demo](https://github.com/justauth/JustAuth-demo)Demo项目中,本节只讲解关键代码
|
|
||||||
|
|
||||||
登录后的效果为
|
|
||||||
|
|
||||||

|
|
||||||

|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -1,123 +0,0 @@
|
|||||||
# 自定义state缓存
|
|
||||||
> starter 内置了2种缓存实现,一种是上一节演示的默认实现,另一种是用户自定义的扩展实现。
|
|
||||||
本节将会使用[JustAuth-demo](https://github.com/justauth/JustAuth-demo)Demo进行演示扩展Redis缓存的方式,当然了,你也可以自定义实现你自己的缓存。
|
|
||||||
|
|
||||||
## 添加 Redis 依赖
|
|
||||||
```xml
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.springframework.boot</groupId>
|
|
||||||
<artifactId>spring-boot-starter-data-redis</artifactId>
|
|
||||||
</dependency>
|
|
||||||
```
|
|
||||||
|
|
||||||
### 添加redis配置
|
|
||||||
|
|
||||||
```xml
|
|
||||||
# 集成redis实现自定义的state缓存
|
|
||||||
spring.redis.database=0
|
|
||||||
spring.redis.host=localhost
|
|
||||||
spring.redis.port=6379
|
|
||||||
spring.redis.password=xxxx
|
|
||||||
```
|
|
||||||
### 实现state缓存接口
|
|
||||||
|
|
||||||
```java
|
|
||||||
package me.zhyd.justauth;
|
|
||||||
|
|
||||||
import me.zhyd.oauth.cache.AuthCacheConfig;
|
|
||||||
import me.zhyd.oauth.cache.AuthStateCache;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.data.redis.core.RedisTemplate;
|
|
||||||
import org.springframework.data.redis.core.ValueOperations;
|
|
||||||
import org.springframework.stereotype.Component;
|
|
||||||
|
|
||||||
import javax.annotation.PostConstruct;
|
|
||||||
import java.util.concurrent.TimeUnit;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 扩展Redis版的state缓存
|
|
||||||
*
|
|
||||||
* @author yadong.zhang (yadong.zhang0415(a)gmail.com)
|
|
||||||
* @version 1.0
|
|
||||||
* @date 2019/10/24 13:38
|
|
||||||
* @since 1.8
|
|
||||||
*/
|
|
||||||
@Component
|
|
||||||
public class AuthStateRedisCache implements AuthStateCache {
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private RedisTemplate<String, String> redisTemplate;
|
|
||||||
|
|
||||||
private ValueOperations<String, String> valueOperations;
|
|
||||||
|
|
||||||
@PostConstruct
|
|
||||||
public void init() {
|
|
||||||
valueOperations = redisTemplate.opsForValue();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 存入缓存,默认3分钟
|
|
||||||
*
|
|
||||||
* @param key 缓存key
|
|
||||||
* @param value 缓存内容
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public void cache(String key, String value) {
|
|
||||||
valueOperations.set(key, value, AuthCacheConfig.timeout, TimeUnit.MILLISECONDS);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 存入缓存
|
|
||||||
*
|
|
||||||
* @param key 缓存key
|
|
||||||
* @param value 缓存内容
|
|
||||||
* @param timeout 指定缓存过期时间(毫秒)
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public void cache(String key, String value, long timeout) {
|
|
||||||
valueOperations.set(key, value, timeout, TimeUnit.MILLISECONDS);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 获取缓存内容
|
|
||||||
*
|
|
||||||
* @param key 缓存key
|
|
||||||
* @return 缓存内容
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public String get(String key) {
|
|
||||||
return valueOperations.get(key);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 是否存在key,如果对应key的value值已过期,也返回false
|
|
||||||
*
|
|
||||||
* @param key 缓存key
|
|
||||||
* @return true:存在key,并且value没过期;false:key不存在或者已过期
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public boolean containsKey(String key) {
|
|
||||||
return redisTemplate.hasKey(key);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
### 获取Request
|
|
||||||
|
|
||||||
本节以Gitee为例
|
|
||||||
|
|
||||||
```java
|
|
||||||
// 1. 注入新添加的cache
|
|
||||||
@Autowired
|
|
||||||
private AuthStateRedisCache stateRedisCache;
|
|
||||||
|
|
||||||
// 2. 创建request时传入stateRedisCache
|
|
||||||
AuthRequest authRequest = new AuthGiteeRequest(AuthConfig.builder()
|
|
||||||
.clientId("clientId")
|
|
||||||
.clientSecret("clientSecret")
|
|
||||||
.redirectUri("redirectUri")
|
|
||||||
.build(), stateRedisCache);// 此处传入自定义实现的类
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
到此已经完成了通过redis**扩展实现state缓存**的功能。当然,只要你愿意,你可以使用**任何一种**缓存技术去实现这个功能,并不局限于redis。
|
|
||||||
@@ -1,29 +0,0 @@
|
|||||||
本文将就JustAuth中涉及到的一些配置、关键词做一下简单说明,方便使用者理解、使用。
|
|
||||||
|
|
||||||
## 本文相关名词
|
|
||||||
|
|
||||||
- `开发者` 指使用`JustAuth`的开发者
|
|
||||||
- `第三方` 指开发者对接的第三方网站,比如:QQ平台、微信平台、微博平台
|
|
||||||
- `用户` 指最终服务的真实用户
|
|
||||||
|
|
||||||
## JustAuth中的关键词
|
|
||||||
|
|
||||||
以下内容了解后,将会使你更容易地上手JustAuth。
|
|
||||||
|
|
||||||
- `clientId` 客户端身份标识符(应用id),一般在申请完Oauth应用后,由**第三方平台颁发**,唯一
|
|
||||||
- `clientSecret` 客户端密钥,一般在申请完Oauth应用后,由**第三方平台颁发**
|
|
||||||
- `redirectUri` **开发者项目中的有效api地址**。用户在确认第三方平台授权(登录)后,第三方平台会重定向到该地址,并携带code等参数
|
|
||||||
- `state` 用来保持授权会话流程完整性,防止CSRF攻击的安全的随机的参数,由**开发者生成**
|
|
||||||
- `alipayPublicKey` 支付宝公钥。当选择支付宝登录时,必传该值,由**开发者生成**
|
|
||||||
- `unionId` 是否需要申请unionid,目前只针对**qq登录**。注:qq授权登录时,获取unionid需要单独发送邮件申请权限。如果个人开发者账号中申请了该权限,可以将该值置为true,在获取openId时就会同步获取unionId。参考链接:[UnionID介绍](http://wiki.connect.qq.com/unionid%E4%BB%8B%E7%BB%8D)
|
|
||||||
- `stackOverflowKey` Stack Overflow 登陆时需单独提供的key,由**第三方平台颁发**
|
|
||||||
- `agentId` 企业微信登陆时需单独提供该值,由**第三方平台颁发**,为授权方的网页应用ID
|
|
||||||
- `source` JustAuth支持的第三方平台,比如:GITHUB、GITEE等
|
|
||||||
|
|
||||||
## 参考资料
|
|
||||||
|
|
||||||
关于OAuth2相关的内容、原理可以自行参阅以下资料:
|
|
||||||
|
|
||||||
- [The OAuth 2.0 Authorization Framework](https://tools.ietf.org/html/rfc6749)
|
|
||||||
- [OAuth 2.0](https://oauth.net/2/)
|
|
||||||
|
|
||||||
|
Before Width: | Height: | Size: 1021 B |
@@ -1,168 +0,0 @@
|
|||||||
# 如何使用
|
|
||||||
|
|
||||||
在前面有介绍到,JustAuth的特点之一就是**简**,极简主义,不给使用者造成不必要的障碍。
|
|
||||||
|
|
||||||
既然牛皮吹下了, 那么如何才能用JustAuth实现第三方登录呢?
|
|
||||||
|
|
||||||
## 使用步骤
|
|
||||||
|
|
||||||
使用JustAuth总共分三步(**这三步也适合于JustAuth支持的任何一个平台**):
|
|
||||||
|
|
||||||
1. 申请注册第三方平台的开发者账号
|
|
||||||
2. 创建第三方平台的应用,获取配置信息(`accessKey`, `secretKey`, `redirectUri`)
|
|
||||||
3. 使用该工具实现授权登陆
|
|
||||||
|
|
||||||
## 使用方式
|
|
||||||
|
|
||||||
- 引入依赖
|
|
||||||
```xml
|
|
||||||
<dependency>
|
|
||||||
<groupId>me.zhyd.oauth</groupId>
|
|
||||||
<artifactId>JustAuth</artifactId>
|
|
||||||
<version>${latest.version}</version>
|
|
||||||
</dependency>
|
|
||||||
```
|
|
||||||
- 调用api
|
|
||||||
```java
|
|
||||||
// 创建授权request
|
|
||||||
AuthRequest authRequest = new AuthGiteeRequest(AuthConfig.builder()
|
|
||||||
.clientId("clientId")
|
|
||||||
.clientSecret("clientSecret")
|
|
||||||
.redirectUri("redirectUri")
|
|
||||||
.build());
|
|
||||||
// 生成授权页面
|
|
||||||
authRequest.authorize("state");
|
|
||||||
// 授权登录后会返回code(auth_code(仅限支付宝))、state,1.8.0版本后,可以用AuthCallback类作为回调接口的参数
|
|
||||||
// 注:JustAuth默认保存state的时效为3分钟,3分钟内未使用则会自动清除过期的state
|
|
||||||
authRequest.login(callback);
|
|
||||||
```
|
|
||||||
|
|
||||||
## API分解
|
|
||||||
|
|
||||||
**JustAuth**的核心就是一个个的`request`,每个平台都对应一个具体的`request`类,所以在使用之前,需要就具体的授权平台创建响应的`request`
|
|
||||||
|
|
||||||
```java
|
|
||||||
// 创建授权request
|
|
||||||
AuthRequest authRequest = new AuthGiteeRequest(AuthConfig.builder()
|
|
||||||
.clientId("clientId")
|
|
||||||
.clientSecret("clientSecret")
|
|
||||||
.redirectUri("redirectUri")
|
|
||||||
.build());
|
|
||||||
```
|
|
||||||
|
|
||||||
所有可用的`Request`列表请参考:[已集成的平台](https://docs.justauth.whnb.wang/#/README?id=已集成的平台)
|
|
||||||
|
|
||||||
### 获取授权链接
|
|
||||||
|
|
||||||
```java
|
|
||||||
String authorizeUrl = authRequest.authorize("state");
|
|
||||||
```
|
|
||||||
获取到`authorizeUrl`后,可以手动实现redirect到`authorizeUrl`上
|
|
||||||
|
|
||||||
**伪代码**
|
|
||||||
|
|
||||||
```java
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @param source 第三方授权平台,以本例为参考,该值为gitee(因为上面声明的AuthGiteeRequest)
|
|
||||||
*/
|
|
||||||
@RequestMapping("/render/{source}")
|
|
||||||
public void renderAuth(@PathVariable("source") String source, HttpServletResponse response) throws IOException {
|
|
||||||
AuthRequest authRequest = getAuthRequest(source);
|
|
||||||
String authorizeUrl = authRequest.authorize(AuthStateUtils.createState());
|
|
||||||
response.sendRedirect(authorizeUrl);
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
注:`state`建议必传!`state`在`OAuth`的流程中的主要作用就是保证请求完整性,防止**CSRF**风险,此处传的`state`将在回调时传回
|
|
||||||
|
|
||||||
### 登录(获取用户信息)
|
|
||||||
|
|
||||||
```java
|
|
||||||
AuthResponse response = authRequest.login(callback);
|
|
||||||
```
|
|
||||||
|
|
||||||
授权登录后会返回code(auth_code(仅限支付宝)、authorization_code(仅限华为))、state,1.8.0版本后,用`AuthCallback`类作为回调接口的入参
|
|
||||||
|
|
||||||
**伪代码**
|
|
||||||
|
|
||||||
```java
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @param source 第三方授权平台,以本例为参考,该值为gitee(因为上面声明的AuthGiteeRequest)
|
|
||||||
*/
|
|
||||||
@RequestMapping("/callback/{source}")
|
|
||||||
public Object login(@PathVariable("source") String source, AuthCallback callback) {
|
|
||||||
AuthRequest authRequest = getAuthRequest(source);
|
|
||||||
AuthResponse response = authRequest.login(callback);
|
|
||||||
return response;
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
**注:第三方平台中配置的授权回调地址,以本文为例,在创建授权应用时的回调地址应为:`[host]/callback/gitee`**
|
|
||||||
|
|
||||||
### 刷新token
|
|
||||||
|
|
||||||
注:`refresh`功能,并不是每个平台都支持
|
|
||||||
|
|
||||||
```java
|
|
||||||
AuthResponse response = authRequest.refresh(AuthToken.builder().refreshToken(token).build());
|
|
||||||
```
|
|
||||||
|
|
||||||
**伪代码**
|
|
||||||
|
|
||||||
```java
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @param source 第三方授权平台,以本例为参考,该值为gitee(因为上面声明的AuthGiteeRequest)
|
|
||||||
* @param token login成功后返回的refreshToken
|
|
||||||
*/
|
|
||||||
@RequestMapping("/refresh/{source}")
|
|
||||||
public Object refreshAuth(@PathVariable("source") String source, String token){
|
|
||||||
AuthRequest authRequest = getAuthRequest(source);
|
|
||||||
return authRequest.refresh(AuthToken.builder().refreshToken(token).build());
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
### 取消授权
|
|
||||||
|
|
||||||
注:`revoke`功能,并不是每个平台都支持
|
|
||||||
|
|
||||||
```java
|
|
||||||
AuthResponse response = authRequest.revoke(AuthToken.builder().accessToken(token).build());
|
|
||||||
```
|
|
||||||
|
|
||||||
**伪代码**
|
|
||||||
|
|
||||||
```java
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @param source 第三方授权平台,以本例为参考,该值为gitee(因为上面声明的AuthGiteeRequest)
|
|
||||||
* @param token login成功后返回的accessToken
|
|
||||||
*/
|
|
||||||
@RequestMapping("/revoke/{source}/{token}")
|
|
||||||
public Object revokeAuth(@PathVariable("source") String source, @PathVariable("token") String token) throws IOException {
|
|
||||||
AuthRequest authRequest = getAuthRequest(source);
|
|
||||||
return authRequest.revoke(AuthToken.builder().accessToken(token).build());
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
## 参考文章
|
|
||||||
|
|
||||||
- [实现Gitee授权登录](http://t.cn/ExDKxQs)
|
|
||||||
- [实现Github授权登录](http://t.cn/EJ0Fxqo)
|
|
||||||
- [Spring Boot 快速集成第三方登录功能](http://t.cn/AiWWx5kH) : QQ、Github、微信、谷歌、微软、小米、企业微信
|
|
||||||
- [集成企业微信](https://mp.weixin.qq.com/s?__biz=MzA3NDk3OTIwMg==&mid=2450633170&idx=2&sn=456b70742a86948a193c691f3e47b72e&chksm=8892933fbfe51a29c1da386a2252d4bf91bfbd14e1ac0b99b783763a0d12e2e4b2d7c4369933&token=482455242&lang=zh_CN#rd)
|
|
||||||
|
|
||||||
## 配套项目
|
|
||||||
|
|
||||||
**配套Demo**:
|
|
||||||
- [JustAuth-demo](https://github.com/justauth/JustAuth-demo):普通版springboot项目demo
|
|
||||||
- [jFinal版](https://github.com/xkcoding/jfinal-justauth-demo): Jfinal集成JustAuth的demo by [xkcoding](https://github.com/xkcoding)
|
|
||||||
- [ActFramework版](https://github.com/xkcoding/act-justauth-demo): ActFramework 集成 JustAuth 的 demo by [xkcoding](https://github.com/xkcoding)
|
|
||||||
- [Nutzboot版](https://github.com/EggsBlue/nutzboot-justauth-demo): NutzBoot集成JustAuth的demo by [蛋蛋](https://github.com/EggsBlue)
|
|
||||||
- [Blade版](https://github.com/justauth/blade-justauth-demo): Blade集成JustAuth的demo
|
|
||||||
|
|
||||||
## starter插件
|
|
||||||
- [justauth-spring-boot-starter](https://github.com/xkcoding/justauth-spring-boot-starter): Spring Boot 集成 JustAuth 的最佳实践 by [xkcoding](https://github.com/xkcoding)
|
|
||||||
- [justauth-spring-security-starter](https://github.com/justauth/justauth-spring-security-starter): JustAuth整合Spring security的 starter依赖 by [luoqiz](https://github.com/luoqiz)
|
|
||||||
@@ -12,119 +12,11 @@
|
|||||||
|
|
||||||
<meta itemprop="name" content="JustAuth,史上最全的整合第三方登录的开源库" />
|
<meta itemprop="name" content="JustAuth,史上最全的整合第三方登录的开源库" />
|
||||||
<meta itemprop="description" content="JustAuth,如你所见,它仅仅是一个第三方授权登录的工具类库,它可以让我们脱离繁琐的第三方登录SDK,让登录变得So easy!" />
|
<meta itemprop="description" content="JustAuth,如你所见,它仅仅是一个第三方授权登录的工具类库,它可以让我们脱离繁琐的第三方登录SDK,让登录变得So easy!" />
|
||||||
<meta itemprop="image" content="./_media/cover.png" />
|
|
||||||
|
|
||||||
<link rel="shortcut icon" href="favicon.ico">
|
|
||||||
<link rel="stylesheet" href="//unpkg.com/docsify/lib/themes/vue.css">
|
|
||||||
<link rel="stylesheet" href="//unpkg.com/gitalk/dist/gitalk.css">
|
|
||||||
<link rel="stylesheet" href="//cdn.jsdelivr.net/npm/mermaid/dist/mermaid.min.css">
|
|
||||||
|
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<div data-app id="app">Please wait...</div>
|
|
||||||
<script>
|
<script>
|
||||||
var num = 0;
|
window.location.href = "https://justauth.wiki";
|
||||||
window.$docsify = {
|
|
||||||
el: '#app',
|
|
||||||
name: 'JustAuth',
|
|
||||||
logo: './_media/cover.png',
|
|
||||||
search: {
|
|
||||||
maxAge: 86400000,
|
|
||||||
noData: {
|
|
||||||
'/': '找不到结果'
|
|
||||||
},
|
|
||||||
paths: 'auto',
|
|
||||||
placeholder: {
|
|
||||||
'/': '输入您的关键词进行搜索'
|
|
||||||
}
|
|
||||||
},
|
|
||||||
repo: 'https://gitee.com/yadong.zhang/JustAuth',
|
|
||||||
loadSidebar: true,
|
|
||||||
maxLevel: 4,
|
|
||||||
subMaxLevel: 2,
|
|
||||||
auto2top: true,
|
|
||||||
coverpage: true,
|
|
||||||
autoHeader: true,
|
|
||||||
formatUpdated: '{YYYY}/{MM}/{DD} {HH}:{mm}:{ss}',
|
|
||||||
notFoundPage: '_404.md',
|
|
||||||
plugins: [
|
|
||||||
function (hook, vm) {
|
|
||||||
var footer = [
|
|
||||||
'<hr/>',
|
|
||||||
'<footer>',
|
|
||||||
'<span>JustAuth: <a href="https://github.com/justauth/JustAuth">Github</a> | <a href="https://gitee.com/yadong.zhang/JustAuth">Gitee</a> ©2019.</span>',
|
|
||||||
'<span>Proudly published with <a href="https://github.com/docsifyjs/docsify" target="_blank">docsify</a>.</span>',
|
|
||||||
'</footer>'
|
|
||||||
].join('');
|
|
||||||
hook.afterEach(function (html) {
|
|
||||||
return html + footer
|
|
||||||
});
|
|
||||||
hook.beforeEach(function (html) {
|
|
||||||
var url = 'https://gitee.com/yadong.zhang/JustAuth/tree/master/docs/' + vm.route.file;
|
|
||||||
var editHtml = '[📝 编辑该文档](' + url + ')\n';
|
|
||||||
|
|
||||||
return html
|
|
||||||
+ '\n----\n'
|
|
||||||
+ '最后更新时间: {docsify-updated} '
|
|
||||||
+ editHtml
|
|
||||||
})
|
|
||||||
}
|
|
||||||
],
|
|
||||||
markdown: {
|
|
||||||
renderer: {
|
|
||||||
code: function(code, lang) {
|
|
||||||
if (lang === "mermaid") {
|
|
||||||
return (
|
|
||||||
'<div class="mermaid">' + mermaid.render('mermaid-svg-' + num++, code) + "</div>"
|
|
||||||
);
|
|
||||||
}
|
|
||||||
return this.origin.code.apply(this, arguments);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
<script src="//unpkg.com/docsify/lib/docsify.min.js"></script>
|
|
||||||
<script src="//unpkg.com/docsify/lib/plugins/search.min.js"></script>
|
|
||||||
<script src="//unpkg.com/docsify-copy-code"></script>
|
|
||||||
<script src="//cdn.jsdelivr.net/npm/mermaid/dist/mermaid.min.js"></script>
|
|
||||||
<script>mermaid.initialize({startOnLoad:true});</script>
|
|
||||||
<script src="//unpkg.com/prismjs/components/prism-java.min.js"></script>
|
|
||||||
|
|
||||||
<script src="//unpkg.com/docsify/lib/plugins/gitalk.min.js"></script>
|
|
||||||
<script src="//unpkg.com/gitalk/dist/gitalk.min.js"></script>
|
|
||||||
|
|
||||||
<script>
|
|
||||||
const gitalk = new Gitalk({
|
|
||||||
clientID: 'e58f172df200e88e266b',
|
|
||||||
clientSecret: 'ee22ce68934616f7de043a950cbdb7d613a03202',
|
|
||||||
repo: 'justauth-talk',
|
|
||||||
owner: 'zhangyd-c',
|
|
||||||
admin: ['zhangyd-c'],
|
|
||||||
id: location.hash,
|
|
||||||
// facebook-like distraction free mode
|
|
||||||
distractionFreeMode: false
|
|
||||||
})
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<!-- 百度统计 -->
|
|
||||||
<script>
|
|
||||||
var _hmt = _hmt || [];
|
|
||||||
(function() {
|
|
||||||
var hm = document.createElement("script");
|
|
||||||
hm.src = "https://hm.baidu.com/hm.js?4c7a1a462477545b480a3dd1ed95f0a9";
|
|
||||||
var s = document.getElementsByTagName("script")[0];
|
|
||||||
s.parentNode.insertBefore(hm, s);
|
|
||||||
})();
|
|
||||||
</script>
|
|
||||||
<!-- Global site tag (gtag.js) - Google Analytics -->
|
|
||||||
<script async src="https://www.googletagmanager.com/gtag/js?id=UA-151202614-1"></script>
|
|
||||||
<script>
|
|
||||||
window.dataLayer = window.dataLayer || [];
|
|
||||||
function gtag(){dataLayer.push(arguments);}
|
|
||||||
gtag('js', new Date());
|
|
||||||
|
|
||||||
gtag('config', 'UA-151202614-1');
|
|
||||||
</script>
|
</script>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|||||||
|
After Width: | Height: | Size: 49 KiB |
@@ -1,82 +0,0 @@
|
|||||||
# 关于OAuth
|
|
||||||
|
|
||||||
请先查阅以下资料:
|
|
||||||
|
|
||||||
- [The OAuth 2.0 Authorization Framework](https://tools.ietf.org/html/rfc6749)
|
|
||||||
- [OAuth 2.0](https://oauth.net/2/)
|
|
||||||
|
|
||||||
## OAuth 2 的授权流程
|
|
||||||
|
|
||||||
### 参与的角色
|
|
||||||
|
|
||||||
- `Resource Owner` 资源所有者,即代表授权客户端访问本身资源信息的用户(User),也就是应用场景中的“**开发者A**”
|
|
||||||
- `Resource Server` 资源服务器,托管受保护的**用户账号信息**,比如Github
|
|
||||||
- `Authorization Server` 授权服务器,**验证用户身份**然后为客户端派发资源访问令牌,比如Github
|
|
||||||
- `Resource Server`和`Authorization Server` 可以是同一台服务器,也可以是不同的服务器,视具体的授权平台而有所差异
|
|
||||||
- `Client` 客户端,即代表意图访问受限资源的**第三方应用**
|
|
||||||
|
|
||||||
### 授权流程
|
|
||||||
```html
|
|
||||||
+--------+ +---------------+
|
|
||||||
| |--(A)- Authorization Request ->| Resource |
|
|
||||||
| | | Owner |
|
|
||||||
| |<-(B)-- Authorization Grant ---| |
|
|
||||||
| | +---------------+
|
|
||||||
| |
|
|
||||||
| | +---------------+
|
|
||||||
| |--(C)-- Authorization Grant -->| Authorization |
|
|
||||||
| Client | | Server |
|
|
||||||
| |<-(D)----- Access Token -------| |
|
|
||||||
| | +---------------+
|
|
||||||
| |
|
|
||||||
| | +---------------+
|
|
||||||
| |--(E)----- Access Token ------>| Resource |
|
|
||||||
| | | Server |
|
|
||||||
| |<-(F)--- Protected Resource ---| |
|
|
||||||
+--------+ +---------------+
|
|
||||||
```
|
|
||||||
|
|
||||||
上面的流程图取自[The OAuth 2.0 Authorization Framework#1.2](https://tools.ietf.org/html/rfc6749#section-1.2)
|
|
||||||
|
|
||||||
**流程解析**
|
|
||||||
|
|
||||||
- (A) 用户打开**客户端**以后,**客户端**要求**用户**给予授权。
|
|
||||||
- (B) **用户**同意给予**客户端**授权。
|
|
||||||
- (C) **客户端**使用上一步获得的授权,向**认证服务器**申请令牌。
|
|
||||||
- (D) **认证服务器**对**客户端**进行认证以后,确认无误,同意发放令牌
|
|
||||||
- (E) **客户端**使用令牌,向**资源服务器**申请获取资源。
|
|
||||||
- (F) **资源服务器**确认令牌无误,同意向**客户端**开放资源。
|
|
||||||
|
|
||||||
### 授权许可 `Authorization Grant`
|
|
||||||
|
|
||||||
- Authorization Code
|
|
||||||
- 结合普通服务器端应用使用(**web**端常用的授权方式)
|
|
||||||
- Implicit
|
|
||||||
- 结合移动应用或 Web App 使用
|
|
||||||
- Resource Owner Password Credentials
|
|
||||||
- 适用于受信任客户端应用,例如同个组织的内部或外部应用
|
|
||||||
- Client Credentials
|
|
||||||
- 适用于客户端调用主服务API型应用(比如百度API Store)
|
|
||||||
|
|
||||||
## 直白话 OAuth 2 流程
|
|
||||||
|
|
||||||
以上流程理解起来可能有些难度,这儿我们给出一个白话版的流程图
|
|
||||||
|
|
||||||
这儿引入三个角色:
|
|
||||||
- 用户A:可以理解成你自己
|
|
||||||
- 网站B:可以理解成 Oschina
|
|
||||||
- 第三方C:可以理解成 Github
|
|
||||||
|
|
||||||
需求:你想通过Github第三方登录Oschina。(_注:下面的内容为流程图,如果您在阅读的时候显示为纯文字,请刷新页面_)
|
|
||||||
|
|
||||||
<div class="mermaid">
|
|
||||||
sequenceDiagram
|
|
||||||
用户A->>网站B: 1.我想登录你
|
|
||||||
网站B->>用户A: 2.我不认识你
|
|
||||||
用户A->>第三方C: 3.老铁我去过你那儿,咱俩认识,你帮我授权给网站B
|
|
||||||
第三方C->>网站B: 4.用户A是我老铁,给你他的授权码
|
|
||||||
网站B->>第三方C: 5.这个授权码是你那儿的人吗?是的话给我他的令牌
|
|
||||||
第三方C->>网站B: 6.是我这儿的人,让他登录吧
|
|
||||||
网站B->>用户A: 7.得嘞,您走着
|
|
||||||
用户A->>网站B: 8.登录成功
|
|
||||||
</div>
|
|
||||||
@@ -1,215 +0,0 @@
|
|||||||
## 1. 配置应用
|
|
||||||
|
|
||||||
### 1.1 创建应用
|
|
||||||
|
|
||||||
#### 1. 进入支付宝开放平台([open.alipay.com](https://open.alipay.com))并登录
|
|
||||||
#### 2. 点击“进入我的开放平台”
|
|
||||||

|
|
||||||
#### 3. 通过 **开发者中心-网页&移动应用** 进入应用管理列表页
|
|
||||||

|
|
||||||

|
|
||||||
#### 4. 选择创建 **自定义接入** 应用
|
|
||||||

|
|
||||||
#### 5. 填入相关信息确认创建
|
|
||||||

|
|
||||||
#### 6. 进入应用详情后,点击【功能列表】中的【**+添加功能**】按钮,选择【获取会员信息】
|
|
||||||

|
|
||||||

|
|
||||||
|
|
||||||
### 1.2 配置密钥
|
|
||||||
开发者调用接口前需要先生成RSA密钥,RSA密钥包含应用私钥(APP_PRIVATE_KEY)、应用公钥(APP_PUBLIC_KEY)。生成密钥后在开放平台开发者中心进行密钥配置,配置完成后可以获取支付宝公钥(ALIPAY_PUBLIC_KEY)。
|
|
||||||
|
|
||||||
接下来我们要在【应用详情】最下面的【开发设置】中,配置密钥相关的内容
|
|
||||||
#### 1. 接口加签方式
|
|
||||||
此处生成密钥的详细说明可以参考:[生成 RSA 密钥 ](https://docs.open.alipay.com/291/105971/)
|
|
||||||
|
|
||||||
我们这儿简单介绍一种使用“公钥”加签的方式
|
|
||||||
|
|
||||||
a. 首先下载密钥生成工具:[Windows版](https://ideservice.alipay.com/ide/getPluginUrl.htm?clientType=assistant&platform=win&channelType=WEB)(请不要安装在含有空格的目录路径下) | [MAC_OS版](https://ideservice.alipay.com/ide/getPluginUrl.htm?clientType=assistant&platform=mac&channelType=WEB)
|
|
||||||
|
|
||||||
b. 点击 【生成密钥】 后,工具会自动生成商户应用公钥(public key)和应用私钥(private key),如下图所示:
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
点击工具界面下方的 【打开文件位置】,即可找到生成的公私钥文件,这儿需要注意!
|
|
||||||
|
|
||||||
工具默认打开的是CSR目录,并不是我们生成的密钥的目录,如下图:
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
我们只需要往前返回一级目录,就可看到 RSA密钥 文件夹,进入 RSA密钥 目录后就可看到我们刚刚生成的密钥文件,如下图所示:
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
注意:应用私钥需要在JustAuth中配置。
|
|
||||||
|
|
||||||
c. 回到应用详情页面,点击【接口加签方式】后面的【设置】按钮,【加签模式】中选择【公钥】,然后在下方输入框中输入之前生成的【应用公钥2048.txt】文件内容
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
保存设置后,将会生成一份【支付宝公钥】,注意:这个公钥会在OAuth中使用!
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
**注意:**
|
|
||||||
|
|
||||||
生成的私钥需**妥善保管,避免遗失,不要泄露**。应用私钥需填写到代码中供签名时使用。应用公钥需提供给支付宝账号管理者上传到支付宝开放平台。
|
|
||||||
|
|
||||||
#### 2. 接口加签方式
|
|
||||||
|
|
||||||
关于IP白名单的配置方式,请参考:[开放平台 IP 白名单接入指南 ](https://docs.open.alipay.com/200/ipwhitelist)
|
|
||||||
|
|
||||||
#### 3. 支付宝网关
|
|
||||||
|
|
||||||
使用默认的即可:https://openapi.alipay.com/gateway.do
|
|
||||||
|
|
||||||
#### 4. 应用网关
|
|
||||||
|
|
||||||
这是选填字段,主要用来接收支付宝的异步通知。请开发者视个人情况选择使用
|
|
||||||
|
|
||||||
#### 5. 授权回调地址
|
|
||||||
|
|
||||||
这是关键内容,JustAuth中需要用到。比如本例配置的回调地址为:https://www.zhyd.me/oauth/callback/alipay
|
|
||||||
|
|
||||||
|
|
||||||
以上步骤比较繁杂,主要需要注意保存的信息为:
|
|
||||||
- 使用【支付宝开放平台开发助手】生成的【应用私钥】(应用私钥2048.txt)
|
|
||||||
- 配置【接口加签方式】时生成的【支付宝公钥】
|
|
||||||
- 授权回调地址
|
|
||||||
- APPID(应用详情左侧应用名称下方有标注)
|
|
||||||
|
|
||||||
### 1.3 应用提交审核
|
|
||||||
|
|
||||||
通过应用详情上方的【提交审核】按钮,将应用提交审核,大约需要1天左右。(ps:本例的应用,我从提交审核到审核完成,大约用了两个小时)
|
|
||||||
|
|
||||||
## 2. 集成JustAuth
|
|
||||||
|
|
||||||
|
|
||||||
### 2.1 引入依赖
|
|
||||||
|
|
||||||
```xml
|
|
||||||
<dependency>
|
|
||||||
<groupId>me.zhyd.oauth</groupId>
|
|
||||||
<artifactId>JustAuth</artifactId>
|
|
||||||
<version>${latest.version}</version>
|
|
||||||
</dependency>
|
|
||||||
```
|
|
||||||
|
|
||||||
`${latest.version}`表示当前最新的版本,可以在[这儿](https://github.com/justauth/JustAuth/releases)获取最新的版本信息。
|
|
||||||
|
|
||||||
### 2.2 创建Request
|
|
||||||
|
|
||||||
```java
|
|
||||||
AuthRequest authRequest = new AuthAlipayRequest(AuthConfig.builder()
|
|
||||||
.clientId("APPID")
|
|
||||||
.clientSecret("应用私钥")
|
|
||||||
.alipayPublicKey("支付宝公钥")
|
|
||||||
.redirectUri("https://www.zhyd.me/oauth/callback/alipay")
|
|
||||||
.build());
|
|
||||||
```
|
|
||||||
|
|
||||||
### 2.3 生成授权地址
|
|
||||||
|
|
||||||
我们可以直接使用以下方式生成第三方平台的授权链接:
|
|
||||||
```java
|
|
||||||
String authorizeUrl = authRequest.authorize(AuthStateUtils.createState());
|
|
||||||
```
|
|
||||||
这个链接我们可以直接后台重定向跳转,也可以返回到前端后,前端控制跳转。前端控制的好处就是,可以将第三方的授权页嵌入到iframe中,适配网站设计。
|
|
||||||
|
|
||||||
|
|
||||||
### 2.4 以上完整代码如下
|
|
||||||
|
|
||||||
```java
|
|
||||||
import me.zhyd.oauth.config.AuthConfig;
|
|
||||||
import me.zhyd.oauth.request.AuthAlipayRequest;
|
|
||||||
import me.zhyd.oauth.model.AuthCallback;
|
|
||||||
import me.zhyd.oauth.request.AuthRequest;
|
|
||||||
import me.zhyd.oauth.utils.AuthStateUtils;
|
|
||||||
import org.springframework.web.bind.annotation.PathVariable;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
|
|
||||||
@RestController
|
|
||||||
@RequestMapping("/oauth")
|
|
||||||
public class RestAuthController {
|
|
||||||
|
|
||||||
@RequestMapping("/render")
|
|
||||||
public void renderAuth(HttpServletResponse response) throws IOException {
|
|
||||||
AuthRequest authRequest = getAuthRequest();
|
|
||||||
response.sendRedirect(authRequest.authorize(AuthStateUtils.createState()));
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping("/callback")
|
|
||||||
public Object login(AuthCallback callback) {
|
|
||||||
AuthRequest authRequest = getAuthRequest();
|
|
||||||
return authRequest.login(callback);
|
|
||||||
}
|
|
||||||
|
|
||||||
private AuthRequest getAuthRequest() {
|
|
||||||
return new AuthAlipayRequest(AuthConfig.builder()
|
|
||||||
.clientId("APPID")
|
|
||||||
.clientSecret("应用私钥")
|
|
||||||
.alipayPublicKey("支付宝公钥")
|
|
||||||
.redirectUri("https://www.zhyd.me/oauth/callback/alipay")
|
|
||||||
.build());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
授权链接访问成功后会看到以下页面内容:
|
|
||||||

|
|
||||||
|
|
||||||
手机扫码后会进去确认页面
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
手机端点击确认后,web端将会跳转到授权认证页面
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
点击同意授权即可完成支付宝的oauth登录。
|
|
||||||
|
|
||||||
## 3. 授权结果
|
|
||||||
|
|
||||||
```json
|
|
||||||
{
|
|
||||||
"code": 2000,
|
|
||||||
"msg": null,
|
|
||||||
"data": {
|
|
||||||
"uuid": "208xxxxx37",
|
|
||||||
"username": "张",
|
|
||||||
"nickname": "张",
|
|
||||||
"avatar": "https://tfs.alipayobjects.com/images/partner/T1vzlgXj8cXXXXXXXX",
|
|
||||||
"blog": null,
|
|
||||||
"company": null,
|
|
||||||
"location": "北京 北京市",
|
|
||||||
"email": null,
|
|
||||||
"remark": null,
|
|
||||||
"gender": "MALE",
|
|
||||||
"source": "ALIPAY",
|
|
||||||
"token": {
|
|
||||||
"accessToken": "authxxxx2d5b0a182A53",
|
|
||||||
"expireIn": 1296000,
|
|
||||||
"refreshToken": "authuxxxx4c1b0edb2X53",
|
|
||||||
"uid": "208xxxxx37",
|
|
||||||
"openId": null,
|
|
||||||
"accessCode": null,
|
|
||||||
"unionId": null,
|
|
||||||
"scope": null,
|
|
||||||
"tokenType": null,
|
|
||||||
"idToken": null,
|
|
||||||
"macAlgorithm": null,
|
|
||||||
"macKey": null,
|
|
||||||
"code": null,
|
|
||||||
"oauthToken": null,
|
|
||||||
"oauthTokenSecret": null,
|
|
||||||
"userId": null,
|
|
||||||
"screenName": null,
|
|
||||||
"oauthCallbackConfirmed": null
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
(敬请期待...)
|
|
||||||
|
|
||||||
## 1. 申请应用
|
|
||||||
|
|
||||||
## 2. 集成JustAuth
|
|
||||||
|
|
||||||
## 3. 授权结果
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
(敬请期待...)
|
|
||||||
|
|
||||||
## 1. 申请应用
|
|
||||||
|
|
||||||
## 2. 集成JustAuth
|
|
||||||
|
|
||||||
## 3. 授权结果
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
(敬请期待...)
|
|
||||||
|
|
||||||
## 1. 申请应用
|
|
||||||
|
|
||||||
## 2. 集成JustAuth
|
|
||||||
|
|
||||||
## 3. 授权结果
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
(敬请期待...)
|
|
||||||
|
|
||||||
## 1. 申请应用
|
|
||||||
|
|
||||||
## 2. 集成JustAuth
|
|
||||||
|
|
||||||
## 3. 授权结果
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
(敬请期待...)
|
|
||||||
|
|
||||||
## 1. 申请应用
|
|
||||||
|
|
||||||
## 2. 集成JustAuth
|
|
||||||
|
|
||||||
## 3. 授权结果
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
(敬请期待...)
|
|
||||||
|
|
||||||
## 1. 申请应用
|
|
||||||
|
|
||||||
## 2. 集成JustAuth
|
|
||||||
|
|
||||||
## 3. 授权结果
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
(敬请期待...)
|
|
||||||
|
|
||||||
## 1. 申请应用
|
|
||||||
|
|
||||||
## 2. 集成JustAuth
|
|
||||||
|
|
||||||
## 3. 授权结果
|
|
||||||
@@ -1,146 +0,0 @@
|
|||||||
## 1. 申请应用
|
|
||||||
|
|
||||||
### 1.1 注册账号
|
|
||||||
|
|
||||||
注册Gitee账号:[https://gitee.com](https://gitee.com)。如果已有则忽略该步骤,直接进入第二步。
|
|
||||||
|
|
||||||
### 1.2 创建第三方授权应用
|
|
||||||
|
|
||||||
进入第三方应用页面([https://gitee.com/oauth/applications](https://gitee.com/oauth/applications))
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
创建应用
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
- **应用名称** 一般填写自己的网站名称即可
|
|
||||||
- **应用描述** 一般填写自己的应用描述即可
|
|
||||||
- **应用主页** 填写自己的网站首页地址
|
|
||||||
- **应用回调地址** 重点,该地址为用户授权后需要跳转到的自己网站的地址,默认携带一个code参数
|
|
||||||
- **权限** 根据页面提示操作,默认勾选第一个就行。
|
|
||||||
|
|
||||||
以上信息输入完成后,点击确定按钮创建应用。创建完成后,点击进入应用详情页,可以看到应用的密钥等信息
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
记录以下三个信息:`Client ID`、`Client Secret`和`应用回调地址`,后面我们会用到
|
|
||||||
|
|
||||||
|
|
||||||
## 2. 集成JustAuth
|
|
||||||
|
|
||||||
### 2.1 引入依赖
|
|
||||||
|
|
||||||
```xml
|
|
||||||
<dependency>
|
|
||||||
<groupId>me.zhyd.oauth</groupId>
|
|
||||||
<artifactId>JustAuth</artifactId>
|
|
||||||
<version>${latest.version}</version>
|
|
||||||
</dependency>
|
|
||||||
```
|
|
||||||
|
|
||||||
`${latest.version}`表示当前最新的版本,可以在[这儿](https://github.com/justauth/JustAuth/releases)获取最新的版本信息。
|
|
||||||
|
|
||||||
### 2.2 创建Request
|
|
||||||
|
|
||||||
```java
|
|
||||||
AuthRequest authRequest = new AuthGiteeRequest(AuthConfig.builder()
|
|
||||||
.clientId("Client ID")
|
|
||||||
.clientSecret("Client Secret")
|
|
||||||
.redirectUri("应用回调地址")
|
|
||||||
.build());
|
|
||||||
```
|
|
||||||
|
|
||||||
### 2.3 生成授权地址
|
|
||||||
|
|
||||||
我们可以直接使用以下方式生成第三方平台的授权链接:
|
|
||||||
```java
|
|
||||||
String authorizeUrl = authRequest.authorize(AuthStateUtils.createState());
|
|
||||||
```
|
|
||||||
这个链接我们可以直接后台重定向跳转,也可以返回到前端后,前端控制跳转。前端控制的好处就是,可以将第三方的授权页嵌入到iframe中,适配网站设计。
|
|
||||||
|
|
||||||
|
|
||||||
### 2.4 以上完整代码如下
|
|
||||||
|
|
||||||
```java
|
|
||||||
import me.zhyd.oauth.config.AuthConfig;
|
|
||||||
import me.zhyd.oauth.request.AuthGiteeRequest;
|
|
||||||
import me.zhyd.oauth.model.AuthCallback;
|
|
||||||
import me.zhyd.oauth.request.AuthRequest;
|
|
||||||
import me.zhyd.oauth.utils.AuthStateUtils;
|
|
||||||
import org.springframework.web.bind.annotation.PathVariable;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
|
|
||||||
@RestController
|
|
||||||
@RequestMapping("/oauth")
|
|
||||||
public class RestAuthController {
|
|
||||||
|
|
||||||
@RequestMapping("/render")
|
|
||||||
public void renderAuth(HttpServletResponse response) throws IOException {
|
|
||||||
AuthRequest authRequest = getAuthRequest();
|
|
||||||
response.sendRedirect(authRequest.authorize(AuthStateUtils.createState()));
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping("/callback")
|
|
||||||
public Object login(AuthCallback callback) {
|
|
||||||
AuthRequest authRequest = getAuthRequest();
|
|
||||||
return authRequest.login(callback);
|
|
||||||
}
|
|
||||||
|
|
||||||
private AuthRequest getAuthRequest() {
|
|
||||||
return new AuthGiteeRequest(AuthConfig.builder()
|
|
||||||
.clientId("Client ID")
|
|
||||||
.clientSecret("Client Secret")
|
|
||||||
.redirectUri("应用回调地址")
|
|
||||||
.build());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
授权链接访问成功后会看到以下页面内容:
|
|
||||||

|
|
||||||
|
|
||||||
点击同意授权即可完成gitee的oauth登录。
|
|
||||||
|
|
||||||
## 3. 授权结果
|
|
||||||
|
|
||||||
注:数据已脱敏
|
|
||||||
|
|
||||||
```json
|
|
||||||
{
|
|
||||||
"code": 2000,
|
|
||||||
"msg": null,
|
|
||||||
"data": {
|
|
||||||
"uuid": "xxx",
|
|
||||||
"username": "yadong.zhang",
|
|
||||||
"nickname": "yadong.zhang",
|
|
||||||
"avatar": "https://avatar.gitee.com/uploads/99/784199_yadong.zhang.png?1462325358",
|
|
||||||
"blog": "https://www.zhyd.me",
|
|
||||||
"company": null,
|
|
||||||
"location": null,
|
|
||||||
"email": null,
|
|
||||||
"remark": "程序员",
|
|
||||||
"gender": "UNKNOWN",
|
|
||||||
"source": "GITEE",
|
|
||||||
"token": {
|
|
||||||
"accessToken": "630740bxxxxxxxx4",
|
|
||||||
"expireIn": 86400,
|
|
||||||
"refreshToken": "1f2e0faedxxxxx537ec8",
|
|
||||||
"uid": null,
|
|
||||||
"openId": null,
|
|
||||||
"accessCode": null,
|
|
||||||
"unionId": null,
|
|
||||||
"scope": "user_info",
|
|
||||||
"tokenType": "bearer",
|
|
||||||
"idToken": null,
|
|
||||||
"macAlgorithm": null,
|
|
||||||
"macKey": null,
|
|
||||||
"code": null
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
@@ -1,145 +0,0 @@
|
|||||||
## 1. 申请应用
|
|
||||||
|
|
||||||
### 1.注册Github账号
|
|
||||||
https://github.com/。如果已有则忽略该步骤,直接进入第二步。
|
|
||||||
### 2.创建第三方应用
|
|
||||||
进入通过右上角进入个人设置页:https://github.com/settings/profile
|
|
||||||

|
|
||||||
然后进入第三方应用页面:https://github.com/settings/developers
|
|
||||||

|
|
||||||
|
|
||||||
在应用管理页面,选择`OAuth App`,然后点击右上方的`New OAuth App`按钮进入新建应用页面
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
`Application name` 一般填写自己的网站名称即可
|
|
||||||
`Application description` 一般填写自己的应用描述即可
|
|
||||||
`Homepage URL` 填写自己的网站首页地址
|
|
||||||
`Authorization callback URL` **重点**,该地址为用户授权后需要跳转到的自己网站的地址,默认携带一个`code`参数
|
|
||||||
|
|
||||||
以上信息输入完成后,点击下方绿色的`Register applaction`按钮创建应用。创建完成后,点击进入应用详情页,可以看到应用的密钥等信息
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
copy以下三个信息:`Client ID`、`Client Secret`和`Authorization callback URL`。
|
|
||||||
|
|
||||||
## 2. 集成JustAuth
|
|
||||||
|
|
||||||
|
|
||||||
### 2.1 引入依赖
|
|
||||||
|
|
||||||
```xml
|
|
||||||
<dependency>
|
|
||||||
<groupId>me.zhyd.oauth</groupId>
|
|
||||||
<artifactId>JustAuth</artifactId>
|
|
||||||
<version>${latest.version}</version>
|
|
||||||
</dependency>
|
|
||||||
```
|
|
||||||
|
|
||||||
`${latest.version}`表示当前最新的版本,可以在[这儿](https://github.com/justauth/JustAuth/releases)获取最新的版本信息。
|
|
||||||
|
|
||||||
### 2.2 创建Request
|
|
||||||
|
|
||||||
```java
|
|
||||||
AuthRequest authRequest = new AuthGithubRequest(AuthConfig.builder()
|
|
||||||
.clientId("Client ID")
|
|
||||||
.clientSecret("Client Secret")
|
|
||||||
.redirectUri("应用回调地址")
|
|
||||||
.build());
|
|
||||||
```
|
|
||||||
|
|
||||||
### 2.3 生成授权地址
|
|
||||||
|
|
||||||
我们可以直接使用以下方式生成第三方平台的授权链接:
|
|
||||||
```java
|
|
||||||
String authorizeUrl = authRequest.authorize(AuthStateUtils.createState());
|
|
||||||
```
|
|
||||||
这个链接我们可以直接后台重定向跳转,也可以返回到前端后,前端控制跳转。前端控制的好处就是,可以将第三方的授权页嵌入到iframe中,适配网站设计。
|
|
||||||
|
|
||||||
|
|
||||||
### 2.4 以上完整代码如下
|
|
||||||
|
|
||||||
```java
|
|
||||||
import me.zhyd.oauth.config.AuthConfig;
|
|
||||||
import me.zhyd.oauth.request.AuthGithubRequest;
|
|
||||||
import me.zhyd.oauth.model.AuthCallback;
|
|
||||||
import me.zhyd.oauth.request.AuthRequest;
|
|
||||||
import me.zhyd.oauth.utils.AuthStateUtils;
|
|
||||||
import org.springframework.web.bind.annotation.PathVariable;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
|
|
||||||
@RestController
|
|
||||||
@RequestMapping("/oauth")
|
|
||||||
public class RestAuthController {
|
|
||||||
|
|
||||||
@RequestMapping("/render")
|
|
||||||
public void renderAuth(HttpServletResponse response) throws IOException {
|
|
||||||
AuthRequest authRequest = getAuthRequest();
|
|
||||||
response.sendRedirect(authRequest.authorize(AuthStateUtils.createState()));
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping("/callback")
|
|
||||||
public Object login(AuthCallback callback) {
|
|
||||||
AuthRequest authRequest = getAuthRequest();
|
|
||||||
return authRequest.login(callback);
|
|
||||||
}
|
|
||||||
|
|
||||||
private AuthRequest getAuthRequest() {
|
|
||||||
return new AuthGithubRequest(AuthConfig.builder()
|
|
||||||
.clientId("Client ID")
|
|
||||||
.clientSecret("Client Secret")
|
|
||||||
.redirectUri("应用回调地址")
|
|
||||||
.build());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
授权链接访问成功后会看到以下页面内容:
|
|
||||||

|
|
||||||
|
|
||||||
输入账号密码登录完成后将会进入授权页面
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
点击同意授权即可完成github的oauth登录。
|
|
||||||
|
|
||||||
## 3. 授权结果
|
|
||||||
|
|
||||||
```json
|
|
||||||
{
|
|
||||||
"code": 2000,
|
|
||||||
"msg": null,
|
|
||||||
"data": {
|
|
||||||
"uuid": "xxx",
|
|
||||||
"username": "zhangyd-c",
|
|
||||||
"nickname": "yadong.zhang",
|
|
||||||
"avatar": "https://avatars3.githubusercontent.com/u/12689082?v=4",
|
|
||||||
"blog": "https://www.zhyd.me",
|
|
||||||
"company": "",
|
|
||||||
"location": "Beijing",
|
|
||||||
"email": "yadong.zhang0415@gmail.com",
|
|
||||||
"remark": "心之所向,无所不能",
|
|
||||||
"gender": "UNKNOWN",
|
|
||||||
"source": "GITHUB",
|
|
||||||
"token": {
|
|
||||||
"accessToken": "6bb4228efdxxxxxx578148e3",
|
|
||||||
"expireIn": 0,
|
|
||||||
"refreshToken": null,
|
|
||||||
"uid": null,
|
|
||||||
"openId": null,
|
|
||||||
"accessCode": null,
|
|
||||||
"unionId": null,
|
|
||||||
"scope": null,
|
|
||||||
"tokenType": "bearer",
|
|
||||||
"idToken": null,
|
|
||||||
"macAlgorithm": null,
|
|
||||||
"macKey": null,
|
|
||||||
"code": null
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
(敬请期待...)
|
|
||||||
|
|
||||||
## 1. 申请应用
|
|
||||||
|
|
||||||
## 2. 集成JustAuth
|
|
||||||
|
|
||||||
## 3. 授权结果
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
(敬请期待...)
|
|
||||||
|
|
||||||
## 1. 申请应用
|
|
||||||
|
|
||||||
## 2. 集成JustAuth
|
|
||||||
|
|
||||||
## 3. 授权结果
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
(敬请期待...)
|
|
||||||
|
|
||||||
## 1. 申请应用
|
|
||||||
|
|
||||||
## 2. 集成JustAuth
|
|
||||||
|
|
||||||
## 3. 授权结果
|
|
||||||
@@ -1,162 +0,0 @@
|
|||||||
## 1. 申请应用
|
|
||||||
企业可通过两种途径申请应用,一、直接通过线下商务合作,由商务人员线下提供开通的对应应用的秘钥信息。二、线上自助申请(此步骤申请的应用可以在应用审核上线后出现在商家后台的应用市场内)。此步骤主要介绍线上自助申请的流程,若以获取到对应的秘钥信息,则直接进入步骤2.
|
|
||||||
注意:目前酷家乐的开放平台只针对合作企业开放,暂时不对个人开发者开放。商务合作或酷家乐应用市场相关信息可访问[https://www.kujiale.com/](酷家乐首页)通过首页上的在线客服咨询。
|
|
||||||
### 1.1 注册账号
|
|
||||||
注册酷家乐账号:[https://www.kujiale.com/](https://www.kujiale.com/)。如果已有则忽略该步骤,直接进入第二步。(一般建议直接使用企业账号)
|
|
||||||
### 1.2 认证开发者
|
|
||||||
进入酷家乐开放平台([https://open.kujiale.com/](https://open.kujiale.com/))点击右上角的管理中心进入第三方应用管理页面。
|
|
||||||

|
|
||||||
首次进入左侧菜单栏的-服务入驻申请模块,系统会要求进行开发者实名认证。
|
|
||||||

|
|
||||||
根据实名认证的流程,开发者需要依次提供:1.开发者信息,2.开发者企业信息,3.开发者企业人员构成信息,4.开发者企业经验背景信息
|
|
||||||

|
|
||||||
在2-3个工作日内,酷家乐运营同学会对提交信息进行审核,审核通过后可进入应用申请。
|
|
||||||
ps:如果有商务同学跟进的话可以联系商务同学提速,基本在1小时内能得到响应。
|
|
||||||
### 1.2 创建第三方授权应用
|
|
||||||
进入服务入驻申请模块([https://open.kujiale.com/open/management/service-application](服务入驻申请)),申请应用服务。
|
|
||||||

|
|
||||||
选择服务类型以后提供相应的应用信息申请应用。
|
|
||||||

|
|
||||||
oauth2.0基础信息
|
|
||||||
- **应用名称** 一般填写自己的网站名称即可
|
|
||||||
- **应用简介** 填写应用描述,预期实现的功能场景。
|
|
||||||
- **应用回调地址** 重点,该地址为用户授权后需要跳转到的自己网站的地址,默认携带一个code参数
|
|
||||||
- **OAuth申请** 根据申请应用的具体业务场景而定,获取账号基本信息为其他权限(可申请用户授权资源项)申请的基础,即获取账号基本信息必选。若只是依托于酷家乐账号登录则只选择获取账号基本信息即可。
|
|
||||||
应用市场基础信息(当前只提供应用市场申请能力;应用市场的具体的营销规则,合作模式以及营销分成规则可通过在线客服与我们的商务同学取得联系。)
|
|
||||||
- **应用图标** 应用图标是应用展示在酷家乐应用市场内的图片表示,一般可以提供商家的品牌logo
|
|
||||||
- **购买通知地址** 当应用在应用市场内由其他商家付钱触发购买行为,酷家乐会通过此接口向第三方推送购买通知。
|
|
||||||
联系信息
|
|
||||||
- **咨询电话** 第三方需要为自己在酷家乐应用市场内的应用提供客户咨询能力。
|
|
||||||
- **客服链接** 第三方需要为自己在酷家乐应用市场内的应用提供客服支持。
|
|
||||||
- **开发者邮箱** 应用负责人联系邮箱,用于推送相关应用信息,例如:应用状态,应用服务情况,应用数据统计情况,以及相关的酷家乐接口迭代推送。
|
|
||||||
- **开发者电话** 应用负责人联系人电话,帮助在系统层面出现问题时候可以快速联系到负责人。
|
|
||||||
协议信息
|
|
||||||
- **应用协议名称** 应用的使用者需要知晓并且同意的协议名称。
|
|
||||||
- **应用协议内容** 应用的使用者需要知晓并且同意才可以使用购买该应用的协议内容。
|
|
||||||
|
|
||||||
保存并提交审核后,由运营在管理后台审核应用的相关信息以及应用申请相关权限的合理性。在审核通过后,可以在应用服务模块中查看到该应用,同时访问应用详情可以获取到此应用的秘钥信息(client_id:应用的唯一标识。client_secret:client_id对应的密钥,访问用户资源时用来验证应用的合法性。)
|
|
||||||
|
|
||||||
## 2. 集成JustAuth
|
|
||||||
|
|
||||||
### 2.1 引入依赖
|
|
||||||
|
|
||||||
```xml
|
|
||||||
<dependency>
|
|
||||||
<groupId>me.zhyd.oauth</groupId>
|
|
||||||
<artifactId>JustAuth</artifactId>
|
|
||||||
<version>${latest.version}</version>
|
|
||||||
</dependency>
|
|
||||||
```
|
|
||||||
|
|
||||||
`${latest.version}`表示当前最新的版本,可以在[这儿](https://github.com/justauth/JustAuth/releases)获取最新的版本信息。
|
|
||||||
|
|
||||||
### 2.2 创建Request
|
|
||||||
|
|
||||||
```java
|
|
||||||
AuthRequest authRequest = new AuthKujialeRequest(AuthConfig.builder()
|
|
||||||
.clientId("Client ID")
|
|
||||||
.clientSecret("Client Secret")
|
|
||||||
.redirectUri("应用回调地址")
|
|
||||||
.build());
|
|
||||||
```
|
|
||||||
|
|
||||||
### 2.3 生成授权地址
|
|
||||||
|
|
||||||
我们可以直接使用以下方式生成第三方平台的授权链接:
|
|
||||||
```java
|
|
||||||
String authorizeUrl = authRequest.authorize(String state);
|
|
||||||
```
|
|
||||||
这个授权链接,默认的是`get_user_info`scope,即只想用户申请用户基本信息的授权,如果想自定义`scope`可以使用如下方式,单独传入对应的`scope`即可
|
|
||||||
```java
|
|
||||||
String authorizeUrl = authRequest.authorize(String state, String scopeStr);
|
|
||||||
```
|
|
||||||
这个链接我们可以直接后台重定向跳转,也可以返回到前端后,前端控制跳转。前端控制的好处就是,可以将第三方的授权页嵌入到iframe中,适配网站设计。
|
|
||||||
|
|
||||||
参数说明:
|
|
||||||
- state:用于防范CSRF攻击,各第三方可以视自己网站的安全性而定(建议预先了解一下oauth2.0的技术以及state参数的意义)
|
|
||||||
- scopeStr:酷家乐授权选项scope,以逗号隔开,具体资源可以参考每个[https://open.kujiale.com/open/apps?app_id=2](酷家乐开放接口文档)内的授权scope内容。
|
|
||||||
|
|
||||||
### 2.4 以上完整代码如下
|
|
||||||
|
|
||||||
```java
|
|
||||||
import me.zhyd.oauth.config.AuthConfig;
|
|
||||||
import me.zhyd.oauth.request.AuthKujialeRequest;
|
|
||||||
import me.zhyd.oauth.model.AuthCallback;
|
|
||||||
import me.zhyd.oauth.request.AuthRequest;
|
|
||||||
import org.springframework.web.bind.annotation.PathVariable;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
|
|
||||||
@RestController
|
|
||||||
@RequestMapping("/oauth")
|
|
||||||
public class RestAuthController {
|
|
||||||
|
|
||||||
@RequestMapping("/render")
|
|
||||||
public void renderAuth(HttpServletResponse response) throws IOException {
|
|
||||||
AuthRequest authRequest = getAuthRequest();
|
|
||||||
response.sendRedirect(authRequest.authorize("state"));
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping("/callback")
|
|
||||||
public Object login(AuthCallback callback) {
|
|
||||||
AuthRequest authRequest = getAuthRequest();
|
|
||||||
//此处如果对安全性有要求,请校验state参数
|
|
||||||
return authRequest.login(callback);
|
|
||||||
}
|
|
||||||
|
|
||||||
private AuthRequest getAuthRequest() {
|
|
||||||
return new AuthKujialeRequest(AuthConfig.builder()
|
|
||||||
.clientId("Client ID")
|
|
||||||
.clientSecret("Client Secret")
|
|
||||||
.redirectUri("应用回调地址")
|
|
||||||
.build());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
授权链接访问成功后会看到以下页面内容:
|
|
||||||

|
|
||||||
|
|
||||||
点击同意授权即可完成酷家乐的oauth登录。
|
|
||||||
|
|
||||||
## 3. 授权结果
|
|
||||||
|
|
||||||
注:数据已脱敏
|
|
||||||
|
|
||||||
```json
|
|
||||||
{
|
|
||||||
"code": 2000,
|
|
||||||
"msg": null,
|
|
||||||
"data": {
|
|
||||||
"uuid": "xxx",
|
|
||||||
"username": "yadong.zhang",
|
|
||||||
"nickname": "yadong.zhang",
|
|
||||||
"avatar": "https://qhyxpicoss.kujiale.com/avatars/2017/03/03/origin8762512743744383438.jpg",
|
|
||||||
"blog": null,
|
|
||||||
"company": null,
|
|
||||||
"location": null,
|
|
||||||
"email": null,
|
|
||||||
"remark": null,
|
|
||||||
"gender": null,
|
|
||||||
"source": "KUJIALE",
|
|
||||||
"token": {
|
|
||||||
"accessToken": "630740bxxxxxxxx4",
|
|
||||||
"expireIn": 86400,
|
|
||||||
"refreshToken": "1f2e0faedxxxxx537ec8",
|
|
||||||
"uid": null,
|
|
||||||
"openId": null,
|
|
||||||
"accessCode": null,
|
|
||||||
"unionId": null,
|
|
||||||
"scope": null,
|
|
||||||
"tokenType": null,
|
|
||||||
"idToken": null,
|
|
||||||
"macAlgorithm": null,
|
|
||||||
"macKey": null,
|
|
||||||
"code": null
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||