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>

相关推荐
apollo_qwe13 分钟前
前端缓存深度解析:从基础到进阶的实现方式与实践指南
前端
学习CS的小白20 分钟前
跨域问题详解
vue.js·后端
周星星日记21 分钟前
vue中hash模式和history模式的区别
前端·面试
Light6021 分钟前
Vue 高阶优化术:v-bind 与 v-on 的实战妙用与思维跃迁
前端·低代码·vue3·v-bind·组件封装·v-on·ai辅助开发
周星星日记21 分钟前
5.为什么vue中使用query可以保留参数
前端·vue.js
lebornjose22 分钟前
javascript - webgl中绑定(bind)缓冲区的逻辑是什么?
前端·webgl
+VX:Fegn089524 分钟前
计算机毕业设计|基于springboot + vue作业管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
Tzarevich26 分钟前
现代前端开发工程化:从 Vite 到 Vue 3 多页面应用实战
vue.js·vite
瘦的可以下饭了26 分钟前
Day05- CSS 标准流、浮动、Flex布局
前端
前端无涯28 分钟前
React中setState后获取更新后值的完整解决方案
前端·react.js