mirror of
				https://gitee.com/dromara/sa-token.git
				synced 2025-10-25 18:19:02 +08:00 
			
		
		
		
	update doc
This commit is contained in:
		| @@ -152,7 +152,7 @@ | |||||||
| 		 | 		 | ||||||
| 		<!--  --> | 		<!--  --> | ||||||
| 		<script src="./static/docsify-plugin.js"></script> | 		<script src="./static/docsify-plugin.js"></script> | ||||||
| 		<script src="./static/is-star-plugin.js"></script> | 		<script src="./static/is-star-plugin.js?v=2"></script> | ||||||
| 		<script> | 		<script> | ||||||
| 			var saTokenTopVersion = '1.35.0.RC';	// Sa-Token最新版本  | 			var saTokenTopVersion = '1.35.0.RC';	// Sa-Token最新版本  | ||||||
| 			var name = '<img style="width: 60px; height: 60px; vertical-align: middle;" src="logo.png" alt="logo" /> '; | 			var name = '<img style="width: 60px; height: 60px; vertical-align: middle;" src="logo.png" alt="logo" /> '; | ||||||
|   | |||||||
| @@ -13,16 +13,16 @@ var isStarPlugin = function(hook, vm) { | |||||||
| 	 | 	 | ||||||
| 	// 钩子函数:每次路由切换时,解析内容之后执行  | 	// 钩子函数:每次路由切换时,解析内容之后执行  | ||||||
| 	hook.afterEach(function(html) { | 	hook.afterEach(function(html) { | ||||||
| 		changePage++; | 		// changePage++; | ||||||
| 		if(changePage % 15 === 0) { | 		// if(changePage % 15 === 0) { | ||||||
| 			isStarRepo(); | 		// 	isStarRepo(); | ||||||
| 		} | 		// } | ||||||
| 		return html; | 		return html; | ||||||
| 	}); | 	}); | ||||||
| 	 | 	 | ||||||
| 	// 每钩子函数:次路由切换时数据全部加载完成后调用,没有参数。 | 	// 钩子函数:每次路由切换时数据全部加载完成后调用,没有参数。 | ||||||
| 	hook.doneEach(function() { | 	hook.doneEach(function() { | ||||||
| 		 | 		isStarRepo(vm); | ||||||
| 	}); | 	}); | ||||||
| 	 | 	 | ||||||
| 	// 钩子函数:初始化并第一次加载完成数据后调用,没有参数。 | 	// 钩子函数:初始化并第一次加载完成数据后调用,没有参数。 | ||||||
| @@ -35,10 +35,10 @@ var isStarPlugin = function(hook, vm) { | |||||||
| // 应用参数  | // 应用参数  | ||||||
| const client_id = '0cc618beb08db99bff50e500e38c2144d95ada9abb51c00c44592726ecd583f4'; | const client_id = '0cc618beb08db99bff50e500e38c2144d95ada9abb51c00c44592726ecd583f4'; | ||||||
| const client_secret = '2574c2aac8ce2142e34752dc5957dddcb30bc68df5c61de64251a3a6b11a51e5'; | const client_secret = '2574c2aac8ce2142e34752dc5957dddcb30bc68df5c61de64251a3a6b11a51e5'; | ||||||
| // const redirect_uri = 'http://local.dev33.cn:8848/sa-token-doc/doc.html'; |  | ||||||
| const redirect_uri = 'https://sa-token.cc/doc.html'; | const redirect_uri = 'https://sa-token.cc/doc.html'; | ||||||
| // const docDomain = 'local.dev33.cn:8848'; |  | ||||||
| const docDomain = 'sa-token.cc'; | const docDomain = 'sa-token.cc'; | ||||||
|  | // const redirect_uri = 'http://127.0.0.1:8848/sa-token-doc/doc.html'; | ||||||
|  | // const docDomain = '127.0.0.1:8848'; | ||||||
| 		 | 		 | ||||||
| // 检查成功后,多少天不再检查  | // 检查成功后,多少天不再检查  | ||||||
| const allowDisparity = 1000 * 60 * 60 * 24 * 30; | const allowDisparity = 1000 * 60 * 60 * 24 * 30; | ||||||
| @@ -46,7 +46,7 @@ const allowDisparity = 1000 * 60 * 60 * 24 * 30; | |||||||
|  |  | ||||||
|  |  | ||||||
| // 判断当前是否已 star | // 判断当前是否已 star | ||||||
| function isStarRepo() { | function isStarRepo(vm) { | ||||||
| 	// 非PC端不检查 | 	// 非PC端不检查 | ||||||
| 	if(document.body.offsetWidth < 800) { | 	if(document.body.offsetWidth < 800) { | ||||||
| 		console.log('small screen ...'); | 		console.log('small screen ...'); | ||||||
| @@ -76,7 +76,16 @@ function isStarRepo() { | |||||||
| 		console.error(e); | 		console.error(e); | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
|  | 	// 白名单路由不判断 | ||||||
|  | 	const whiteList = ['/', '/more/link', '/more/demand-commit', '/more/join-group', '/more/sa-token-donate',  | ||||||
|  | 			'/sso/sso-pro', '/more/update-log', '/more/common-questions', '/fun/sa-token-test', '/fun/issue-template']; | ||||||
|  | 	if(whiteList.indexOf(vm.route.path) >= 0 && getParam('code') === null) { | ||||||
|  | 		console.log('white route ...'); | ||||||
|  | 		return; | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
| 	// 开始获取 code  | 	// 开始获取 code  | ||||||
|  | 	$('body').css({'overflow': 'hidden'}); | ||||||
| 	getCode(); | 	getCode(); | ||||||
| } | } | ||||||
| 		 | 		 | ||||||
| @@ -103,14 +112,24 @@ function confirmStar() { | |||||||
| 				'<div>1、打开 Sa-Token <a href="https://gitee.com/dromara/sa-token" target="_blank">开源仓库主页</a>,在右上角点个 star 。</div>' +  | 				'<div>1、打开 Sa-Token <a href="https://gitee.com/dromara/sa-token" target="_blank">开源仓库主页</a>,在右上角点个 star 。</div>' +  | ||||||
| 				'<div>2、点击下方 [ 同意授权检测 ] 按钮,同意 Sa-Token 获取 API 权限进行检测。<a href="javascript:authDetails();" style="text-decoration: none;">?</a></div>' +  | 				'<div>2、点击下方 [ 同意授权检测 ] 按钮,同意 Sa-Token 获取 API 权限进行检测。<a href="javascript:authDetails();" style="text-decoration: none;">?</a></div>' +  | ||||||
| 				"</div>"; | 				"</div>"; | ||||||
| 	tipStr += "<p><b>不点也没关系 ❤️ ❤️ ❤️,Sa-Token 将努力变得更加完善!😇</b></p>"; | 	tipStr += "<p><b>本章节文档将在 star 后正常开放展示</b></p>"; | ||||||
| 	tipStr = '<div>' + tipStr + '</div>' | 	tipStr = '<div>' + tipStr + '</div>' | ||||||
| 	layer.confirm(tipStr, {title: '提示', btn: ['同意授权检测', '暂时不要,我先看看文档'], area: '450px', offset: '20%'}, function(index) { | 	 | ||||||
| 		//  | 	layer.confirm(tipStr, { | ||||||
| 		layer.close(index); | 			title: '提示',  | ||||||
| 		// 用户点了确认,去 gitee 官方请求授权获取 | 			btn: ['同意授权检测'],  | ||||||
| 		goAuth(); | 			// btn: ['同意授权检测', '暂时不要,我先看看文档'],  | ||||||
| 	}); | 			area: '450px',  | ||||||
|  | 			offset: '25%', | ||||||
|  | 			closeBtn: false | ||||||
|  | 		},  | ||||||
|  | 		function(index) { | ||||||
|  | 			//  | ||||||
|  | 			layer.close(index); | ||||||
|  | 			// 用户点了确认,去 gitee 官方请求授权获取 | ||||||
|  | 			goAuth(); | ||||||
|  | 		} | ||||||
|  | 	); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -129,7 +148,7 @@ function goAuth() { | |||||||
| function getAccessToken(code) { | function getAccessToken(code) { | ||||||
| 	// 根据 code 获取 access_token | 	// 根据 code 获取 access_token | ||||||
| 	$.ajax({ | 	$.ajax({ | ||||||
| 		url: 'https://gitee.com/oauth/token', | 		url: 'https://sa-token.cc/server/oauth/token', | ||||||
| 		method: 'post', | 		method: 'post', | ||||||
| 		data: { | 		data: { | ||||||
| 			grant_type: 'authorization_code', | 			grant_type: 'authorization_code', | ||||||
| @@ -139,6 +158,14 @@ function getAccessToken(code) { | |||||||
| 			client_secret: client_secret, | 			client_secret: client_secret, | ||||||
| 		}, | 		}, | ||||||
| 		success: function(res) { | 		success: function(res) { | ||||||
|  | 			// 如果返回的不是 200 | ||||||
|  | 			if(res.code !== 200) { | ||||||
|  | 				return layer.alert(res.msg, {closeBtn: false}, function(){ | ||||||
|  | 					// 刷新url,去掉 code 参数  | ||||||
|  | 					location.href = 'doc.html'; | ||||||
|  | 				}); | ||||||
|  | 			} | ||||||
|  | 			 | ||||||
| 			// 拿到 access_token  | 			// 拿到 access_token  | ||||||
| 			const access_token = res.access_token; | 			const access_token = res.access_token; | ||||||
| 			 | 			 | ||||||
| @@ -166,7 +193,7 @@ function getAccessToken(code) { | |||||||
| 					// 如下返回,代表没有 star  | 					// 如下返回,代表没有 star  | ||||||
| 					if(e.statusText = 'Not Found'){ | 					if(e.statusText = 'Not Found'){ | ||||||
| 						console.log('not star ...'); | 						console.log('not star ...'); | ||||||
| 						layer.alert('未检测到 star 数据...', function() { | 						layer.alert('未检测到 star 数据...', {closeBtn: false}, function() { | ||||||
| 							// 刷新url,去掉 code 参数  | 							// 刷新url,去掉 code 参数  | ||||||
| 							location.href = location.href.replace("?code=" + code, ''); | 							location.href = location.href.replace("?code=" + code, ''); | ||||||
| 						}); | 						}); | ||||||
| @@ -177,18 +204,30 @@ function getAccessToken(code) { | |||||||
| 		}, | 		}, | ||||||
| 		error: function(e) { | 		error: function(e) { | ||||||
| 			console.log('请求错误 ', e); | 			console.log('请求错误 ', e); | ||||||
|  | 			// 如果请求地址有错,则暂停一天  | ||||||
|  | 			if(e.status === 0 || e.status === 502) { | ||||||
|  | 				return layer.alert(JSON.stringify(e), {closeBtn: false}, function(){ | ||||||
|  | 					// 一天内不再检查,否则 | ||||||
|  | 					const ygTime = allowDisparity - (1000 * 60 * 60 * 24); | ||||||
|  | 					localStorage.isStarRepo = new Date().getTime() - ygTime; | ||||||
|  | 					// 刷新url,去掉 code 参数  | ||||||
|  | 					location.href = location.href.replace("?code=" + code, ''); | ||||||
|  | 				}); | ||||||
|  | 			} | ||||||
|  | 			 | ||||||
| 			// 无效授权,可能是 code 无效  | 			// 无效授权,可能是 code 无效  | ||||||
| 			if(e.responseJSON.error == 'invalid_grant') { | 			const errorMsg = (e.responseJSON && e.responseJSON.error) || JSON.stringify(e); | ||||||
|  | 			if(errorMsg == 'invalid_grant') { | ||||||
| 				console.log('无效code', code); | 				console.log('无效code', code); | ||||||
| 			} | 			} | ||||||
| 			layer.alert('check error...' + e.responseJSON.error, function(index) { | 			layer.alert('check error... ' + errorMsg, function(index) { | ||||||
| 				layer.close(index); | 				layer.close(index); | ||||||
| 				// 刷新url,去掉 code 参数  | 				// 刷新url,去掉 code 参数  | ||||||
| 				let url = location.href.replace("?code=" + code, ''); | 				let url = location.href.replace("?code=" + code, ''); | ||||||
| 				url = url.replace("&code=" + code, ''); | 				url = url.replace("&code=" + code, ''); | ||||||
| 				location.href = url; | 				location.href = url; | ||||||
| 			}); | 			}); | ||||||
| 			// 一天内不再检查,否则容易引起无限重定向  | 			// 一天内不再检查,否则 | ||||||
| 			// const ygTime = allowDisparity - (1000 * 60 * 60 * 24); | 			// const ygTime = allowDisparity - (1000 * 60 * 60 * 24); | ||||||
| 			// localStorage.isStarRepo = new Date().getTime() - ygTime; | 			// localStorage.isStarRepo = new Date().getTime() - ygTime; | ||||||
| 			// // 刷新url,去掉 code 参数  | 			// // 刷新url,去掉 code 参数  | ||||||
| @@ -197,14 +236,12 @@ function getAccessToken(code) { | |||||||
| 	}) | 	}) | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| // 疑问 | // 疑问 | ||||||
| function authDetails() { | function authDetails() { | ||||||
| 	const str = "用于检测的凭证信息将仅保存你的浏览器本地,不发往任何第三方服务器,Sa-Token 文档已完整开源,源码可查"; | 	const str = "用于检测的凭证信息将仅保存你的浏览器本地,Sa-Token 文档已完整开源,源码可查"; | ||||||
| 	alert(str); | 	alert(str); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| // 获取 url 携带的参数  | // 获取 url 携带的参数  | ||||||
| function getParam(name, defaultValue){ | function getParam(name, defaultValue){ | ||||||
| 	var query = window.location.search.substring(1); | 	var query = window.location.search.substring(1); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 click33
					click33