抱歉,您的浏览器无法访问本站
本页面需要浏览器支持(启用)JavaScript
了解详情 >

项目结构

DearXuan

在项目根目录下创建”api”文件夹,在api中创建”index.*”(例如index.js)的文件,则该文件会被尝试执行,如果将js文件直接放在根目录,则会被当作文本文件读取

如果不创建,则你需要手动输入文件名来访问api

例如

*.vercel.app/api/js

vercel会根据后缀名自动判断语言

下面给出了3中语言的api示例

python

1
2
3
4
5
6
7
8
9
10
11
from http.server import BaseHTTPRequestHandler


class handler(BaseHTTPRequestHandler):

def do_GET(self):
self.send_response(200)
self.send_header('Content-type', 'text/plain')
self.end_headers()
self.wfile.write("DearXuan's API by python!".encode())
return

nodejs

1
2
3
4
5
6
module.exports = OnRequest;

function OnRequest(request, response){
response.send("DearXuan's API by nodejs!");
response.end();
}

php

该语言需要配置文件

1
2
<?php
echo "DearXuan's API by php!";

配置文件

在根目录下创建 “vercel.json” 文件

php需要配置环境才能运行,将下面json代码直接复制到 “vercel.json” 中即可

1
2
3
4
5
6
7
8
9
10
{
"functions": {
"api/index.php": {
"runtime": "vercel-php@0.3.1",
"excludeFiles": "{test/**}",
"memory": 256,
"maxDuration": 5
}
}
}

通过配置文件还可以自定义路由

例如下面的json代码指定使用 “/api/python.py” 文件执行 “/python” 路由的请求

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
{
"functions": {
"api/php.php": {
"runtime": "vercel-php@0.3.1",
"excludeFiles": "{test/**}",
"memory": 256,
"maxDuration": 5
}
},
"routes": [
{
"src": "/python",
"dest": "/api/python"
}
]
}

构建

你能看到这篇文章,说明你肯定对vercel有些了解了,因此这里不在介绍怎么上传。但是构建时还有一个注意点,下图红圈圈起来的地方选择 “Other”(默认值),不要修改

DearXuan

访问

通过 *.vercel.app/api/js ,即可访问js写的api,其它文件同理

如果访问 *.vercel.app/api/js/ ,则会访问”/api/js/“目录下的index文件,因此在本项目中会报错

访问 *.vercel.app/python 和访问 *.vercel.app/api/python 是完全相同的,因为json中已经定义了这个路由

评论