Admin SDK คือชุดไลบรารีเซิร์ฟเวอร์ที่ช่วยให้คุณโต้ตอบกับ Firebase จากสภาพแวดล้อมที่มีสิทธิ์เพื่อดำเนินการต่างๆ เช่น
- ทำการค้นหาและการเปลี่ยนแปลงในFirebase SQL Connect บริการสำหรับ การจัดการข้อมูลแบบกลุ่มและการดำเนินการอื่นๆ ที่มีสิทธิ์ของผู้ดูแลระบบอย่างเต็มรูปแบบ
- อ่านและเขียนRealtime Databaseข้อมูลด้วยสิทธิ์ของผู้ดูแลระบบแบบเต็ม
- ส่งFirebase Cloud Messagingโดยใช้โปรแกรมด้วยวิธีการที่เรียบง่ายและเป็นทางเลือกแทนโปรโตคอลเซิร์ฟเวอร์ของ Firebase Cloud Messaging
- สร้างและยืนยันโทเค็นการตรวจสอบสิทธิ์ Firebase
- เข้าถึงทรัพยากร Google Cloud เช่น บัคเก็ต Cloud Storage และ ฐานข้อมูล Cloud Firestore ที่เชื่อมโยงกับโปรเจ็กต์ Firebase
- สร้างคอนโซลผู้ดูแลระบบแบบง่ายของคุณเองเพื่อทำสิ่งต่างๆ เช่น ค้นหาข้อมูลผู้ใช้ หรือเปลี่ยนอีเมลของผู้ใช้สำหรับการตรวจสอบสิทธิ์
หากสนใจใช้ Node.js SDK เป็นไคลเอ็นต์สำหรับการเข้าถึงของผู้ใช้ปลายทาง (เช่น ในแอปพลิเคชันเดสก์ท็อปหรือ IoT ของ Node.js) แทนการเข้าถึงของผู้ดูแลระบบ จากสภาพแวดล้อมที่มีสิทธิ์ (เช่น เซิร์ฟเวอร์) คุณควรทำตามวิธีการตั้งค่า JavaScript SDK ของไคลเอ็นต์แทน
ต่อไปนี้คือตารางฟีเจอร์ที่แสดงฟีเจอร์ Firebase ที่รองรับในแต่ละภาษา
ดูข้อมูลเพิ่มเติมเกี่ยวกับการผสานรวม Admin SDK สำหรับการใช้งานเหล่านี้ได้ในเอกสารประกอบที่เกี่ยวข้องของ Realtime Database FCM Authentication Remote Config และ Cloud Storage ส่วนที่เหลือของหน้านี้จะเน้นที่การตั้งค่าพื้นฐานสำหรับ Admin SDK
ข้อกำหนดเบื้องต้น
ตรวจสอบว่าคุณมีแอปเซิร์ฟเวอร์
ตรวจสอบว่าเซิร์ฟเวอร์ของคุณเรียกใช้สิ่งต่อไปนี้โดยขึ้นอยู่กับAdmin SDK ที่คุณใช้
- Admin Node.js SDK — Node.js 22 ขึ้นไป
- Admin Java SDK - Java 8 ขึ้นไป
- Admin Python SDK - Python 3.9 ขึ้นไป (แนะนํา Python 3.10 ขึ้นไป)
เลิกใช้งานการรองรับ Python 3.9 แล้ว - Admin Go SDK - Go 1.25 ขึ้นไป
- Admin .NET SDK - .NET Framework 4.6.2 ขึ้นไปหรือ .NET Standard 2.0 หรือ .NET 6.0 ขึ้นไป (แนะนํา .NET 8.0 ขึ้นไป)
การรองรับ .NET 6.0 และ 7.0 ถูกเลิกใช้งานแล้ว - SDK Dart สำหรับผู้ดูแลระบบเวอร์ชันทดลอง - ตรวจสอบว่าเซิร์ฟเวอร์ใช้ Dart SDK 3.9 ขึ้นไป
- Admin Node.js SDK — Node.js 22 ขึ้นไป
ตั้งค่าโปรเจ็กต์ Firebase และบัญชีบริการ
หากต้องการใช้Firebase Admin SDK คุณจะต้องมีสิ่งต่อไปนี้
- โปรเจ็กต์ Firebase
- บัญชีบริการ Firebase Admin SDK เพื่อสื่อสารกับ Firebase ระบบจะสร้างบัญชีบริการนี้โดยอัตโนมัติเมื่อคุณสร้างโปรเจ็กต์ Firebase หรือเพิ่ม Firebase ลงในโปรเจ็กต์ Google Cloud
- ไฟล์กำหนดค่าที่มีข้อมูลเข้าสู่ระบบของบัญชีบริการ
หากยังไม่มีโปรเจ็กต์ Firebase คุณจะต้องสร้างโปรเจ็กต์ในFirebaseคอนโซล โปรดไปที่ทำความเข้าใจโปรเจ็กต์ Firebase เพื่อดูข้อมูลเพิ่มเติมเกี่ยวกับโปรเจ็กต์ Firebase
เพิ่ม SDK
หากกำลังตั้งค่าโปรเจ็กต์ใหม่ คุณจะต้องติดตั้ง SDK สำหรับ ภาษาที่ต้องการ
Node.js
Firebase Admin Node.js SDK พร้อมใช้งานใน npm หากยังไม่มีไฟล์ package.json ให้สร้างผ่าน npm init จากนั้นติดตั้ง
firebase-admin แพ็กเกจ npm และบันทึกลงใน package.json
npm install firebase-admin --save
หากต้องการใช้โมดูลในแอปพลิเคชัน ให้requireจากไฟล์ JavaScript
const { initializeApp } = require('firebase-admin/app');
หากใช้ ES2015 คุณสามารถimportโมดูลได้โดยทำดังนี้
import { initializeApp } from 'firebase-admin/app';
Java
Firebase Admin Java SDK เผยแพร่ในที่เก็บ Maven Central
หากต้องการติดตั้งไลบรารี ให้ประกาศเป็นทรัพยากร Dependency ในไฟล์ build.gradle
dependencies {
implementation 'com.google.firebase:firebase-admin:9.9.0'
}
หากใช้ Maven เพื่อสร้างแอปพลิเคชัน คุณสามารถเพิ่มทรัพยากร Dependency ต่อไปนี้ลงใน pom.xml ได้
<dependency>
<groupId>com.google.firebase</groupId>
<artifactId>firebase-admin</artifactId>
<version>9.9.0</version>
</dependency>
Python
Firebase Admin Python SDK พร้อมใช้งานผ่าน pip
คุณติดตั้งไลบรารีสำหรับผู้ใช้ทั้งหมดได้ผ่าน sudo โดยทำดังนี้
sudo pip install firebase-admin
หรือจะติดตั้งไลบรารีสำหรับผู้ใช้ปัจจุบันเท่านั้นก็ได้โดยส่งผ่านแฟล็ก --user
pip install --user firebase-admin
Go
คุณติดตั้ง Go Admin SDK ได้โดยใช้เครื่องมือ go get ดังนี้
# Install the latest version:
go get firebase.google.com/go/v4@latest
# Or install a specific version:
go get firebase.google.com/go/v4@4.20.0
C#
คุณติดตั้ง .NET Admin SDK ได้โดยใช้เครื่องมือจัดการแพ็กเกจ .NET ดังนี้
Install-Package FirebaseAdmin -Version 3.5.0
หรือจะติดตั้งโดยใช้dotnetยูทิลิตีบรรทัดคำสั่งก็ได้
dotnet add package FirebaseAdmin --version 3.5.0
หรือจะติดตั้งโดยเพิ่มรายการอ้างอิงแพ็กเกจต่อไปนี้ลงในไฟล์ .csproj ก็ได้
<ItemGroup>
<PackageReference Include="FirebaseAdmin" Version="3.5.0" />
</ItemGroup>
Dart (ทดลอง)
dart pub add firebase_admin_sdk
หากต้องการใช้โมดูลในแอปพลิเคชัน ให้นำเข้าตามที่แสดง
import 'package:firebase_admin_sdk';
// Also import the separate Firestore package if you're interacting with Firestore.
import 'package:google_cloud_firestore/google_cloud_firestore.dart';
เริ่มต้น SDK
เมื่อสร้างโปรเจ็กต์ Firebase แล้ว คุณจะเริ่มต้น SDK ด้วยข้อมูลรับรองเริ่มต้นของแอปพลิเคชัน Google ได้ เนื่องจากการค้นหาข้อมูลรับรองเริ่มต้นจะทำงานโดยอัตโนมัติอย่างสมบูรณ์ในสภาพแวดล้อมของ Google โดยไม่ต้องระบุตัวแปรสภาพแวดล้อมหรือการกำหนดค่าอื่นๆ เราจึงขอแนะนำอย่างยิ่งให้ใช้การเริ่มต้น SDK ในลักษณะนี้สำหรับแอปพลิเคชันที่ทำงานในสภาพแวดล้อมของ Google เช่น Firebase App Hosting, Cloud Run, App Engine และ Cloud Functions for Firebase
หากต้องการระบุตัวเลือกการเริ่มต้นสำหรับบริการต่างๆ เช่น Realtime Database,
Cloud Storage หรือ Cloud Functions ให้ใช้ตัวแปรสภาพแวดล้อม FIREBASE_CONFIG
หากเนื้อหาของตัวแปร FIREBASE_CONFIG ขึ้นต้นด้วย { ระบบจะแยกวิเคราะห์เป็นออบเจ็กต์ JSON มิฉะนั้น SDK จะถือว่า
สตริงเป็นเส้นทางของไฟล์ JSON ที่มีตัวเลือก
Node.js
const app = initializeApp();
Java
FirebaseApp.initializeApp();
Python
default_app = firebase_admin.initialize_app()
Go
app, err := firebase.NewApp(context.Background(), nil)
if err != nil {
log.Fatalf("error initializing app: %v\n", err)
}
C#
FirebaseApp.Create();
Dart (ทดลอง)
final admin = FirebaseApp.initializeApp();
เมื่อเริ่มต้นแล้ว คุณจะใช้ Admin SDK เพื่อทํางานประเภทต่อไปนี้ได้
- ใช้การตรวจสอบสิทธิ์ที่กำหนดเอง
- จัดการFirebase Authenticationผู้ใช้
- เรียกใช้การค้นหาและการเปลี่ยนแปลงการดูแลระบบในFirebase SQL Connect บริการ
- อ่านและเขียนข้อมูลจาก Realtime Database
- ส่งFirebase Cloud Messaging ข้อความ
การใช้โทเค็นการรีเฟรช OAuth 2.0
Admin SDK ยังมีข้อมูลเข้าสู่ระบบที่ช่วยให้คุณตรวจสอบสิทธิ์ ด้วยโทเค็นการรีเฟรช Google OAuth2 ได้ด้วย
Node.js
const myRefreshToken = '...'; // Get refresh token from OAuth2 flow
initializeApp({
credential: refreshToken(myRefreshToken),
databaseURL: 'https://<DATABASE_NAME>.firebaseio.com'
});
Java
FileInputStream refreshToken = new FileInputStream("path/to/refreshToken.json");
FirebaseOptions options = FirebaseOptions.builder()
.setCredentials(GoogleCredentials.fromStream(refreshToken))
.setDatabaseUrl("https://<DATABASE_NAME>.firebaseio.com/")
.build();
FirebaseApp.initializeApp(options);
Python
cred = credentials.RefreshToken('path/to/refreshToken.json')
default_app = firebase_admin.initialize_app(cred)
Go
opt := option.WithCredentialsFile("path/to/refreshToken.json")
config := &firebase.Config{ProjectID: "my-project-id"}
app, err := firebase.NewApp(context.Background(), config, opt)
if err != nil {
log.Fatalf("error initializing app: %v\n", err)
}
C#
FirebaseApp.Create(new AppOptions()
{
Credential = CredentialFactory.FromFile<UserCredential>("path/to/refreshToken.json").ToGoogleCredential(),
});
เริ่มต้น SDK ในสภาพแวดล้อมที่ไม่ใช่ของ Google
หากคุณทำงานในสภาพแวดล้อมเซิร์ฟเวอร์ที่ไม่ใช่ของ Google ซึ่งไม่สามารถ ค้นหาข้อมูลเข้าสู่ระบบเริ่มต้นโดยอัตโนมัติได้อย่างเต็มที่ คุณสามารถเริ่มต้น SDK ด้วยไฟล์คีย์บัญชีบริการที่ส่งออกได้
โปรเจ็กต์ Firebase รองรับบัญชีบริการของ Google ซึ่งคุณใช้เพื่อเรียกใช้ เซิร์ฟเวอร์ API ของ Firebase จากเซิร์ฟเวอร์แอปหรือสภาพแวดล้อมที่เชื่อถือได้ หากคุณ พัฒนาโค้ดในเครื่องหรือติดตั้งใช้งานแอปพลิเคชันในองค์กร คุณสามารถใช้ ข้อมูลเข้าสู่ระบบที่ได้รับโดยใช้บัญชีบริการนี้เพื่อให้สิทธิ์คำขอของเซิร์ฟเวอร์
คุณดูบัญชีบริการทั้งหมดสำหรับโปรเจ็กต์ Firebase ได้ใน
หากต้องการตรวจสอบสิทธิ์บัญชีบริการและให้สิทธิ์เข้าถึงบริการ Firebase คุณต้องสร้างไฟล์คีย์ส่วนตัวในรูปแบบ JSON
วิธีสร้างไฟล์คีย์ส่วนตัวสำหรับบัญชีบริการ
ในFirebaseคอนโซล ให้ไปที่
การตั้งค่า > แท็บบัญชีบริการคลิกสร้างคีย์ส่วนตัวใหม่ แล้วยืนยันโดยคลิก สร้างคีย์
จัดเก็บไฟล์ JSON ที่มีคีย์อย่างปลอดภัย
เมื่อให้สิทธิ์ผ่านบัญชีบริการ คุณจะมี 2 ตัวเลือกในการระบุข้อมูลเข้าสู่ระบบให้กับแอปพลิเคชัน คุณจะตั้งค่าตัวแปรสภาพแวดล้อม GOOGLE_APPLICATION_CREDENTIALS หรือส่งเส้นทางไปยังคีย์บัญชีบริการในโค้ดอย่างชัดเจนก็ได้ ตัวเลือกแรกมีความปลอดภัยมากกว่าและเราขอแนะนำให้ใช้
วิธีตั้งค่าตัวแปรสภาพแวดล้อม
ตั้งค่าตัวแปรสภาพแวดล้อม GOOGLE_APPLICATION_CREDENTIALS เป็นเส้นทางไฟล์ของไฟล์ JSON ที่มีคีย์บัญชีบริการ ตัวแปรนี้จะมีผลกับเซสชันเชลล์ปัจจุบันเท่านั้น ดังนั้นหากคุณเปิดเซสชันใหม่ ให้ตั้งค่าตัวแปรอีกครั้ง
Linux หรือ macOS
export GOOGLE_APPLICATION_CREDENTIALS="/home/user/Downloads/service-account-file.json"
Windows
ด้วย PowerShell
$env:GOOGLE_APPLICATION_CREDENTIALS="C:\Users\username\Downloads\service-account-file.json"
หลังจากทำตามขั้นตอนข้างต้นแล้ว ข้อมูลรับรองเริ่มต้นของแอปพลิเคชัน (ADC) จะกำหนดข้อมูลเข้าสู่ระบบของคุณโดยนัยได้ ซึ่งจะช่วยให้คุณใช้ข้อมูลเข้าสู่ระบบของบัญชีบริการ เมื่อทดสอบหรือเรียกใช้ในสภาพแวดล้อมที่ไม่ใช่ของ Google ได้
เริ่มต้น SDK ดังที่แสดง
Node.js
initializeApp({
credential: applicationDefault(),
databaseURL: 'https://<DATABASE_NAME>.firebaseio.com'
});
Java
FirebaseOptions options = FirebaseOptions.builder()
.setCredentials(GoogleCredentials.getApplicationDefault())
.setDatabaseUrl("https://<DATABASE_NAME>.firebaseio.com/")
.build();
FirebaseApp.initializeApp(options);
Python
default_app = firebase_admin.initialize_app()
Go
app, err := firebase.NewApp(context.Background(), nil)
if err != nil {
log.Fatalf("error initializing app: %v\n", err)
}
C#
FirebaseApp.Create(new AppOptions()
{
Credential = GoogleCredential.GetApplicationDefault(),
ProjectId = "my-project-id",
});
เริ่มต้นแอปหลายแอป
ในกรณีส่วนใหญ่ คุณจะต้องเริ่มต้นแอปเริ่มต้นเพียงแอปเดียว คุณสามารถ เข้าถึงบริการจากแอปนั้นได้ 2 วิธีที่เทียบเท่ากัน ดังนี้
Node.js
// Initialize the default app
const defaultApp = initializeApp(defaultAppConfig);
console.log(defaultApp.name); // '[DEFAULT]'
// Retrieve services via the defaultApp variable...
let defaultAuth = getAuth(defaultApp);
let defaultDatabase = getDatabase(defaultApp);
// ... or use the equivalent shorthand notation
defaultAuth = getAuth();
defaultDatabase = getDatabase();
Java
// Initialize the default app
FirebaseApp defaultApp = FirebaseApp.initializeApp(defaultOptions);
System.out.println(defaultApp.getName()); // "[DEFAULT]"
// Retrieve services by passing the defaultApp variable...
FirebaseAuth defaultAuth = FirebaseAuth.getInstance(defaultApp);
FirebaseDatabase defaultDatabase = FirebaseDatabase.getInstance(defaultApp);
// ... or use the equivalent shorthand notation
defaultAuth = FirebaseAuth.getInstance();
defaultDatabase = FirebaseDatabase.getInstance();
Python
# Import the Firebase service
from firebase_admin import auth
# Initialize the default app
default_app = firebase_admin.initialize_app(cred)
print(default_app.name) # "[DEFAULT]"
# Retrieve services via the auth package...
# auth.create_custom_token(...)
Go
// Initialize default app
app, err := firebase.NewApp(context.Background(), nil)
if err != nil {
log.Fatalf("error initializing app: %v\n", err)
}
// Access auth service from the default app
client, err := app.Auth(context.Background())
if err != nil {
log.Fatalf("error getting Auth client: %v\n", err)
}
C#
// Initialize the default app
var defaultApp = FirebaseApp.Create(new AppOptions()
{
Credential = GoogleCredential.GetApplicationDefault(),
});
Console.WriteLine(defaultApp.Name); // "[DEFAULT]"
// Retrieve services by passing the defaultApp variable...
var defaultAuth = FirebaseAuth.GetAuth(defaultApp);
// ... or use the equivalent shorthand notation
defaultAuth = FirebaseAuth.DefaultInstance;
กรณีการใช้งานบางอย่างกำหนดให้คุณต้องสร้างแอปหลายแอปพร้อมกัน ตัวอย่างเช่น คุณอาจต้องการอ่านข้อมูลจาก Realtime Database ของโปรเจ็กต์ Firebase หนึ่งและสร้างโทเค็นที่กำหนดเองสำหรับอีกโปรเจ็กต์หนึ่ง หรือคุณอาจต้องการ ตรวจสอบสิทธิ์ 2 แอปด้วยข้อมูลเข้าสู่ระบบที่แยกกัน Firebase SDK ช่วยให้คุณสร้างแอปหลายแอปพร้อมกันได้ โดยแต่ละแอปจะมีข้อมูลการกำหนดค่าของตัวเอง
Node.js
// Initialize the default app
initializeApp(defaultAppConfig);
// Initialize another app with a different config
var otherApp = initializeApp(otherAppConfig, 'other');
console.log(getApp().name); // '[DEFAULT]'
console.log(otherApp.name); // 'other'
// Use the shorthand notation to retrieve the default app's services
const defaultAuth = getAuth();
const defaultDatabase = getDatabase();
// Use the otherApp variable to retrieve the other app's services
const otherAuth = getAuth(otherApp);
const otherDatabase = getDatabase(otherApp);
Java
// Initialize the default app
FirebaseApp defaultApp = FirebaseApp.initializeApp(defaultOptions);
// Initialize another app with a different config
FirebaseApp otherApp = FirebaseApp.initializeApp(otherAppConfig, "other");
System.out.println(defaultApp.getName()); // "[DEFAULT]"
System.out.println(otherApp.getName()); // "other"
// Use the shorthand notation to retrieve the default app's services
FirebaseAuth defaultAuth = FirebaseAuth.getInstance();
FirebaseDatabase defaultDatabase = FirebaseDatabase.getInstance();
// Use the otherApp variable to retrieve the other app's services
FirebaseAuth otherAuth = FirebaseAuth.getInstance(otherApp);
FirebaseDatabase otherDatabase = FirebaseDatabase.getInstance(otherApp);
Python
# Initialize the default app
default_app = firebase_admin.initialize_app(cred)
# Initialize another app with a different config
other_app = firebase_admin.initialize_app(cred, name='other')
print(default_app.name) # "[DEFAULT]"
print(other_app.name) # "other"
# Retrieve default services via the auth package...
# auth.create_custom_token(...)
# Use the `app` argument to retrieve the other app's services
# auth.create_custom_token(..., app=other_app)
Go
// Initialize the default app
defaultApp, err := firebase.NewApp(context.Background(), nil)
if err != nil {
log.Fatalf("error initializing app: %v\n", err)
}
// Initialize another app with a different config
opt := option.WithCredentialsFile("service-account-other.json")
otherApp, err := firebase.NewApp(context.Background(), nil, opt)
if err != nil {
log.Fatalf("error initializing app: %v\n", err)
}
// Access Auth service from default app
defaultClient, err := defaultApp.Auth(context.Background())
if err != nil {
log.Fatalf("error getting Auth client: %v\n", err)
}
// Access auth service from other app
otherClient, err := otherApp.Auth(context.Background())
if err != nil {
log.Fatalf("error getting Auth client: %v\n", err)
}
C#
// Initialize the default app
var defaultApp = FirebaseApp.Create(defaultOptions);
// Initialize another app with a different config
var otherApp = FirebaseApp.Create(otherAppConfig, "other");
Console.WriteLine(defaultApp.Name); // "[DEFAULT]"
Console.WriteLine(otherApp.Name); // "other"
// Use the shorthand notation to retrieve the default app's services
var defaultAuth = FirebaseAuth.DefaultInstance;
// Use the otherApp variable to retrieve the other app's services
var otherAuth = FirebaseAuth.GetAuth(otherApp);
ตั้งค่าขอบเขตสำหรับ Realtime Database และ Authentication
หากคุณใช้ VM ของ Google Compute Engine ที่มีข้อมูลรับรองเริ่มต้นของแอปพลิเคชัน Google สำหรับ Realtime Database หรือ Authentication โปรดตรวจสอบว่าได้ตั้งค่าขอบเขตการเข้าถึงที่ถูกต้องด้วย
สำหรับ Realtime Database และ Authentication คุณต้องมีขอบเขตที่ลงท้ายด้วย userinfo.email และ
cloud-platform หรือ firebase.database หากต้องการตรวจสอบขอบเขตการเข้าถึงที่มีอยู่
และเปลี่ยนขอบเขต ให้เรียกใช้คำสั่งต่อไปนี้โดยใช้ gcloud
gcloud
# Check the existing access scopes
gcloud compute instances describe [INSTANCE_NAME] --format json
# The above command returns the service account information. For example:
"serviceAccounts": [
{
"email": "your.gserviceaccount.com",
"scopes": [
"https://www.googleapis.com/auth/cloud-platform",
"https://www.googleapis.com/auth/userinfo.email"
]
}
],
# Stop the VM, then run the following command, using the service account
# that gcloud returned when you checked the scopes.
gcloud compute instances set-service-account [INSTANCE_NAME] --service-account "your.gserviceaccount.com" --scopes "https://www.googleapis.com/auth/firebase.database,https://www.googleapis.com/auth/userinfo.email"
การทดสอบด้วยข้อมูลเข้าสู่ระบบของผู้ใช้ปลายทาง gcloud
เมื่อทดสอบ Admin SDK ในเครื่องด้วย
ข้อมูลรับรองเริ่มต้นของแอปพลิเคชันของ Google
ที่ได้จากการเรียกใช้ gcloud auth application-default login คุณจะต้องทำการเปลี่ยนแปลงเพิ่มเติมเพื่อใช้ Firebase Authentication เนื่องจากสาเหตุต่อไปนี้
- Firebase Authentication ไม่ยอมรับข้อมูลเข้าสู่ระบบของผู้ใช้ปลายทาง gcloud ที่สร้างขึ้นโดยใช้ รหัสไคลเอ็นต์ OAuth ของ gcloud
- Firebase Authentication ต้องระบุรหัสโปรเจ็กต์เมื่อเริ่มต้นสำหรับ ข้อมูลเข้าสู่ระบบของผู้ใช้ปลายทางประเภทนี้
วิธีแก้ปัญหาชั่วคราวคือคุณสามารถสร้างข้อมูลรับรองเริ่มต้นของแอปพลิเคชัน Google ใน gcloud โดยใช้รหัสไคลเอ็นต์ OAuth 2.0 ของคุณเอง รหัสไคลเอ็นต์ OAuth ต้องเป็นประเภทแอปพลิเคชันแอปบนเดสก์ท็อป
gcloud
gcloud auth application-default login --client-id-file=[/path/to/client/id/file]
คุณระบุรหัสโปรเจ็กต์อย่างชัดเจนในการเริ่มต้นแอปหรือใช้เพียงตัวแปรสภาพแวดล้อม
GOOGLE_CLOUD_PROJECTก็ได้ ซึ่งวิธีหลังจะช่วยให้ไม่ต้องทำการเปลี่ยนแปลงเพิ่มเติม
เพื่อทดสอบโค้ด
หากต้องการระบุรหัสโปรเจ็กต์อย่างชัดเจน ให้ทำดังนี้
Node.js
import { initializeApp, applicationDefault } from 'firebase-admin/app';
initializeApp({
credential: applicationDefault(),
projectId: '<FIREBASE_PROJECT_ID>',
});
Java
FirebaseOptions options = FirebaseOptions.builder()
.setCredentials(GoogleCredentials.getApplicationDefault())
.setProjectId("<FIREBASE_PROJECT_ID>")
.build();
FirebaseApp.initializeApp(options);
Python
app_options = {'projectId': '<FIREBASE_PROJECT_ID>'}
default_app = firebase_admin.initialize_app(options=app_options)
Go
config := &firebase.Config{ProjectID: "<FIREBASE_PROJECT_ID>"}
app, err := firebase.NewApp(context.Background(), config)
if err != nil {
log.Fatalf("error initializing app: %v\n", err)
}
C#
FirebaseApp.Create(new AppOptions()
{
Credential = GoogleCredential.GetApplicationDefault(),
ProjectId = "<FIREBASE_PROJECT_ID>",
});
ขั้นตอนถัดไป
ดูข้อมูลเกี่ยวกับ Firebase
อ่านAdmin SDKที่เกี่ยวข้องในบล็อกโดยหนึ่งในผู้สร้าง Admin SDK เช่น การเข้าถึง Firestore และ Firebase ผ่านพร็อกซีเซิร์ฟเวอร์
เพิ่มฟีเจอร์ Firebase ไปยังแอป
- เขียนแบ็กเอนด์แบบไร้เซิร์ฟเวอร์ด้วย Cloud Functions
- จัดเก็บข้อมูลด้วย Realtime Database หรือข้อมูล Blob ด้วย Cloud Storage
- รับการแจ้งเตือนด้วย Cloud Messaging