{"id":321,"date":"2023-06-17T03:01:16","date_gmt":"2023-06-16T19:01:16","guid":{"rendered":"https:\/\/www.gzlcy.cn\/?p=321"},"modified":"2023-06-17T03:01:16","modified_gmt":"2023-06-16T19:01:16","slug":"%e4%bc%81%e4%b8%9a%e7%ba%a7%e5%8d%95%e7%82%b9%e7%99%bb%e5%bd%95%e5%ae%9e%e7%8e%b0%e6%96%b9%e6%a1%88oauth2-%e5%89%8d%e7%ab%af%e7%99%bb%e5%bd%95%e5%8f%8a%e8%af%b7%e6%b1%82%e5%ae%9e","status":"publish","type":"post","link":"https:\/\/www.gzlcy.cn\/?p=321","title":{"rendered":"\u4f01\u4e1a\u7ea7\u5355\u70b9\u767b\u5f55\u5b9e\u73b0\u65b9\u6848OAuth2\u2014\u2014\u524d\u7aef\u767b\u5f55\u53ca\u8bf7\u6c42\u5b9e\u73b0\u53c2\u8003"},"content":{"rendered":"<p>\u5f53\u540e\u7aef\u4f7f\u7528Spring Security Oauth2\u7684\u65b9\u5f0f\u63a7\u5236\u6743\u9650\u65f6\uff0c\u5bc6\u7801\u6a21\u5f0f\u4e0b\u524d\u7aef\u6709\u4e24\u4e2a\u5730\u65b9\u7684\u5b9e\u73b0\u9700\u8981\u5173\u6ce8\uff0c\u4e00\u662f\u767b\u5f55\uff1b\u4e8c\u662f\u767b\u5f55\u540e\u7684\u5176\u5b83\u63a5\u53e3\u8c03\u7528\u3002<\/p>\n<p>\u672c\u793a\u4f8b\u4e3aVue\u5b9e\u73b0\uff0c\u4f7f\u7528axios\u6765\u8fdb\u884c\u63a5\u53e3\u8c03\u7528\u3002<\/p>\n<p>1. \u767b\u5f55<\/p>\n<p>\u767b\u5f55\u9700\u8981\u9700\u8981\u8c03\u7528\/oauth\/token\u63a5\u53e3\uff0c\u5e76\u4f20\u5165\u76f8\u5173\u767b\u5f55\u4fe1\u606f\uff0c\u4ee3\u7801\u5b9e\u73b0\u5982\u4e0b\uff1a<\/p>\n<p><pre><code>\/\/ \u7ec4\u88c5\u767b\u5f55\u53c2\u6570\nlet params = {\n    username: this.userLoginForm.username,\n    password: this.passwordEncode(this.userLoginForm.password),\n    id: \"testResource\",\n    client_id: \"test\",\n    client_secret: \"secret\",\n    scope: \"read\",\n    grant_type: \"password\",\n    type: \"user\",\n};\n\/\/ \u53d1\u8d77\u8bf7\u6c42\nthis.$postUrlParams(\"\/oauth\/token\", params)\n \u00a0  .then((res) =&gt; {\n \u00a0 \u00a0 \u00a0 \u00a0this.loading = false;\n \u00a0 \u00a0 \u00a0 \u00a0this.$cacheToken(res.access_token);\n \u00a0 \u00a0 \u00a0 \u00a0\/\/ \u767b\u5f55\u6210\u529f\u540e\u83b7\u53d6\u7528\u6237\u4fe1\u606f\n \u00a0 \u00a0 \u00a0 \u00a0...\n \u00a0  })\n \u00a0  .catch(() =&gt; {\n \u00a0 \u00a0 \u00a0 \u00a0this.loading = false;\n \u00a0  });<\/code><\/pre>\n<\/p>\n<p>\u6ce8\u610f<\/p>\n<p>1. \u767b\u5f55\u6210\u529f\u540e\uff0c\u6211\u4eec\u9700\u8981\u5c06\u8fd4\u56de\u7684token\u5b58\u50a8\u8d77\u6765\uff0c\u4ee5\u4fbf\u5728\u540e\u7eed\u8bf7\u6c42\u4e2d\u4f7f\u7528\u8fd9\u4e2aToken\u3002\uff08\u5982\u4f55\u4f7f\u7528\u540e\u6587\u4f1a\u8bf4\u660e\uff0c\u53ef\u4ee5\u5c06\u8fd9\u4e2atoken\u5b58\u50a8\u5230localStorage\u4e2d\uff09<\/p>\n<p>2. \u76f8\u5173\u53c2\u6570\u4e00\u5b9a\u8981\u4e0e\u540e\u7aef\u8d44\u6e90\u670d\u52a1\u5668\u4e2d\u914d\u7f6e\u7684\u4fe1\u606f\u5339\u914d\uff0c\u5426\u5219\u4f1a\u767b\u5f55\u5931\u8d25\uff1b<\/p>\n<p>3. \u5ba2\u6237\u7aef\u6a21\u5f0f\u4e0e\u4e0a\u8ff0\u8fc7\u7a0b\u7c7b\u4f3c\uff0c\u4f46\u4f20\u7684\u53c2\u6570\u4e0d\u4e00\u6837\uff0c\u4e0d\u9700\u8981\u7528\u6237\u540d\u53ca\u5bc6\u7801\uff1b<\/p>\n<p>\u5176\u4e2dpostUrlPrarams\u65b9\u6cd5\u5b9a\u4e49\u5982\u4e0b\uff1a<\/p>\n<p><pre><code>const myAxios = axios.create({\n \u00a0 \u00a0 \u00a0 \u00a0baseURL: \"\/api\/front\",\n \u00a0 \u00a0 \u00a0 \u00a0timeout: 20000,\n \u00a0 \u00a0 \u00a0 \u00a0headers: {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0post: {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0\"Content-Type\": \"application\/x-www-form-urlencoded;charset=UTF-8\",\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  },\n \u00a0 \u00a0 \u00a0  },\n \u00a0  });\nfunction postUrlParams(url, param) {\n \u00a0 \u00a0 \u00a0 \u00a0return new Promise((resolve, reject) =&gt; {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0myAxios\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  .post(url, param)\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  .then(\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  (response) =&gt; {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0resolve(response);\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  },\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  (err) =&gt; {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0if (err.status === 404) {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0Message.error(\"\u7cfb\u7edf\u5f02\u5e38(404)\");\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  } else {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0reject(err);\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  }\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  }\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  )\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  .catch((error) =&gt; {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0console.log(error);\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0reject(error);\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  });\n \u00a0 \u00a0 \u00a0  });\n \u00a0  }<\/code><\/pre>\n<\/p>\n<p>\u5b9e\u73b0\u540e\u767b\u5f55\u63a5\u53e3\u8bf7\u6c42\u5185\u5bb9\u5982\u4e0b\u6240\u793a\uff1a<\/p>\n<p><img src='https:\/\/p3-sign.toutiaoimg.com\/pgc-image\/af631698d48d426ca966e2185930e3cc~noop.image?_iz=58558&amp;from=article.pc_detail&amp;x-expires=1687546874&amp;x-signature=rNGe1WssIYO3LkntuFEdzGR3PFI%3D' alt='\u5355\u70b9\u767b\u5f55\u539f\u7406_\u9ed8\u8ba4\u5e02\u503c\u5355\u504f\u79bb\u70b9\u5dee\u662f\u4ec0\u4e48\u610f\u601d_\u5355\u76f8\u53d8\u4e09\u76f8\u539f\u7406\u6a21\u7535' \/><\/p>\n<p>\u767b\u5f55\u8bf7\u6c42\u5185\u5bb9<\/p>\n<p>\u6ce8\u610fcontent-type\u9700\u8981\u662f\u6307\u5b9a\u7c7b\u578b\u7684\uff1b\u8bf7\u6c42\u7684\u6570\u636e\u9700\u8981\u662f\u201c\u8868\u5355\u6570\u636e\u201d\u8fd9\u79cd\u683c\u5f0f\uff0c\u5176\u5b83\u683c\u5f0f\u90fd\u4f1a\u62a5\u9519\u3002<\/p>\n<p>2. \u767b\u5f55\u540e\u63a5\u53e3\u8c03\u7528<\/p>\n<p>\u767b\u5f55\u540e\u8c03\u7528\u540e\u7aef\u63a5\u53e3\u65f6\uff0c\u9700\u8981\u5728\u8bf7\u6c42\u5934\u4e2d\u6dfb\u52a0Authentication\u9879\uff0c\u8bbe\u7f6e\u5176\u503c\u4e3abearer + \u7a7a\u683c + \u767b\u5f55\u8fd4\u56de\u7684token\uff1b\u4f7f\u7528axios\u65f6\uff0c\u53ef\u4ee5\u901a\u8fc7interceptor\u6765\u7edf\u4e00\u5904\u7406\uff1a<\/p>\n<p><pre><code>const myAxios = axios.create({\n \u00a0 \u00a0 \u00a0 \u00a0baseURL: \"\/api\/front\", \u00a0\n \u00a0 \u00a0 \u00a0 \u00a0timeout: 20000,\n \u00a0 \u00a0 \u00a0 \u00a0headers: {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0post: {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0\"Content-Type\": \"application\/x-www-form-urlencoded;charset=UTF-8\",\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  },\n \u00a0 \u00a0 \u00a0  },\n \u00a0  });\n \u00a0 \u00a0\/\/POST\u4f20\u53c2\u5e8f\u5217\u5316(\u6dfb\u52a0\u8bf7\u6c42\u62e6\u622a\u5668)\n \u00a0 \u00a0myAxios.interceptors.request.use(\n \u00a0 \u00a0 \u00a0  (config) =&gt; {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0if (config.method === \"post\") {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0let contentType = config.headers[\"Content-Type\"];\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0if (contentType !== \"application\/json;charset=UTF-8\" &amp;&amp; contentType !== \"multipart\/form-data\") {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0config.data = qs.stringify(config.data);\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  }\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  }\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0let token = window.localStorage.getItem(\"ttAccessToken\");\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0\/\/ \u767b\u5f55\u8bf7\u6c42\u4e2d\u4e0d\u80fd\u5305\u542b\u6709token\uff0c\u5426\u5219\u4f1a\u6709\u62a5\u5f02\u5e38\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0\/\/ \u5176\u5b83\u8bf7\u6c42\u5c06token\u5e26\u4e0a\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0if (token &amp;&amp; config.url.indexOf(\"\/oauth\/token\") === -1) {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0config.withCredentials = true;\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0config.headers.Authorization = \"Bearer \" + token;\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  }\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0return config;\n \u00a0 \u00a0 \u00a0  },\n \u00a0 \u00a0 \u00a0  (error) =&gt; {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0console.log(\"\u9519\u8bef\u7684\u4f20\u53c2\");\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0return Promise.reject(error);\n \u00a0 \u00a0 \u00a0  }\n \u00a0  );<\/code><\/pre>\n<\/p>\n<p>\u540c\u65f6\u5efa\u8bae\u5904\u7406\u5f53\u540e\u7aef\u8fd4\u56de401\u3001402\u7b49\u60c5\u51b5\u65f6\uff0c\u91cd\u65b0\u8df3\u8f6c\u5230\u767b\u5f55\u9875\u9762\uff0c\u5982\uff1a<\/p>\n<p><pre><code> \u00a0 \u00a0\/\/\u8fd4\u56de\u72b6\u6001\u5224\u65ad(\u6dfb\u52a0\u54cd\u5e94\u62e6\u622a\u5668)\n \u00a0 \u00a0myAxios.interceptors.response.use(\n \u00a0 \u00a0 \u00a0  (res) =&gt; {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0if (res.data.code == \"200\") {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0return Promise.resolve(res.data.data);\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  } else if (res.data.access_token) {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0return Promise.resolve(res.data);\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  }\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0console.log(res.data);\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0Message.error(res.data.msg || \"\u7cfb\u7edf\u5f02\u5e38\");\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0return Promise.reject(res.data);\n \u00a0 \u00a0 \u00a0  },\n \u00a0 \u00a0 \u00a0  (error) =&gt; {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0console.log(error);\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0let resp = error.response;\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0let status = resp.status;\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0if (status === 401 || status === 402) {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0window.localStorage.removeItem(\"ttAccessToken\");\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0store.commit(\"needLogin\");\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  } else if (status === 500 &amp;&amp; !resp.data.error_description) {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0\/\/ \u5982\u679c\u540e\u7aef\u8fd4\u56de\u7684\u6570\u636e\u4e2d\u5305\u542bcode\uff0c\u90a3\u4e48\u4e0d\u9700\u8981\u505a\u901a\u7528\u5904\u7406\uff0c\u9700\u8981\u5404\u4e2a\u9875\u9762\u505a\u7279\u6b8a\u5904\u7406\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0var msg = resp.data.msg || \"\u7cfb\u7edf\u9519\u8bef\";\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0Message.error(msg);\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  } else if (status === 403) {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0Message.error(\"\u6743\u9650\u4e0d\u8db3\");\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  } else if (status === 404) {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0Message.error(\"\u7cfb\u7edf\u5f02\u5e38(404)\");\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0return Promise.reject(\"\u7cfb\u7edf\u5f02\u5e38(404)\");\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  } else {\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0Message.error(resp.data.error_description);\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0  }\n \u00a0 \u00a0 \u00a0 \u00a0 \u00a0 \u00a0return Promise.reject(resp.data);\n \u00a0 \u00a0 \u00a0  }\n \u00a0  );<\/code><\/pre>\n<\/p>\n<p>\u5f53\u7136\u5177\u4f53\u5b9e\u73b0\u8981\u6839\u636e\u5b9e\u9645\u4e1a\u52a1\u573a\u666f\u53ca\u524d\u540e\u7aef\u4ea4\u4e92\u65f6\u7684\u63a5\u53e3\u65b9\u5f0f\uff0c\u4ee5\u4e0a\u4ee3\u7801\u4ec5\u4f9b\u53c2\u8003\u3002<\/p>\n<p>\u8bf7\u6c42\u7684\u793a\u4f8b\u5982\u4e0b\uff1a<\/p>\n<p><img src='https:\/\/p3-sign.toutiaoimg.com\/pgc-image\/8698050441594cd3a5ce7553e8a1e498~noop.image?_iz=58558&amp;from=article.pc_detail&amp;x-expires=1687546874&amp;x-signature=%2BaxdiHnMnhYsoHN96LJqj%2BsvJgU%3D' alt='\u5355\u76f8\u53d8\u4e09\u76f8\u539f\u7406\u6a21\u7535_\u9ed8\u8ba4\u5e02\u503c\u5355\u504f\u79bb\u70b9\u5dee\u662f\u4ec0\u4e48\u610f\u601d_\u5355\u70b9\u767b\u5f55\u539f\u7406' \/><\/p>\n<p>\u5e26token\u7684\u8bf7\u6c42\u793a\u4f8b<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u5f53\u540e\u7aef\u4f7f\u7528Spring Security Oauth2\u7684\u65b9\u5f0f\u63a7\u5236\u6743\u9650\u65f6\uff0c\u5bc6\u7801\u6a21\u5f0f\u4e0b\u524d\u7aef\u6709\u4e24\u4e2a\u5730\u65b9\u7684\u5b9e\u73b0\u9700\u8981\u5173\u6ce8\uff0c\u4e00\u662f\u767b\u5f55\uff1b\u4e8c\u662f\u767b\u5f55\u540e\u7684\u5176\u5b83\u63a5\u53e3\u8c03<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[1],"tags":[631,632],"_links":{"self":[{"href":"https:\/\/www.gzlcy.cn\/index.php?rest_route=\/wp\/v2\/posts\/321"}],"collection":[{"href":"https:\/\/www.gzlcy.cn\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.gzlcy.cn\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.gzlcy.cn\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.gzlcy.cn\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=321"}],"version-history":[{"count":0,"href":"https:\/\/www.gzlcy.cn\/index.php?rest_route=\/wp\/v2\/posts\/321\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.gzlcy.cn\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=321"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.gzlcy.cn\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=321"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.gzlcy.cn\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=321"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}