content/cookbook/15-api-servers/20-express.mdx
You can use the AI SDK in an Express server to generate and stream text and objects to the client.
The examples start a simple HTTP server that listens on port 8080. You can e.g. test it using curl:
curl -X POST http://localhost:8080
Full example: github.com/vercel/ai/examples/express
You can use the pipeUIMessageStreamToResponse method to pipe the stream data to the server response.
import { streamText } from 'ai';
import express, { Request, Response } from 'express';
const app = express();
app.post('/', async (req: Request, res: Response) => {
const result = streamText({
model: 'openai/gpt-4o',
prompt: 'Invent a new holiday and describe its traditions.',
});
result.pipeUIMessageStreamToResponse(res);
});
app.listen(8080, () => {
console.log(`Example app listening on port ${8080}`);
});
pipeUIMessageStreamToResponse can be used to send custom data to the client.
import {
createUIMessageStream,
pipeUIMessageStreamToResponse,
streamText,
} from 'ai';
import express, { Request, Response } from 'express';
const app = express();
app.post('/custom-data-parts', async (req: Request, res: Response) => {
pipeUIMessageStreamToResponse({
response: res,
stream: createUIMessageStream({
execute: async ({ writer }) => {
writer.write({ type: 'start' });
writer.write({
type: 'data-custom',
data: {
custom: 'Hello, world!',
},
});
const result = streamText({
model: 'openai/gpt-4o',
prompt: 'Invent a new holiday and describe its traditions.',
});
writer.merge(result.toUIMessageStream({ sendStart: false }));
},
}),
});
});
app.listen(8080, () => {
console.log(`Example app listening on port ${8080}`);
});
You can send a text stream to the client using pipeTextStreamToResponse.
import { streamText } from 'ai';
import express, { Request, Response } from 'express';
const app = express();
app.post('/', async (req: Request, res: Response) => {
const result = streamText({
model: 'openai/gpt-4o',
prompt: 'Invent a new holiday and describe its traditions.',
});
result.pipeTextStreamToResponse(res);
});
app.listen(8080, () => {
console.log(`Example app listening on port ${8080}`);
});