Vue 3 接入谷歌登录 (小白版)

本文档介绍如何在 Vue 3 项目中接入 Google OAuth 登录功能。


📋 前置准备

1. 获取 Google 客户端 ID (若已有可直接跳过下面步骤直接到项目集成)

步骤一:访问 Google Cloud Console

访问 Google Cloud Console

步骤二:创建项目

  1. 点击 "创建项目" 或选择现有项目
  2. 输入项目名称(例如:testDemo
  3. 点击 "创建"

步骤四:创建 OAuth 客户端 ID

  1. 点击 "创建凭据" → "OAuth 客户端 ID".
  2. 选择应用类型:Web 应用
  3. 填写配置信息:
    • 名称xxx
    • 已获授权的 JavaScript 来源
      • http://localhost:5173 (开发环境)
      • https://your-production-domain.com (生产环境)
    • 已获授权的重定向 URI
      • http://localhost:5173 (开发环境)
      • https://your-production-domain.com/ (生产环境)
  4. 点击 "创建"
  5. 保存生成的客户端 ID

🚀 项目集成

2. 安装依赖

bash 复制代码
pnpm add vue3-google-login

📚 官方文档vue3-google-login


3. 配置插件

src/main.ts 中注册插件:

typescript 复制代码
import { createApp } from 'vue';
// 关键代码 引入插件
import vue3GoogleLogin from 'vue3-google-login';
import App from './App.vue';

const app = createApp(App);

// 关键代码 注册 Google Login 插件
app.use(vue3GoogleLogin, {
  clientId: xxxx, // 这里为客户端id
});

app.mount('#app');

💻 使用方式

方式一:获取auth_code

vue 复制代码
<script setup>
import { googleAuthCodeLogin vv} from "vue3-google-login"
const login = () => {
  googleAuthCodeLogin().then((response) => {
    console.log("Handle the response", response)
  })
}
</script>

<template>
  <button @click="login">Login Using Google</button>
</template>

方式二:获取access_token

vue 复制代码
<script setup>
import { googleTokenLogin } from "vue3-google-login"
const login = () => {
  googleTokenLogin().then((response) => {
    console.log("Handle the response", response)
  })
}
</script>

<template>
  <button @click="login">Login Using Google</button>
</template>

相关推荐
刘发财1 小时前
弃用html2pdf.js,这个html转pdf方案能力是它的几十倍
前端·javascript·github
牛奶4 小时前
2026年大模型怎么选?前端人实用对比
前端·人工智能·ai编程
牛奶4 小时前
前端人为什么要学AI?
前端·人工智能·ai编程
Kagol6 小时前
🎉OpenTiny NEXT-SDK 重磅发布:四步把你的前端应用变成智能应用!
前端·开源·agent
GIS之路7 小时前
ArcGIS Pro 中的 notebook 初识
前端
JavaGuide7 小时前
7 道 RAG 基础概念知识点/面试题总结
前端·后端
ssshooter8 小时前
看完就懂 useSyncExternalStore
前端·javascript·react.js
格砸9 小时前
从入门到辞职|从ChatGPT到OpenClaw,跟上智能时代的进化
前端·人工智能·后端
Live000009 小时前
在鸿蒙中使用 Repeat 渲染嵌套列表,修改内层列表的一个元素,页面不会更新
前端·javascript·react native
柳杉9 小时前
使用Ai从零开发智慧水利态势感知大屏(开源)
前端·javascript·数据可视化