Skip to main content

Command Palette

Search for a command to run...

Vercel | 使用 vercel 实现 API 的几种模板

Published
2 min read
Vercel | 使用 vercel 实现 API 的几种模板

平时的话我们总会遇到一些简单的 API 需求,但是现在的话呢,我又没有服务器..

在一次偶然的机会下,我发现了这个仓库

让我感到眼前一亮的是 vercel 居然可以搭建 API

接着去翻了一下 vercel 的文档,一个仓库免费版可以搭建 12serverless 服务?

好家伙,这不得整起来。

于是......这个仓库就装满了 12API zkeq/icodeq-api: 自用 API 地址 (github.com)

1

12 个对于我来说还是少了些

于是...... zkeq/icodeq-bpi: API 的第二个仓库 (github.com)

2

这不就好起来了嘛。

废话不说了,上模板

返回 HTML 数据模板 // 直接利用 str.replace()

# -*- coding: UTF-8 -*-
# 具体例子看我那个 API 仓库
from http.server import BaseHTTPRequestHandler


def index_html_1(url_list, begin_time):


    return html

def index_html_2(url_list, begin_time):


    return html


class handler(BaseHTTPRequestHandler):
    def do_GET(self):
        begin_time = get_timestamp()
        path = self.path
        path = path.replace('?native.theme=1', '')  # 这里是 B 站访问的时候多加的链接...
        url_split = path.split('?')
        if len(url_split) == 1:
            data = index_html_1()
        elif len(url_split) == 2:
            data = index_html_2()
        self.send_response(200)
        self.send_header('Access-Control-Allow-Origin', '*')
        self.send_header('Content-type', 'text/html; charset=utf-8')
        self.end_headers()
        self.wfile.write(data.encode('utf-8'))
        return

返回 JSON 数据模板

# -*- coding: UTF-8 -*-
import requests
from http.server import BaseHTTPRequestHandler
import json


def getdata(params):

    return returndata

class handler(BaseHTTPRequestHandler):
    def do_GET(self):
        path = self.path
        params = path.split('?')[1]
        data = getdata(params)
        self.send_response(200)
        self.send_header('Access-Control-Allow-Origin', '*')
        self.send_header('Content-type', 'application/json')
        self.end_headers()
        self.wfile.write(json.dumps(data).encode('utf-8'))
        return

重定向308 数据模板

# coding:utf-8
from http.server import BaseHTTPRequestHandler
import os


def get_video(params):

    return _params_data


class handler(BaseHTTPRequestHandler):
    def do_GET(self):
        params_data = get_video(params=self.path.split('?')[1])
        self.send_response(308) # vercel 只有 308 跳转才可以缓存 详情见官方文档
        self.send_header('Access-Control-Allow-Origin', '*')
        self.send_header('location', url) # 这个是主要的
        self.send_header('Refresh', '0;url={}'.format(url))
        self.send_header('Cache-Control', 'max-age=0, s-maxage=60, stale-while-revalidate=3600') # vercel 缓存
        self.send_header('Content-type', 'text/plain')
        self.end_headers()
        self.wfile.write('Redirecting to {} (308)'.format(url).encode('utf-8'))  # 这里无所谓
        return None

腾讯云函数 308 跳转模板

import json
import requests
from http.server import BaseHTTPRequestHandler


def get_308(params):

    return url


def main_handler(event, context):
    try:
        params = event.get('path').split('/')[-1]
    except IndexError:
        params = ''
    print(params)
    url = get_308(params)
    return{
        "isBase64Encoded": False,
        "statusCode": 308,
        "headers": {"Content-Type":"text/plain",
                    "Refresh": "0;url={}".format(url),
                    "location": url,
                    'Access-Control-Allow-Origin': '*',},
        "body": 'Redirecting to {} (308)'.format(url)
        }

Notion API 返回数据模板

# -*- coding: UTF-8 -*-
# 获取
import json
import requests
from http.server import BaseHTTPRequestHandler

SK = 
ID = 


def get_notion_data():
    global SK
    global ID
    url = "https://api.notion.com/v1/databases/{}/query".format(ID)
    headers = {
        "Accept": "application/json",
        "Notion-Version": "2021-08-16",
        "Content-Type": "application/json",
        "Authorization": SK
    }
    response = requests.request("POST", url, headers=headers).text
    dict_all = json.loads(response)
    short_dict = {}
    for i in dict_all['results']:
        # print(i)

    return params


class handler(BaseHTTPRequestHandler):
    def do_GET(self):
        data = get_notion_data()
        self.send_response(200)
        self.send_header('Access-Control-Allow-Origin', '*')
        self.send_header('Cache-Control', 'max-age=0, s-maxage=60, stale-while-revalidate')
        self.send_header('Content-type', 'application/json; charset=utf-8')
        self.end_headers()
        self.wfile.write(json.dumps(data).encode('utf-8'))
        return

其他需要的看我的仓库吧,这里整理这么多应该够日常使用了。

这里需要注意的是
  • vercel 的云函数 没有 Node.js 环境,但是 Github Action 有..
  • 腾讯云函数的编码问题很麻烦(这问题好像不给跟进了)
  • 3

相信大家用以上这些模板可以做出来很多有意思的东西。

🚀 x 10086

31 views

More from this blog

MySQL | 表的内连接

数据操作语言:表连接查询(一) 从多张表中提取数据 从多张表提取数据,必须指定关联的条件。如果不定义关联条件就会出现无条件连接,两张表的数据会交叉连接,产生 笛卡尔积。 规定了连接条件的表连接语句,就不会出现笛卡尔积。 # 查询每名员工的部门信息 SELECT e.empno,e.ename,d.dname FROM t_emp e JOIN t_dept d ON e.deptno=d.deptno; 表连接的分类 表连接分为两种:内连接 和 外连接 内连接是结果集中只保留符合...

May 16, 20221 min read13
MySQL | 表的内连接

MySQL | 分组查询的应用

数据操作语言:分组查询 为什么要分组? 默认情况下汇总函数是对全表范围内的数据做统计 GROUP BY 子句的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对每个小区域分别进行数据汇总处理 SELECT deptno,AVG(sal) FROM t_emp GROUP BY deptno; SELECT deptno,ROUND(AVG(sal)) FROM t_emp GROUP BY deptno; -- ROUND 取整 逐级分组 数据库支持多列分组条件,执行的时候...

Apr 27, 20221 min read10
MySQL | 分组查询的应用

MySQL | 聚合函数的使用

数据操作语言:聚合函数 什么是聚合函数 聚合函数在数据的查询分析中,应用十分广泛。聚合函数可以对 数据求和、求 最大值 和 最小值 、求 平均值 等等。 求公司员工的评价月收入是多少? SELECT AVG(sal+IFNULL(comm,0)) FROM t_emp; SELECT AVG(sal+IFNULL(comm,0)) AS avg FROM t_emp; SUM 函数 SUM 函数用于求和,只能用户数字类型,字符类型的统计结果为 0 ,日期类型统计结果是毫秒数相加 SE...

Apr 26, 20221 min read8
MySQL | 聚合函数的使用
U

Untitled Publication

173 posts

Vercel | 使用 vercel 实现 API 的几种模板