This quickstart shows you how to install the Google Gen AI SDK for your language of choice and then make your first API request. The samples vary slightly based on whether you authenticate to Vertex AI using an API key or application default credentials (ADC).
Choose your authentication method:
Before you begin
Get one of the following API keys:
- If you're a new user to Google Cloud, get an express mode API key 
- If you already have a Google Cloud project, get a Google Cloud API key that's bound to a service account. Binding an API key to a service account is possible only if it's enabled in the organization policy settings. If you can't enable this setting, use application default credentials instead. You can't use a standard API key to complete this tutorial. 
Required roles
    
      To get the permissions that
      you need to use the Gemini API in Vertex AI,
    
      ask your administrator to grant you the
    
  
  
    
      Vertex AI User  (roles/aiplatform.user)
     IAM role on your project.
  
  
  
  
  For more information about granting roles, see Manage access to projects, folders, and organizations.
  
  
You might also be able to get the required permissions through custom roles or other predefined roles.
Install the SDK and set up your environment
On your local machine, click one of the following tabs to install the SDK for your programming language.
Python Gen AI SDK
Install and update the Gen AI SDK for Python by running this command.
pip install --upgrade google-genai
Set environment variables:
export API_KEY=YOUR_API_KEY export GOOGLE_GENAI_USE_VERTEXAI=True
Go Gen AI SDK
Install and update the Gen AI SDK for Go by running this command.
go get google.golang.org/genai
Set environment variables:
export API_KEY=YOUR_API_KEY export GOOGLE_GENAI_USE_VERTEXAI=True
Node.js Gen AI SDK
Install and update the Gen AI SDK for Node.js by running this command.
npm install @google/genai
Set environment variables:
export API_KEY=YOUR_API_KEY export GOOGLE_GENAI_USE_VERTEXAI=True
Java Gen AI SDK
Install and update the Gen AI SDK for Java by running this command.
Maven
Add the following to your pom.xml:
<dependencies>
  <dependency>
    <groupId>com.google.genai</groupId>
    <artifactId>google-genai</artifactId>
    <version>0.7.0</version>
  </dependency>
</dependencies>
Set environment variables:
export API_KEY=YOUR_API_KEY export GOOGLE_GENAI_USE_VERTEXAI=True
REST
Set environment variables:
API_KEY=YOUR_API_KEY API_ENDPOINT=YOUR_API_ENDPOINT MODEL_ID="gemini-2.5-flash" GENERATE_CONTENT_API="generateContent"
Make your first request
Use the
generateContent
method to send a request to the Gemini API in Vertex AI:
Python
Go
Node.js
Java
REST
To send this prompt request, run the curl command from the command line or include the REST call in your application.
curl -X POST -H "Content-Type: application/json" "https://${API_ENDPOINT}/v1/publishers/google/models/${MODEL_ID}:${GENERATE_CONTENT_API}?key=${API_KEY}" -d $'{ "contents": { "role": "user", "parts": { "text": "Explain how AI works in a few words" } } }'
The model returns a response. Note that the response is generated in sections with each section separately evaluated for safety.
Generate images
Gemini can generate and process images conversationally. You can prompt Gemini with text, images, or a combination of both to achieve various image-related tasks, such as image generation and editing. The following code demonstrates how to generate an image based on a descriptive prompt:
You must include responseModalities: ["TEXT", "IMAGE"] in your
configuration. Image-only output is not supported with these models.
Python
Node.js
Java
Image understanding
Gemini can understand images as well. The following code uses the image generated in the previous section and uses a different model to infer information about the image:
Python
Go
Node.js
Java
Code execution
The Gemini API in Vertex AI code execution feature enables the model to generate and run Python code and learn iteratively from the results until it arrives at a final output. Vertex AI provides code execution as a tool, similar to function calling. You can use this code execution capability to build applications that benefit from code-based reasoning and that produce text output. For example:
Python
Go
Node.js
Java
For more examples of code execution, check out the code execution documentation.
What's next
Now that you made your first API request, you might want to explore the following guides that show how to set up more advanced Vertex AI features for production code: