应用实战|微信小程序开发示例之Super课表

此示例提供了使用 MemFire Cloud 构建一个课表的小程序的步骤。小程序用到的MemFire Cloud的功能包括:

  • 云数据库:存储小程序数据表的信息。

  • 用户验证:小程序使用MemFire Cloud提供的用户认证的API接口,快速完成用户注册登录操作。

  • 云存储:存储小程序的注册用户上传的头像。

  • 行级安全策略:采用RLS策略来限制用户访问行为,用户可以修改个人信息,上传个人头像。

  • 即时API:创建数据表时会自动生成 API。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-acketCQR-1663239309449)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=MjQ2YWViMDBiYzU2ODFhYmNiYWJiOTdkZGYwMWY4MjdfQjFVVkNxT1NOcWRYVHBEN0kwcElCb0hLV004c3pEOFRfVG9rZW46Ym94Y25WNmRyOE9mWUxVQWh2bG1mOEp2WXloXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

创建应用

目的:通过创建的一个MemFire Cloud应用来获得数据库、云存储等一系列资源,并将获得该应用专属的API访问链接和访问密钥,用户可以轻松的调用API接口与以上资源进行交互。

登录https://cloud.MemFiredb.com/auth/login,在“我的应用”页面创建一个新应用

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GFxnS37g-1663239309450)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=NjIzOGE5ZmQ0ZWQ5NzAxMTE4NjAwNGVhMjdmMjQ5YWNfRjdGejAySVlSZExmT2xGcXZ6V1NrZ3E2bE5ic2p5Q0FfVG9rZW46Ym94Y24yWjNaWmxqaVZ4ekF5TG8wOUtNVllmXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

创建数据表

点击进入应用详情页面,在“数据表”页面可视化建表。

1.创建school表

在数据表页面,点击“新建数据表”,创建school表。school表主要记录学校信息,表结构字段如下:

名称类型描述
idint8主键,自增,唯一标识ID
schoolNametext学校名称(唯一)
updated_attimeatamptz修改时间

建表页面配置:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DTsBzoZF-1663239309450)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=MGZkNTg2NDcxOTE2Yzk1YjM0ZjU1NWQzZDZlZmE3ZmZfNlhlejdlakQ4Vkp4MzNOelo3RVowNUpNUGRTODJRUmtfVG9rZW46Ym94Y25WVDZ0NjJkRzc4R1p6TUdvV1JiZ2tnXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

数据表创建完后可在school表中手动插入几条学校信息数据 ,如下图。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6UmLR4Y8-1663239309451)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=MjFhYzZhYTE0M2NmMGJkN2Q0NjkzZTYzYzVkNWZiYzRfTk95Y1M2N3NTNExqZWlSZXNYZzE0TUVaNjZZeDJQTkRfVG9rZW46Ym94Y25jUkc3c3JkNkc1TXd1VDJTcEJpOWNoXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

sql操作如下:

CREATE TABLE "public"."school" ( 
  "id" BIGINT NOT NULL,
  "updated_at" TIMESTAMP WITH TIME ZONE NOT NULL,
  "schoolName" TEXT NOT NULL,
  CONSTRAINT "school_pkey" PRIMARY KEY ("id"),
  CONSTRAINT "school_schoolName_key" UNIQUE ("schoolName")
);
INSERT INTO "public"."school" ("id", "updated_at", "schoolName") VALUES ('1', '2022-08-12 18:43:53.166+08', '武汉大学');
INSERT INTO "public"."school" ("id", "updated_at", "schoolName") VALUES ('2', '2022-08-22 11:01:19.088+08', '武汉科技大学');
INSERT INTO "public"."school" ("id", "updated_at", "schoolName") VALUES ('3', '2022-08-22 11:01:36.909+08', '华中师范大学');
INSERT INTO "public"."school" ("id", "updated_at", "schoolName") VALUES ('4', '2022-08-22 11:01:56.022+08', '武汉理工大学');

2.创建department表

在数据表页面,点击“新建数据表”,创建department表。department表主要记录学院信息,表结构字段如下:

名称类型描述
idint8主键,自增,唯一标识ID
departmentNametext学院名称,唯一
updated_attimeatamptz修改时间

建表页面配置:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-utIqrjua-1663239309452)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=ZTU3NjVmNjMwNDIzM2FlYWQxYjViMWIzYTk4YTgwMTFfbmxBRHJJY0ZMYmI0eVpINkxtelI2YmRhWkN3OEQwSHNfVG9rZW46Ym94Y254eE81WURscW1RamJqVmdBbTREcVlkXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

数据表创建完后可在department表中手动插入几条学院信息数据,如下图。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pWiJr7fM-1663239309452)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=ZTYyODAwNTQ0NDU0MmViZjdlZmFkNWFmZjg4MGZiY2JfRWx3eW5qdVhPNkw3ZzJyWnRRSmw2b1Q1NkFQVFhtbjhfVG9rZW46Ym94Y25MVlQ2OGxCN3JOUGo0RUxCVGlacmpoXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

sql操作如下

CREATE TABLE "public"."department" ( 
  "id" BIGINT NOT NULL,
  "updated_at" TIMESTAMP WITH TIME ZONE NOT NULL,
  "departmentName" TEXT NOT NULL,
  CONSTRAINT "department_pkey" PRIMARY KEY ("id"),
  CONSTRAINT "department_departmentName_key" UNIQUE ("departmentName")
);

INSERT INTO "public"."department" ("id", "updated_at", "departmentName") VALUES ('1', '2022-08-12 18:44:14.7+08', '计算机学院');
INSERT INTO "public"."department" ("id", "updated_at", "departmentName") VALUES ('2', '2022-08-18 10:09:02.871+08', '体育学院');
INSERT INTO "public"."department" ("id", "updated_at", "departmentName") VALUES ('3', '2022-08-18 10:09:28.667+08', '商贸学院');
INSERT INTO "public"."department" ("id", "updated_at", "departmentName") VALUES ('4', '2022-08-18 10:09:47.602+08', '土木工程学院');

3.创建subject表

在数据表页面,点击“新建数据表”,创建subject表。subject表主要记录课程信息,表结构字段如下:

名称类型描述
idint8主键,自增,唯一标识ID
teacherNametext老师
adresstext上课地点
subjectNametext科目
updated_attimeatamptz修改时间

建表页面配置:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JByMzLCX-1663239309452)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=MjkyNzZiODE2YzVlZTYyMzNjMTRkYTU4ZDBlZWZhNGFfb3JwOWJrWE9BRnJGbGR3dHR1RmJxa0l6V3dkYXNza05fVG9rZW46Ym94Y24zTktja0lkbjNZWUNlTEltYkVLZUljXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

数据表创建完后可在subject表中手动插入几条课程信息数据,如下图。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5u0mszZ3-1663239309453)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=MWNlZTM5YTQ1NmEwNmVlYzk3NWI3ODczMmE5M2E1M2Vfd1BGMmJ0Zmg1Z25Bb1BDSzdnUkk2YjJRUERXa2FKTTZfVG9rZW46Ym94Y25Kb0l3M0dhMHJWdEJYYW4wVDRKcjBCXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

sql操作如下

CREATE TABLE "public"."subject" ( 
  "id" BIGINT NOT NULL,
  "teacherName" TEXT NOT NULL,
  "updated_at" TIMESTAMP WITH TIME ZONE NOT NULL,
  "adress" TEXT NOT NULL,
  "subjectName" TEXT NOT NULL,
  CONSTRAINT "subject_pkey" PRIMARY KEY ("id")
);
INSERT INTO "public"."subject" ("id", "teacherName", "updated_at", "adress", "subjectName") VALUES ('1', '张珊', '2022-08-12 18:28:30.725+08', '计科楼2-1003', '数据库原理');
INSERT INTO "public"."subject" ("id", "teacherName", "updated_at", "adress", "subjectName") VALUES ('2', '李四', '2022-08-17 16:13:54.527+08', '重楼2-3112', '计算机基础');
INSERT INTO "public"."subject" ("id", "teacherName", "updated_at", "adress", "subjectName") VALUES ('3', '王五', '2022-08-17 17:28:49.603+08', '4教-101', '分布式数据库');
INSERT INTO "public"."subject" ("id", "teacherName", "updated_at", "adress", "subjectName") VALUES ('4', '王博', '2022-08-18 17:28:59.265+08', '综合楼4-401', '高等数学');
INSERT INTO "public"."subject" ("id", "teacherName", "updated_at", "adress", "subjectName") VALUES ('5', '肖战', '2022-08-18 17:29:41.462+08', '教4-401', '线性代数');

4.创建student表

在数据表页面,点击“新建数据表”,创建student表,student表主要记录学生信息,表结构字段如下:

名称类型描述
iduuid主键,自增,唯一标识ID,与auth.users表中的uuid外键关联
update_attimestampt创建时间
studentIdint8学号,唯一

建表页面配置:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-fzytnZ5q-1663239309453)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=OTk2NWU3OWNiZGQ5NzliYThlZGM2NDlhNDNiYWYzMGJfQzRmQkY3U1NHNUUxc1FqMnpiZUF6MVBLaGNhSjltTTVfVG9rZW46Ym94Y251ZFM4QTlJT0xNSUVJeUM2TXZQN0plXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

说明:其中student表字段id和auth.users表中的uuid外键关联。

5.创建subject_student表

在数据表页面,点击“新建数据表”,创建subject_student表。subject_student表主要记录学生的课表信息,表结构字段如下:

名称类型描述
idint8主键,自增,唯一标识ID
studentIdint8学号
subjectIdint8与课程表的id关联
schoolIdint8与学校表的id关联
departmentIdint8与学院表的id关联
updated_attimestampt修改时间

建表页面配置:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5HlzML4E-1663239309453)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=ZjUwOGNmZTQyZjc5N2YzMjhjMDgyNmRlZTY0YjdmMTBfeHhLc0pFelhyQURscDlBbk80dTZVTUpibVBKUVJnTnlfVG9rZW46Ym94Y25SZ1c0WDR6T3BDOXM4bDQ2dDZZVGdkXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

说明:其中subjectId与subject表中的id外键关联,schoolId与school表中的id外键关联,departmentId与department表中的id外键关联。

数据表创建后可在subject_student表中手动插入几条信息数据,如下图。

其中subjectId、schoolId、departmentId需要对应数据表里的id。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lJda1DzC-1663239309454)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=MTdmYzBlYzRiYWJjZWFhYTczZTk5ZDhlN2VmMTUzYzlfUkk0aW5leW1jZVp3Smk2ZUF1MW9HbUxlZVJ2SDkxTXJfVG9rZW46Ym94Y25MREcyUnlBaDJxNVFjSmFrWlVqZ0ZmXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

sql操作

CREATE TABLE "public"."subject_student" ( 
  "id" BIGINT NOT NULL,
  "updated_at" TIMESTAMP WITH TIME ZONE NOT NULL,
  "studentId" BIGINT NOT NULL,
  "subjectId" BIGINT NOT NULL,
  "schoolId" BIGINT NULL,
  "departmentId" BIGINT NULL,
  CONSTRAINT "subject_student_pkey" PRIMARY KEY ("id")
);
ALTER TABLE "public"."subject_student" ADD CONSTRAINT "subject_student_departmentId_fkey" FOREIGN KEY ("departmentId") REFERENCES "public"."department" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION;
ALTER TABLE "public"."subject_student" ADD CONSTRAINT "subject_student_schoolId_fkey" FOREIGN KEY ("schoolId") REFERENCES "public"."school" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION;
ALTER TABLE "public"."subject_student" ADD CONSTRAINT "subject_student_subjectId_fkey" FOREIGN KEY ("subjectId") REFERENCES "public"."subject" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION;


INSERT INTO "public"."subject_student" ("id", "updated_at", "studentId", "subjectId", "schoolId", "departmentId") VALUES ('1', '2022-08-17 09:51:14.733+08', '20222202', '1', '1', '1');
INSERT INTO "public"."subject_student" ("id", "updated_at", "studentId", "subjectId", "schoolId", "departmentId") VALUES ('2', '2022-08-17 16:14:51.236+08', '20222202', '2', '1', '1');
INSERT INTO "public"."subject_student" ("id", "updated_at", "studentId", "subjectId", "schoolId", "departmentId") VALUES ('3', '2022-08-17 17:29:33.938+08', '20222202', '3', '1', '1');
INSERT INTO "public"."subject_student" ("id", "updated_at", "studentId", "subjectId", "schoolId", "departmentId") VALUES ('4', '2022-08-18 17:30:09.934+08', '20222202', '4', '1', '1');
INSERT INTO "public"."subject_student" ("id", "updated_at", "studentId", "subjectId", "schoolId", "departmentId") VALUES ('5', '2022-08-18 17:31:45.261+08', '20222202', '5', '1', '1');

6.创建subject_time表

在数据表页面,点击“新建数据表”,创建subject_time表。subject_time表主要记录学生的排课信息,表结构字段如下:

描述:通过关联的课程id去查询课程并合并数据

名称类型描述
idint8主键,自增,唯一标识ID
subjectIdint8与课程表的id关联
weekNumtext周数(例如:“[25,26,27,28]”)
timetext第几节课(例如:1到6中的任意一个数字)
weekDaytext周几上课(例如:“[1,2]“或”[1,3,5]”)
updated_attimestampt修改时间

建表页面配置:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-7JOdDVLH-1663239309454)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=MWU5YTBjMTIxZTYwMzNmNTMwN2Y1NmVkMmE4NmFiMTZfOGg2NkFVT0dNd2VRSHdjUDRFR2cyUjgxT2ZtaU9BS0tfVG9rZW46Ym94Y25OdWw3NlY0SlM5Z3lqb0YwbUxCTkVnXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

数据表创建完成后可在subject_time表中手动插入几条信息数据,如下图。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-TRBw2xOz-1663239309454)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=YzgwMGFkZDhkNGEyZmJmM2QyNmQwYjA5ZjdmMTQ0MmZfbW81U0FiZTR4T3Z5eXpHYkpScHdCNTU1Z01kcjNoT2NfVG9rZW46Ym94Y25tYU51TmpibWh1dmpaNEhEd0xUT3RkXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

说明:其中subjectId与subject表中的id外键关联。

sql语法操作

CREATE TABLE "public"."subject_time" ( 
  "id" BIGINT NOT NULL,
  "updated_at" TIMESTAMP WITH TIME ZONE NOT NULL,
  "subjectId" BIGINT NOT NULL,
  "weekNum" TEXT NOT NULL,
  "time" TEXT NOT NULL,
  "weekDay" TEXT NOT NULL,
  CONSTRAINT "subject_time_pkey" PRIMARY KEY ("id"),
  CONSTRAINT "subject_time_subjectId_fkey" FOREIGN KEY ("subjectId") REFERENCES "public"."subject" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION
);

INSERT INTO "public"."subject_time" ("id", "updated_at", "subjectId", "weekNum", "time", "weekDay") VALUES ('1', '2022-08-12 18:29:01.828+08', '1', '[34,35,36,37,38]', '1', '[1,4,6]');
INSERT INTO "public"."subject_time" ("id", "updated_at", "subjectId", "weekNum", "time", "weekDay") VALUES ('2', '2022-08-17 16:25:48.757+08', '2', '[34,35,36,37,38]', '2', '[2,3,5]');
INSERT INTO "public"."subject_time" ("id", "updated_at", "subjectId", "weekNum", "time", "weekDay") VALUES ('3', '2022-08-17 17:29:54.301+08', '3', '[34,35,36,37,38]', '3', '[3,4,5,6,7]');
INSERT INTO "public"."subject_time" ("id", "updated_at", "subjectId", "weekNum", "time", "weekDay") VALUES ('4', '2022-08-18 17:30:59.789+08', '4', '[34,35,36,37,38,39,40]', '4', '[1,3,4,5]');
INSERT INTO "public"."subject_time" ("id", "updated_at", "subjectId", "weekNum", "time", "weekDay") VALUES ('5', '2022-08-18 17:32:20.801+08', '5', '[34,35,36,37,38,39,40]', '5', '[2,4,5]');

创建avatars存储桶

创建云存储的存储桶,用来存储用户的头像图片,涉及操作包括:

  1. 创建一个存储桶avatars

在该应用的云存储导航栏,点击“新建Bucket”按钮,创建存储桶avatars。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-zkgc9qzy-1663239309454)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=ZDBlNDAwNTFkMzQ0MDhkY2E3MDI0ZTc4YWQ5N2E5MTBfRHUwTjhKaEFmVVp1ZU95bk9xRkFuMHBmVzBiYU9PVHNfVG9rZW46Ym94Y24xcUVveHF3QXBSamV6N3p2WTdTQXVoXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

  1. 允许每个用户可以查看存储桶avatars

选中存储桶avatars,切换到权限设置栏,点击“新规则”按钮,弹出策略编辑弹框,选择“自定义”,如下图所示:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vvrPZot8-1663239309455)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=YmNkMWE4ODQ1NGIxOTNjM2IwMzJlOGNlOTI1ZjIyY2NfOG0yV05wMHUyNEZaTWNSeXk0N2ZaRGdIME1zeE14c1BfVG9rZW46Ym94Y25nT1poQW1zTVB4MWVtaHhmSXhzRGZmXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

选择SELECT操作,输入策略名称,点击“生成策略”按钮,如下图所示。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Vb50885Z-1663239309455)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=YWY3OTJlNzc4N2FjZmM5ZDQ3YzVmOTNlOWRiMDQ3ODVfRUV5TE91NUw5WnZBUW9wQVZ3MmcyUEUyQjBOTkRDaUpfVG9rZW46Ym94Y253d1d2WjNUeW9rNEcxajFyeFJWS0RoXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

  1. 允许用户上传存储桶avatars;

选中存储桶avatars,切换到权限设置栏,点击“新规则”按钮,弹出策略编辑弹框,选择“自定义”,如下图所示:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-B8dBvD3J-1663239309455)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=Mjc1ZmY4OGMwNTFkOTg3OWZlOWRlNDUyZjNlZWYyMjdfRURjWFRwRzZVNkNVSjNMR3Bva1R2REV2UTFTVHZsTGtfVG9rZW46Ym94Y25TbGs1TnZmUXRyOWZxUmdzOTVoSTNlXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

选择INSERT操作,输入策略名称,点击“生成策略”按钮,如下图所示。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-r7z7BMMQ-1663239309455)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=NWFhMzA4YjIwZmIzNTY3OTVmNzFkN2RhODhmMTBjNzRfSExDQkhNTkl2MUR5YXBpNndhWUhxckZ5aTlQT3U3emNfVG9rZW46Ym94Y25UbHhhV1RMM0FKdVF1UGs5QkNaTWFiXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

查看结果:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-MAmnvLL0-1663239309456)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=NWE3Y2Q2Yjc5ZWQ0NDAyYmFiODZmNmM0ZWM3NzFiNWFfcXN2RFNXbDhzb2JaUGRqMk51ZERrVjZmNXRjcmhOS1lfVG9rZW46Ym94Y25IdHM5TXM5alBFNml6VmxPYXZLMHhkXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

注册小程序

以上是我们在MemFire Cloud上配置的全部步骤,接下来是在微信开发者工具上操作了。

如果您还未注册过小程序,请参考官方步骤注册小程序(只需要通过您的邮箱注册一个小程序获得一个appid,然后下载一个微信开发工具即可)

下载代码

https://github.com/LucaRao/subjectWechat.git

Node.js (>=14.x <=16.x) 。

用微信开发者工具点击导入项目

选择目录是下载好的小程序项目的目录,AppID为您在微信公众平台注册小程序获得的专属appid

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-edcHBDb4-1663239309456)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=MDA1NWFiZDQwNjFhNjQwYjAyNmQ4NTEwMWQ0NzJjNDhfR3laa0FLZ2ZEdmlSTG9kQXNuSGVOd0I3Z1RsUk81d0pfVG9rZW46Ym94Y25rNHhDOFFWSUtySWY2YjZ0NEFWaWlnXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

构建npm

在右侧详情里面的本地设置把“使用npm模块”和“不校验合法域名”勾上

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-stNoP0QP-1663239309456)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=OTA0Njk5NDY4NGIzNjMzZDc4Mzc3YTMyOWRhMDVhMjNfeE9vSll4STJLVFdva0VBZkRaR0NlS3o0RlZWOEhlS3pfVG9rZW46Ym94Y240Z0NFMDdzYU53cVRXdkdyNGNpWWxlXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

打开终端,在项目目录miniprogram下执行如下命令 。

npm init
npm install

接下来,下载小程序需要的Supabase 小程序客户端和ui组件包。

npm install supabase-wechat-stable
npm install @vant/weapp

点击开发者工具中的菜单栏:工具 /构建 npm

![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-zlTNVOPp-1663239309457)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=MDVmN2EyNzdhMGRjOTIzZGI1N2Q5NjY5NmM1ZmE4Y2NfZEJRWHoyT0U0amNxYUxhTzRCRXNGdWJISnl5VEIyVXNfVG9rZW46Ym94Y25hMzJZOVlhNXYwVW12cGs4SWNxOHRXXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]](https://img-blog.csdnimg.cn/398deed11371428d82dfec544c6fde0e.png

这一步npm就构建完成了,我们需要的依赖也已经下载好了,目录miniprogram下会多出两个文件,如下图。

![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GzW0rX0e-1663239309457)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=Mjk4YWQ5Mjc3Y2YyNjJjZjliNWUwNDBmMGQyZjZlZTJfcU5UcU1qSmp6TjZ0akpYNm85VWtsUFRPSDlBbGxYSWxfVG9rZW46Ym94Y25YQWJnTmtORWZWWGROZXJuMWZZaWdjXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]](https://img-blog.csdnimg.cn/655a23ba716d4b96ae63ecfdecb4024c.png

获取 API密钥

我们需要创建一个可以访问应用程序数据的客户端,我们使用了Supabase 微信客户端,使用他生态里提供的功能(登录、注册、增删改查等)去进行交互。创建一个可以访问我们应用程序数据的客户端需要接口的地址(URL)和一个数据权限的令牌(ANON_KEY),我们需要去应用的概览里面去获取这两个参数然后配置到lib/supabase.ts里面去。

lib/supabase.ts

import { createClient } from 'supabase-wechat-stable'
const url = ""
const key = ""

export const supabase = createClient(url, key)

回到MemFire Cloud首页,在应用/概括页面,获取服务地址以及token信息,只需要从总览中获取URL接口地址和anon的密钥。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-I86MVn1W-1663239309457)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=MWI1MmM4M2YyYzY5MTRlNTYxNjE3YzA1ZGE2YjFjZWJfTTFvRGR4RWxoSG16UWJqRWVYdmhDZlliVEpjdWRGdENfVG9rZW46Ym94Y25leGdXeGhiOTg0UGdRdlRoT21abUJkXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

Anon(公开)密钥是客户端API密钥。它允许“匿名访问”您的数据库,直到用户登录。登录后,密钥将切换到用户自己的登录令牌。这将为数据启用行级安全性。

注意:service_role密钥可以绕过任何安全策略完全访问您的数据。这些密钥必须保密,并且要在服务器环境中使用,绝不能在客户端或浏览器上使用。 在后续示例代码中,需要提供supabaseUrl和supabaseKey。

编译小程序

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8XatcY5V-1663239309458)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=OTFjNDJmOTZiYWNlYjFkY2ZlNThjOTQ2OTU2Y2NiMzRfU2E4UnhtNFFsV1NMRXZtcWl1TzlWcFVBWFVNQW02UEFfVG9rZW46Ym94Y25WWUpOcFNYc28xUXJja3pSSllVM3ZoXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

功能1:在没有登录绑定学号时,主页不会出现当日的课程情况,请先点击“绑定学号”去注册登录后才会有该学生今日的课表情况。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Xq7IT5Fl-1663239309458)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=NWQ1NmQ5NTE4NDFiYWM0MmQ0Y2M0OWMyOTQyMTc0ODRfVWJNemlKMXZFb0d4dlNIZWo4STdhcVE5S2JSUTFZQXZfVG9rZW46Ym94Y25La2lCMTV5cm9XV1RiNFVEcTh4dHlkXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

功能2:点击班级课表,输入学校、学院及学号可以查看该学生本周的课程情况

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-odZ9yoCB-1663239309458)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=ZTdiNjk3NWI1MmU4Y2QwMmMzZWMzYzQ1MmU2NzQwMGFfUFdidnoxeUNncFZESERIR0hGRzh4Mzd0Y3p0RmM3QWhfVG9rZW46Ym94Y25xQVc3OUlZdkh2SnlMR2ZvUm5hSVNuXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

功能3:更换头像

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hlb5Q8pg-1663239309459)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=N2JlYWZmYjliYmM5NjZmY2RlMzNkNDgxYTk1MWYyZmNfTE55dTVuYmwyZ1pUQk1yQThuSWEzNmpzaEpodlVmbk9fVG9rZW46Ym94Y25raEhRZnBvQTZuazFMZTU3NHIyWW5mXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

上传头像需要注意: 使用wx.chooseMedia来上传文件

推荐使用方法:

    wx.chooseMedia({
      count: 1,
      sizeType: ["original", "compressed"],
      sourceType: ["album", "camera"],
      async success(res) {
        const file = res.tempFiles[0]
        const fileExt = res.tempFiles[0].tempFilePath.split('.').pop()
        const fileName = `${Math.random()}.${fileExt}`
        const filePath = `${fileName}`
        let { error: uploadError } = await supabase.storage
          .from('avatars')
          .upload(filePath, file)
        if (uploadError) {
          throw uploadError
        }
      },
    });

功能4:清除缓存(会清除当前学生的所有账号及课表信息)

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-bo0rlPWB-1663239309459)(https://g8nb5c2xl3.feishu.cn/space/api/box/stream/download/asynccode/?code=NTczNzA2MmUwMTYwNzc4ZmRiYzJiZjQzOWM1YTU5ZjNfY0hnUjJyN1NubllBZFZpcFF5ZUdxTXpBcURTWVJLWFRfVG9rZW46Ym94Y25Wc0hxYzBPZFdEVEhwdlc5Y1hORDdnXzE2NjMyMzkyOTY6MTY2MzI0Mjg5Nl9WNA)]

以上就是使用微信小程序MemFire Cloud 构建的一个完整课表小程序的具体流程。一起来试试吧~

  • 4
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值