การจัดการชื่อแทน

อีเมลแทนสำหรับส่งในนามแสดงถึงอีเมลที่บัญชีใช้ส่งอีเมลได้ แต่ละบัญชีจะมีนามแฝงอย่างน้อย 1 รายการเสมอเพื่อแสดงถึง อีเมลหลักของบัญชี

ชื่อแทนสำหรับส่งในชื่อจะสอดคล้องกับฟีเจอร์"ส่งอีเมลในชื่อ" ใน อินเทอร์เฟซบนเว็บ

นอกจากนี้ยังใช้นามแฝงเพื่อจัดการลายเซ็นสำหรับบัญชีด้วย คุณต้องมีความเข้าใจพื้นฐาน เกี่ยวกับนามแฝงสำหรับส่งอีเมลในชื่อจึงจะเปลี่ยนลายเซ็นอีเมลได้ วิดีโอด้านบนแสดงวิธีวนซ้ำผ่านอีเมลแทนสำหรับส่งเป็นและแก้ไขลายเซ็นสำหรับอีเมลหลักของผู้ใช้

ดูข้อมูลเกี่ยวกับวิธี สร้าง แสดง รับ อัปเดต หรือลบนามแฝง ได้ที่ SendAs ข้อมูลอ้างอิง

การสร้างและยืนยันชื่อแทน

คุณต้องสร้าง ชื่อแทนก่อนใช้งาน ในบางกรณี ผู้ใช้ต้องยืนยันการเป็นเจ้าของ อีเมลแทนด้วย

หาก Gmail กำหนดให้ผู้ใช้ต้องยืนยันชื่อแทน ระบบจะแสดงชื่อแทนพร้อม สถานะ pending ระบบจะส่งข้อความยืนยันไปยัง อีเมลปลายทางโดยอัตโนมัติ เจ้าของอีเมลต้องทำการยืนยันให้เสร็จสมบูรณ์ก่อนจึงจะใช้อีเมลได้

นามแฝงที่ไม่ต้องมีการยืนยันจะมีสถานะการยืนยันเป็น accepted

ใช้วิธีการ verify เพื่อ ส่งคำขอยืนยันอีกครั้งหากจำเป็น

การตั้งค่า SMTP

นามแฝงสำหรับที่อยู่ภายนอกควรส่งอีเมลผ่าน SMTP ระยะไกล Mail Sending Agent (MSA) หากต้องการกำหนดค่า MSA ของ SMTP สำหรับนามแฝง ให้ใช้ฟิลด์ smtpMsa เพื่อระบุรายละเอียดการเชื่อมต่อ

การจัดการลายเซ็น

นอกจากนี้ คุณยังกำหนดค่าลายเซ็นอีเมลสำหรับแต่ละนามแฝงได้ด้วย เช่น หากต้องการตั้งค่าลายเซ็นสำหรับอีเมลหลักของผู้ใช้ ให้ทำดังนี้

Java

gmail/snippets/src/main/java/UpdateSignature.java
import com.google.api.client.googleapis.json.GoogleJsonError;
import com.google.api.client.googleapis.json.GoogleJsonResponseException;
import com.google.api.client.http.HttpRequestInitializer;
import com.google.api.client.http.javanet.NetHttpTransport;
import com.google.api.client.json.gson.GsonFactory;
import com.google.api.services.gmail.Gmail;
import com.google.api.services.gmail.GmailScopes;
import com.google.api.services.gmail.model.ListSendAsResponse;
import com.google.api.services.gmail.model.SendAs;
import com.google.auth.http.HttpCredentialsAdapter;
import com.google.auth.oauth2.GoogleCredentials;
import java.io.IOException;

/* Class to demonstrate the use of Gmail Update Signature API */
public class UpdateSignature {
  /**
   * Update the gmail signature.
   *
   * @return the updated signature id , {@code null} otherwise.
   * @throws IOException - if service account credentials file not found.
   */
  public static String updateGmailSignature() throws IOException {
        /* Load pre-authorized user credentials from the environment.
           TODO(developer) - See https://developers.google.com/identity for
            guides on implementing OAuth2 for your application. */
    GoogleCredentials credentials = GoogleCredentials.getApplicationDefault()
        .createScoped(GmailScopes.GMAIL_SETTINGS_BASIC);
    HttpRequestInitializer requestInitializer = new HttpCredentialsAdapter(credentials);

    // Create the gmail API client
    Gmail service = new Gmail.Builder(new NetHttpTransport(),
        GsonFactory.getDefaultInstance(),
        requestInitializer)
        .setApplicationName("Gmail samples")
        .build();

    try {
      SendAs primaryAlias = null;
      ListSendAsResponse aliases = service.users().settings().sendAs().list("me").execute();
      for (SendAs alias : aliases.getSendAs()) {
        if (alias.getIsPrimary()) {
          primaryAlias = alias;
          break;
        }
      }
      // Updating a new signature
      SendAs aliasSettings = new SendAs().setSignature("Automated Signature");
      SendAs result = service.users().settings().sendAs().patch(
              "me",
              primaryAlias.getSendAsEmail(),
              aliasSettings)
          .execute();
      //Prints the updated signature
      System.out.println("Updated signature - " + result.getSignature());
      return result.getSignature();
    } catch (GoogleJsonResponseException e) {
      // TODO(developer) - handle error appropriately
      GoogleJsonError error = e.getDetails();
      if (error.getCode() == 403) {
        System.err.println("Unable to update signature: " + e.getDetails());
      } else {
        throw e;
      }
    }
    return null;
  }
}

Python

gmail/snippet/settings snippets/update_signature.py
import google.auth
from googleapiclient.discovery import build
from googleapiclient.errors import HttpError


def update_signature():
  """Create and update signature in gmail.
  Returns:Draft object, including updated signature.

  Load pre-authorized user credentials from the environment.
  TODO(developer) - See https://developers.google.com/identity
  for guides on implementing OAuth2 for the application.
  """
  creds, _ = google.auth.default()

  try:
    # create gmail api client
    service = build("gmail", "v1", credentials=creds)

    primary_alias = None

    # pylint: disable=E1101
    aliases = service.users().settings().sendAs().list(userId="me").execute()
    for alias in aliases.get("sendAs"):
      if alias.get("isPrimary"):
        primary_alias = alias
        break

    send_as_configuration = {
        "displayName": primary_alias.get("sendAsEmail"),
        "signature": "Automated Signature",
    }

    # pylint: disable=E1101
    result = (
        service.users()
        .settings()
        .sendAs()
        .patch(
            userId="me",
            sendAsEmail=primary_alias.get("sendAsEmail"),
            body=send_as_configuration,
        )
        .execute()
    )
    print(f'Updated signature for: {result.get("displayName")}')

  except HttpError as error:
    print(f"An error occurred: {error}")
    result = None

  return result.get("signature")


if __name__ == "__main__":
  update_signature()