{"id":49355,"date":"2023-12-03T19:39:37","date_gmt":"2023-06-29T16:21:33","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e7%bb%9d%e5%af%b9%e8%83%bd%e5%81%9a%e5%88%b0%ef%bc%81%e3%80%91%e8%b0%b7%e6%ad%8c%e7%99%bb%e5%bd%95%e6%8c%89%e9%92%ae%e7%9a%84%e5%ae%9e%e7%8e%b0%e3%80%902-6%e3%80%91\/"},"modified":"2024-05-04T12:00:27","modified_gmt":"2024-05-04T04:00:27","slug":"%e3%80%90%e7%bb%9d%e5%af%b9%e8%83%bd%e5%81%9a%e5%88%b0%ef%bc%81%e3%80%91%e8%b0%b7%e6%ad%8c%e7%99%bb%e5%bd%95%e6%8c%89%e9%92%ae%e7%9a%84%e5%ae%9e%e7%8e%b0%e3%80%902-6%e3%80%91","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e7%bb%9d%e5%af%b9%e8%83%bd%e5%81%9a%e5%88%b0%ef%bc%81%e3%80%91%e8%b0%b7%e6%ad%8c%e7%99%bb%e5%bd%95%e6%8c%89%e9%92%ae%e7%9a%84%e5%ae%9e%e7%8e%b0%e3%80%902-6%e3%80%91\/","title":{"rendered":"\u3010\u7edd\u5bf9\u80fd\u505a\u5230\uff01\u3011\u8c37\u6b4c\u767b\u5f55\u6309\u94ae\u7684\u5b9e\u73b0\u30102\/6\u3011"},"content":{"rendered":"<h1>\u7edd\u5bf9\u80fd\u529e\u5230\uff01Google\u767b\u5f55\u6309\u94ae\u7684\u5b9e\u73b0\u30102\/6\u3011<\/h1>\n<p>\u672c\u6587\u4ecb\u7ecd\u4e86\u5728React \u00d7 DjangoRESTFramework\u4e2d\u5b9e\u73b0Google\u767b\u5f55\u6309\u94ae\u7684\u6559\u7a0b\uff0c\u8fd9\u662f\u5176\u4e2d\u7684\u7b2c\u4e8c\u90e8\u5206\u3002\u5982\u679c\u8981\u4ece\u7b2c\u4e00\u90e8\u5206\u5f00\u59cb\u9605\u8bfb\uff0c\u8bf7\u70b9\u51fb\u8fd9\u91cc\u3002\u5c0e\u5165\u504f\u7684\u90e8\u52060\u8bf7\u70b9\u51fb\u8fd9\u91cc\u3002<\/p>\n<h1>\u7b2c\u4e8c\u90e8\u5206\uff1a\u521b\u5efa\u540e\u7aef<\/h1>\n<h2>0. \u5bf9\u73af\u5883\u53d8\u5316\u7684\u7406\u89e3<\/h2>\n<p>\u8fd9\u6bb5\u7684\u6d41\u7a0b\u5982\u4e0b\u6240\u793a\u3002<\/p>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>\u521b\u5efa\u865a\u62df\u73af\u5883<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>\u5b89\u88c5\u5e93<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>\u521b\u5efaDjango\u9879\u76ee<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>\u66f4\u6539\u9879\u76ee\u8bbe\u7f6e<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>\u521b\u5efa\u53d8\u91cf\u8bbe\u7f6e\u6587\u4ef6<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>\u521b\u5efaURL<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>\u9996\u6b21\u8fc1\u79fb\uff0c\u521b\u5efa\u8d85\u7ea7\u7528\u6237<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>\u521b\u5efadjango-social-oauth\u5e94\u7528\u7a0b\u5e8f<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>\u786e\u8ba4DRF\uff08Django Rest Framework\uff09\u7684\u4f7f\u7528\u60c5\u51b5<\/ol>\n<h2>1. \u521b\u5efa\u865a\u62df\u73af\u5883<\/h2>\n<pre class=\"post-pre\"><code><span class=\"nv\">$ <\/span>python <span class=\"nt\">-m<\/span> venv tutorial\r\n<span class=\"nv\">$ <\/span><span class=\"nb\">source <\/span>tutorial\/bin\/activate\r\n<span class=\"nv\">$ <\/span>pip <span class=\"nb\">install<\/span> <span class=\"nt\">--upgrade<\/span> pip\r\n<\/code><\/pre>\n<h2>2. \u5b89\u88c5\u5fc5\u8981\u7684\u5e93\u6587\u4ef6<\/h2>\n<ul class=\"post-ul\">requirements.txt\u306b\u8a18\u5165<\/ul>\n<pre class=\"post-pre\"><code><span class=\"nv\">$ <\/span>vi requirements.txt\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code>django\r\ndjangorestframework\r\ndrf_social_oauth2\r\npython-decouple\r\ndjango-cors-headers\r\n<\/code><\/pre>\n<p>drf_social_oauth2 : \u4f7f\u7528DRF\u8fdb\u884c\u793e\u4ea4\u767b\u5f55\u529f\u80fd\u65f6\u6240\u9700<br \/>\npython_decouple : \u4ece.env\u6587\u4ef6\u4e2d\u63d0\u53d6\u6570\u636e\u65f6\u6240\u9700<br \/>\ndjango-cors-headers : \u5728React\u548cDjango\u4e4b\u95f4\u8fdb\u884cCORS\u8de8\u57df\u901a\u4fe1\u65f6\u6240\u9700<\/p>\n<ul class=\"post-ul\">install\u5b9f\u884c<\/ul>\n<pre class=\"post-pre\"><code><span class=\"nv\">$ <\/span>pip <span class=\"nb\">install<\/span> <span class=\"nt\">-r<\/span> requirements.txt\r\n\r\n<span class=\"nv\">$ <\/span>pip list\r\nPackage                Version\r\n<span class=\"nt\">----------------------<\/span> <span class=\"nt\">--------<\/span>\r\nDjango                 3.2.11\r\ndjango-cors-headers    3.10.1\r\ndjango-oauth-toolkit   1.7.0\r\ndjangorestframework    3.13.1\r\ndrf-social-oauth2      1.2.1\r\npython-decouple        3.5\r\n<\/code><\/pre>\n<h2>3. \u521b\u5efa\u9879\u76ee<\/h2>\n<pre class=\"post-pre\"><code><span class=\"nv\">$ <\/span>django-admin startproject backend\r\n<span class=\"nv\">$ <\/span><span class=\"nb\">cd <\/span>backend\r\n<\/code><\/pre>\n<h2>4. \u9879\u76ee\u8bbe\u5b9a<\/h2>\n<ul class=\"post-ul\">INSTALLED_APPS \u306b \u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u8ffd\u52a0<\/ul>\n<pre class=\"post-pre\"><code><span class=\"c1\"># Application definition\r\n<\/span>\r\n<span class=\"n\">INSTALLED_APPS<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">django.contrib.admin<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">django.contrib.auth<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">django.contrib.contenttypes<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">django.contrib.sessions<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">django.contrib.messages<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">django.contrib.staticfiles<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n\r\n    <span class=\"c1\"># \u4ee5\u4e0b\u8ffd\u52a0\r\n<\/span>    <span class=\"sh\">'<\/span><span class=\"s\">rest_framework<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">drf_social_oauth2<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">social_django<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">oauth2_provider<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">corsheaders<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n<span class=\"p\">]<\/span>\r\n<\/code><\/pre>\n<ul class=\"post-ul\">MIDDLEWARE \u306b\u3082\u8ffd\u52a0<\/ul>\n<pre class=\"post-pre\"><code><span class=\"n\">MIDDLEWARE<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">django.middleware.security.SecurityMiddleware<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">django.contrib.sessions.middleware.SessionMiddleware<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">django.middleware.common.CommonMiddleware<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">django.middleware.csrf.CsrfViewMiddleware<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">django.contrib.auth.middleware.AuthenticationMiddleware<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">django.contrib.messages.middleware.MessageMiddleware<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">django.middleware.clickjacking.XFrameOptionsMiddleware<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n\r\n    <span class=\"c1\"># \u4ee5\u4e0b\u8ffd\u52a0\r\n<\/span>    <span class=\"sh\">'<\/span><span class=\"s\">corsheaders.middleware.CorsMiddleware<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n<span class=\"p\">]<\/span>\r\n<\/code><\/pre>\n<ul class=\"post-ul\">CORS \u8a2d\u5b9a\u8ffd\u8a18<\/ul>\n<pre class=\"post-pre\"><code><span class=\"c1\"># React \u3068\u306e CORS \u306e\u8a2d\u5b9a\r\n<\/span>\r\n<span class=\"n\">CORS_ALLOWED_ORIGINS<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span>\r\n    <span class=\"sh\">\"<\/span><span class=\"s\">http:\/\/localhost:3000<\/span><span class=\"sh\">\"<\/span> <span class=\"c1\"># React\u306fport:3000\u3092\u5229\u7528\r\n<\/span><span class=\"p\">]<\/span>\r\n<\/code><\/pre>\n<ul class=\"post-ul\">TEMPLATES \u3092\u4ee5\u4e0b\u306e\u901a\u308a\u8ffd\u52a0<\/ul>\n<pre class=\"post-pre\"><code><span class=\"n\">TEMPLATES<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span>\r\n    <span class=\"p\">{<\/span>\r\n        <span class=\"sh\">'<\/span><span class=\"s\">BACKEND<\/span><span class=\"sh\">'<\/span><span class=\"p\">:<\/span> <span class=\"sh\">'<\/span><span class=\"s\">django.template.backends.django.DjangoTemplates<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"sh\">'<\/span><span class=\"s\">DIRS<\/span><span class=\"sh\">'<\/span><span class=\"p\">:<\/span> <span class=\"p\">[],<\/span>\r\n        <span class=\"sh\">'<\/span><span class=\"s\">APP_DIRS<\/span><span class=\"sh\">'<\/span><span class=\"p\">:<\/span> <span class=\"bp\">True<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"sh\">'<\/span><span class=\"s\">OPTIONS<\/span><span class=\"sh\">'<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n            <span class=\"sh\">'<\/span><span class=\"s\">context_processors<\/span><span class=\"sh\">'<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span>\r\n                <span class=\"sh\">'<\/span><span class=\"s\">django.template.context_processors.debug<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n                <span class=\"sh\">'<\/span><span class=\"s\">django.template.context_processors.request<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n                <span class=\"sh\">'<\/span><span class=\"s\">django.contrib.auth.context_processors.auth<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n                <span class=\"sh\">'<\/span><span class=\"s\">django.contrib.messages.context_processors.messages<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n\r\n                <span class=\"c1\"># \u4ee5\u4e0b\u8ffd\u52a0\r\n<\/span>                <span class=\"sh\">'<\/span><span class=\"s\">social_django.context_processors.backends<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n                <span class=\"sh\">'<\/span><span class=\"s\">social_django.context_processors.login_redirect<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n            <span class=\"p\">],<\/span>\r\n        <span class=\"p\">},<\/span>\r\n    <span class=\"p\">},<\/span>\r\n<span class=\"p\">]<\/span>\r\n<\/code><\/pre>\n<ul class=\"post-ul\">REST framework \u8a2d\u5b9a\u3092\u8ffd\u52a0<\/ul>\n<pre class=\"post-pre\"><code><span class=\"c1\"># REST framework \u8a2d\u5b9a\r\n<\/span>\r\n<span class=\"n\">REST_FRAMEWORK<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">DEFAULT_AUTHENTICATION_CLASSES<\/span><span class=\"sh\">'<\/span><span class=\"p\">:<\/span> <span class=\"p\">(<\/span>\r\n        <span class=\"sh\">'<\/span><span class=\"s\">oauth2_provider.contrib.rest_framework.OAuth2Authentication<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"sh\">'<\/span><span class=\"s\">drf_social_oauth2.authentication.SocialAuthentication<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"p\">),<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"n\">AUTHENTICATION_BACKENDS<\/span> <span class=\"o\">=<\/span> <span class=\"p\">(<\/span>\r\n    <span class=\"c1\"># Google OAuth2 \u306e\u8a8d\u8a3c\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\r\n<\/span>    <span class=\"sh\">'<\/span><span class=\"s\">social_core.backends.google.GoogleOAuth2<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n\r\n    <span class=\"c1\"># Django REST framework \u306e\u8a8d\u8a3c\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\r\n<\/span>    <span class=\"sh\">'<\/span><span class=\"s\">drf_social_oauth2.backends.DjangoOAuth2<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n\r\n    <span class=\"c1\"># Django \u306e\u8a8d\u8a3c\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\r\n<\/span>    <span class=\"sh\">'<\/span><span class=\"s\">django.contrib.auth.backends.ModelBackend<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n<span class=\"p\">)<\/span>\r\n<\/code><\/pre>\n<ul class=\"post-ul\">\u3055\u3089\u306b\u3001Google OAuth \u95a2\u9023\u8a2d\u5b9a\u8ffd\u52a0<\/ul>\n<pre class=\"post-pre\"><code><span class=\"c1\"># decouple \u304b\u3089 config \u3092\u30a4\u30f3\u30dd\u30fc\u30c8\r\n<\/span><span class=\"kn\">from<\/span> <span class=\"n\">decouple<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">config<\/span>\r\n\r\n<span class=\"c1\"># Google \u304b\u3089\u53d6\u5f97\u3057\u305f\u9375\u60c5\u5831\r\n<\/span>\r\n<span class=\"n\">SOCIAL_AUTH_GOOGLE_OAUTH2_KEY<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">config<\/span><span class=\"p\">(<\/span><span class=\"sh\">\"<\/span><span class=\"s\">SOCIAL_AUTH_GOOGLE_OAUTH2_KEY<\/span><span class=\"sh\">\"<\/span><span class=\"p\">)<\/span>\r\n<span class=\"n\">SOCIAL_AUTH_GOOGLE_OAUTH2_SECRET<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">config<\/span><span class=\"p\">(<\/span><span class=\"sh\">\"<\/span><span class=\"s\">SOCIAL_AUTH_GOOGLE_OAUTH2_SECRET<\/span><span class=\"sh\">\"<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"c1\"># \u30a2\u30af\u30bb\u30b9\u30b9\u30b3\u30fc\u30d7\u306e\u8a2d\u5b9a\r\n<\/span>\r\n<span class=\"n\">SOCIAL_AUTH_GOOGLE_OAUTH2_SCOPE<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">https:\/\/www.googleapis.com\/auth\/userinfo.email<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"sh\">'<\/span><span class=\"s\">https:\/\/www.googleapis.com\/auth\/userinfo.profile<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span>\r\n<span class=\"p\">]<\/span>\r\n<\/code><\/pre>\n<ul class=\"post-ul\">(\u30aa\u30d7\u30b7\u30e7\u30f3)\u8a00\u8a9e\u8a2d\u5b9a<\/ul>\n<p>\u7531\u4e8e\u6613\u4e8e\u7406\u89e3\uff0c\u6240\u4ee5\u4e8b\u5148\u5c06\u5176\u7ffb\u8bd1\u6210\u65e5\u8bed\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c1\"># Internationalization\r\n# https:\/\/docs.djangoproject.com\/en\/3.2\/topics\/i18n\/\r\n<\/span>\r\n<span class=\"n\">LANGUAGE_CODE<\/span> <span class=\"o\">=<\/span> <span class=\"sh\">'<\/span><span class=\"s\">ja<\/span><span class=\"sh\">'<\/span>\r\n\r\n<span class=\"n\">TIME_ZONE<\/span> <span class=\"o\">=<\/span> <span class=\"sh\">'<\/span><span class=\"s\">Asia\/Tokyo<\/span><span class=\"sh\">'<\/span>\r\n<\/code><\/pre>\n<h2>5. \u521b\u5efa\u53d8\u91cf\u8bbe\u7f6e\u6587\u4ef6<\/h2>\n<p>\u6211\u4eec\u5c06Google Cloud\u83b7\u5f97\u7684\u8ba4\u8bc1\u4fe1\u606f\u7684ID\u548c\u5bc6\u94a5\u4fdd\u5b58\u4e3a\u53d8\u91cf\u3002\u8bf7\u521b\u5efa.env\u6587\u4ef6\u3002<\/p>\n<p>\u203b\u5c06\u5176\u521b\u5efa\u5728\u9879\u76ee\u7684\u6839\u76ee\u5f55\u4e0b\uff08\u4e0emanage.py\u6587\u4ef6\u5728\u540c\u4e00\u5c42\uff09\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"nv\">$ <\/span>vi .env\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code>SOCIAL_AUTH_GOOGLE_OAUTH2_KEY=\"499058585498-xxxxxxxxxxxx.apps.googleusercontent.com\"\r\nSOCIAL_AUTH_GOOGLE_OAUTH2_SECRET=\"GOCSxxxxxxxxxxxxnn3rV\"\r\n<\/code><\/pre>\n<h2>6. \u7f51\u5740\u7684\u914d\u7f6e<\/h2>\n<pre class=\"post-pre\"><code><span class=\"kn\">from<\/span> <span class=\"n\">django.contrib<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">admin<\/span>\r\n<span class=\"kn\">from<\/span> <span class=\"n\">django.urls<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">path<\/span><span class=\"p\">,<\/span> <span class=\"n\">include<\/span> <span class=\"c1\"># include\u8ffd\u52a0\r\n<\/span>\r\n<span class=\"n\">urlpatterns<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span>\r\n    <span class=\"nf\">path<\/span><span class=\"p\">(<\/span><span class=\"sh\">'<\/span><span class=\"s\">admin\/<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span> <span class=\"n\">admin<\/span><span class=\"p\">.<\/span><span class=\"n\">site<\/span><span class=\"p\">.<\/span><span class=\"n\">urls<\/span><span class=\"p\">),<\/span>\r\n    <span class=\"nf\">path<\/span><span class=\"p\">(<\/span><span class=\"sh\">'<\/span><span class=\"s\">auth\/<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span> <span class=\"nf\">include<\/span><span class=\"p\">(<\/span><span class=\"sh\">'<\/span><span class=\"s\">drf_social_oauth2.urls<\/span><span class=\"sh\">'<\/span><span class=\"p\">,<\/span> <span class=\"n\">namespace<\/span><span class=\"o\">=<\/span><span class=\"sh\">'<\/span><span class=\"s\">drf<\/span><span class=\"sh\">'<\/span><span class=\"p\">)),<\/span> <span class=\"c1\"># \u8ffd\u52a0\r\n<\/span><span class=\"p\">]<\/span>\r\n<\/code><\/pre>\n<h2>7. \u8fc1\u79fb\uff0c\u5efa\u7acb\u8d85\u7ea7\u7528\u6237<\/h2>\n<pre class=\"post-pre\"><code><span class=\"nv\">$ <\/span>python manage.py migrate\r\n<span class=\"nv\">$ <\/span>python manage.py createsuperuser <span class=\"nt\">--email<\/span><span class=\"o\">=<\/span>your.email@gmail.com <span class=\"nt\">--username<\/span><span class=\"o\">=<\/span>admin\r\n<\/code><\/pre>\n<h2>8. \u7ba1\u7406\u9875\u9762\u8bbe\u7f6e<\/h2>\n<ul class=\"post-ul\">\u30b5\u30fc\u30d0\u8d77\u52d5<\/ul>\n<pre class=\"post-pre\"><code>$ python manage.py runserver\r\n<\/code><\/pre>\n<p>\u8bf7\u4f7f\u7528\u521b\u5efa\u7684\u7ba1\u7406\u5458\u7528\u6237\u767b\u5f55\u5230 http:\/\/127.0.0.1:8000\/admin\u3002<\/p>\n<ol>\u521b\u5efa\u5e94\u7528\u7a0b\u5e8f<\/ol>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d8aef913a08637a6cbddf\/47-0.png\" alt=\"create-application-1.png\" \/><\/div>\n<p>\u6dfb\u52a0 Django OAuth Toolkit \u7684\u5e94\u7528\u7a0b\u5e8f<\/p>\n<ol>\u8bbe\u5b9a<\/ol>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d8aef913a08637a6cbddf\/50-0.png\" alt=\"create-application-2.png\" \/><\/div>\n<p>Client id , Client secret \u306e\u5024\u306f\u81ea\u52d5\u3067\u4f5c\u6210\u3055\u308c\u3066\u3044\u307e\u3059 \u5f8c\u307b\u3069\u5229\u7528\u3059\u308b\u306e\u3067\u3069\u3053\u304b\u30e1\u30e2\u5e33\u306b\u63a7\u3048\u3066\u304a\u304d\u307e\u3057\u3087\u3046(\u203b\u5024\u3092\u5909\u66f4\u3057\u306a\u3044\u3088\u3046\u6ce8\u610f\u3057\u3066\u304f\u3060\u3055\u3044)<br \/>\n\u305d\u306e\u4ed6\u4ee5\u4e0b\u306e\u901a\u308a\u8a2d\u5b9a\u3057\u3001\u4fdd\u5b58<\/p>\n<p>User : 1<br \/>\nClient type : Confidental<br \/>\nAuthorization grant type : Resource owner password-based<br \/>\nName : \u9069\u5f53\u306b\u5165\u529b(\u81ea\u5206\u306fGoogle OAuth\u306b\u3057\u307e\u3057\u305f)<\/p>\n<h2>9. \u78ba\u8a8dDRF<\/h2>\n<p>\u5c1d\u8bd5\u8bbf\u95ee http:\/\/127.0.0.1:8000\/auth\/convert-token\uff0c\u5982\u679c\u51fa\u73b0\u4ee5\u4e0b\u9875\u9762\uff0c\u5219\u8868\u793a\u6682\u65f6OK\uff01<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d8aef913a08637a6cbddf\/54-0.png\" alt=\"create-application-3.png\" \/><\/div>\n<h1>\u7b2c\u4e8c\u90e8\u5206\u7ed3\u675f<\/h1>\n<p>\u8f9b\u82e6\u4e86\uff0c\u8bf7\u5728\u4e0b\u4e00\u90e8\u5206\u8fdb\u884c\u524d\u7aef\u8bbe\u7f6e\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u7edd\u5bf9\u80fd\u529e\u5230\uff01Google\u767b\u5f55\u6309\u94ae\u7684\u5b9e\u73b0\u30102\/6\u3011 \u672c\u6587\u4ecb\u7ecd\u4e86\u5728React \u00d7 DjangoRESTFramew [&hellip;]<\/p>\n","protected":false},"author":10,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-49355","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u3010\u7edd\u5bf9\u80fd\u505a\u5230\uff01\u3011\u8c37\u6b4c\u767b\u5f55\u6309\u94ae\u7684\u5b9e\u73b0\u30102\/6\u3011 - Blog - Silicon Cloud<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/zh\/blog\/\u3010\u7edd\u5bf9\u80fd\u505a\u5230\uff01\u3011\u8c37\u6b4c\u767b\u5f55\u6309\u94ae\u7684\u5b9e\u73b0\u30102-6\u3011\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u3010\u7edd\u5bf9\u80fd\u505a\u5230\uff01\u3011\u8c37\u6b4c\u767b\u5f55\u6309\u94ae\u7684\u5b9e\u73b0\u30102\/6\u3011\" \/>\n<meta property=\"og:description\" content=\"\u7edd\u5bf9\u80fd\u529e\u5230\uff01Google\u767b\u5f55\u6309\u94ae\u7684\u5b9e\u73b0\u30102\/6\u3011 \u672c\u6587\u4ecb\u7ecd\u4e86\u5728React \u00d7 DjangoRESTFramew [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u3010\u7edd\u5bf9\u80fd\u505a\u5230\uff01\u3011\u8c37\u6b4c\u767b\u5f55\u6309\u94ae\u7684\u5b9e\u73b0\u30102-6\u3011\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-06-29T16:21:33+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-05-04T04:00:27+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d8aef913a08637a6cbddf\/47-0.png\" \/>\n<meta name=\"author\" content=\"\u5b87, \u534e\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u5b87, \u534e\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"2 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e7%bb%9d%e5%af%b9%e8%83%bd%e5%81%9a%e5%88%b0%ef%bc%81%e3%80%91%e8%b0%b7%e6%ad%8c%e7%99%bb%e5%bd%95%e6%8c%89%e9%92%ae%e7%9a%84%e5%ae%9e%e7%8e%b0%e3%80%902-6%e3%80%91\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e7%bb%9d%e5%af%b9%e8%83%bd%e5%81%9a%e5%88%b0%ef%bc%81%e3%80%91%e8%b0%b7%e6%ad%8c%e7%99%bb%e5%bd%95%e6%8c%89%e9%92%ae%e7%9a%84%e5%ae%9e%e7%8e%b0%e3%80%902-6%e3%80%91\/\",\"name\":\"\u3010\u7edd\u5bf9\u80fd\u505a\u5230\uff01\u3011\u8c37\u6b4c\u767b\u5f55\u6309\u94ae\u7684\u5b9e\u73b0\u30102\/6\u3011 - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-06-29T16:21:33+00:00\",\"dateModified\":\"2024-05-04T04:00:27+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/513018e4e121d3add1b7c5de8be21458\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e7%bb%9d%e5%af%b9%e8%83%bd%e5%81%9a%e5%88%b0%ef%bc%81%e3%80%91%e8%b0%b7%e6%ad%8c%e7%99%bb%e5%bd%95%e6%8c%89%e9%92%ae%e7%9a%84%e5%ae%9e%e7%8e%b0%e3%80%902-6%e3%80%91\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e7%bb%9d%e5%af%b9%e8%83%bd%e5%81%9a%e5%88%b0%ef%bc%81%e3%80%91%e8%b0%b7%e6%ad%8c%e7%99%bb%e5%bd%95%e6%8c%89%e9%92%ae%e7%9a%84%e5%ae%9e%e7%8e%b0%e3%80%902-6%e3%80%91\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e7%bb%9d%e5%af%b9%e8%83%bd%e5%81%9a%e5%88%b0%ef%bc%81%e3%80%91%e8%b0%b7%e6%ad%8c%e7%99%bb%e5%bd%95%e6%8c%89%e9%92%ae%e7%9a%84%e5%ae%9e%e7%8e%b0%e3%80%902-6%e3%80%91\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u3010\u7edd\u5bf9\u80fd\u505a\u5230\uff01\u3011\u8c37\u6b4c\u767b\u5f55\u6309\u94ae\u7684\u5b9e\u73b0\u30102\/6\u3011\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/513018e4e121d3add1b7c5de8be21458\",\"name\":\"\u5b87, \u534e\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/63cd45cbc05a35fc4ff7637a163c83c4962ef58d27472726c3a3e0c9c5194f0f?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/63cd45cbc05a35fc4ff7637a163c83c4962ef58d27472726c3a3e0c9c5194f0f?s=96&d=mm&r=g\",\"caption\":\"\u5b87, \u534e\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/yuhua\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e7%bb%9d%e5%af%b9%e8%83%bd%e5%81%9a%e5%88%b0%ef%bc%81%e3%80%91%e8%b0%b7%e6%ad%8c%e7%99%bb%e5%bd%95%e6%8c%89%e9%92%ae%e7%9a%84%e5%ae%9e%e7%8e%b0%e3%80%902-6%e3%80%91\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u3010\u7edd\u5bf9\u80fd\u505a\u5230\uff01\u3011\u8c37\u6b4c\u767b\u5f55\u6309\u94ae\u7684\u5b9e\u73b0\u30102\/6\u3011 - Blog - Silicon Cloud","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.silicloud.com\/zh\/blog\/\u3010\u7edd\u5bf9\u80fd\u505a\u5230\uff01\u3011\u8c37\u6b4c\u767b\u5f55\u6309\u94ae\u7684\u5b9e\u73b0\u30102-6\u3011\/","og_locale":"zh_CN","og_type":"article","og_title":"\u3010\u7edd\u5bf9\u80fd\u505a\u5230\uff01\u3011\u8c37\u6b4c\u767b\u5f55\u6309\u94ae\u7684\u5b9e\u73b0\u30102\/6\u3011","og_description":"\u7edd\u5bf9\u80fd\u529e\u5230\uff01Google\u767b\u5f55\u6309\u94ae\u7684\u5b9e\u73b0\u30102\/6\u3011 \u672c\u6587\u4ecb\u7ecd\u4e86\u5728React \u00d7 DjangoRESTFramew [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u3010\u7edd\u5bf9\u80fd\u505a\u5230\uff01\u3011\u8c37\u6b4c\u767b\u5f55\u6309\u94ae\u7684\u5b9e\u73b0\u30102-6\u3011\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-06-29T16:21:33+00:00","article_modified_time":"2024-05-04T04:00:27+00:00","og_image":[{"url":"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d8aef913a08637a6cbddf\/47-0.png"}],"author":"\u5b87, \u534e","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u5b87, \u534e","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"2 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e7%bb%9d%e5%af%b9%e8%83%bd%e5%81%9a%e5%88%b0%ef%bc%81%e3%80%91%e8%b0%b7%e6%ad%8c%e7%99%bb%e5%bd%95%e6%8c%89%e9%92%ae%e7%9a%84%e5%ae%9e%e7%8e%b0%e3%80%902-6%e3%80%91\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e7%bb%9d%e5%af%b9%e8%83%bd%e5%81%9a%e5%88%b0%ef%bc%81%e3%80%91%e8%b0%b7%e6%ad%8c%e7%99%bb%e5%bd%95%e6%8c%89%e9%92%ae%e7%9a%84%e5%ae%9e%e7%8e%b0%e3%80%902-6%e3%80%91\/","name":"\u3010\u7edd\u5bf9\u80fd\u505a\u5230\uff01\u3011\u8c37\u6b4c\u767b\u5f55\u6309\u94ae\u7684\u5b9e\u73b0\u30102\/6\u3011 - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-06-29T16:21:33+00:00","dateModified":"2024-05-04T04:00:27+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/513018e4e121d3add1b7c5de8be21458"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e7%bb%9d%e5%af%b9%e8%83%bd%e5%81%9a%e5%88%b0%ef%bc%81%e3%80%91%e8%b0%b7%e6%ad%8c%e7%99%bb%e5%bd%95%e6%8c%89%e9%92%ae%e7%9a%84%e5%ae%9e%e7%8e%b0%e3%80%902-6%e3%80%91\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e7%bb%9d%e5%af%b9%e8%83%bd%e5%81%9a%e5%88%b0%ef%bc%81%e3%80%91%e8%b0%b7%e6%ad%8c%e7%99%bb%e5%bd%95%e6%8c%89%e9%92%ae%e7%9a%84%e5%ae%9e%e7%8e%b0%e3%80%902-6%e3%80%91\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e7%bb%9d%e5%af%b9%e8%83%bd%e5%81%9a%e5%88%b0%ef%bc%81%e3%80%91%e8%b0%b7%e6%ad%8c%e7%99%bb%e5%bd%95%e6%8c%89%e9%92%ae%e7%9a%84%e5%ae%9e%e7%8e%b0%e3%80%902-6%e3%80%91\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u3010\u7edd\u5bf9\u80fd\u505a\u5230\uff01\u3011\u8c37\u6b4c\u767b\u5f55\u6309\u94ae\u7684\u5b9e\u73b0\u30102\/6\u3011"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/513018e4e121d3add1b7c5de8be21458","name":"\u5b87, \u534e","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/63cd45cbc05a35fc4ff7637a163c83c4962ef58d27472726c3a3e0c9c5194f0f?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/63cd45cbc05a35fc4ff7637a163c83c4962ef58d27472726c3a3e0c9c5194f0f?s=96&d=mm&r=g","caption":"\u5b87, \u534e"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/yuhua\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90%e7%bb%9d%e5%af%b9%e8%83%bd%e5%81%9a%e5%88%b0%ef%bc%81%e3%80%91%e8%b0%b7%e6%ad%8c%e7%99%bb%e5%bd%95%e6%8c%89%e9%92%ae%e7%9a%84%e5%ae%9e%e7%8e%b0%e3%80%902-6%e3%80%91\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/49355","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/10"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=49355"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/49355\/revisions"}],"predecessor-version":[{"id":98195,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/49355\/revisions\/98195"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=49355"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=49355"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=49355"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}