StrApi基本使用

1.创建项目(这里只使用默认的sqllite)

点击链接进入官网查看先决条件,看看自己的node,python等是否符合版本要求

运行以下命令进行创建项目(网慢导致下载失败的话可以尝试使用手机热点给电脑使用,我就是这样解决的,也可以看我csdn的资源这里进行下载)

yarn create strapi-app my-project --quickstart
// 或者使用下面的
npx create-strapi-app@latest my-project --quickstart

安装完成后稍等一会会自动启动项目,如果是使用的我的压缩包的话解压后在项目里面使用yarn run develop或者npm run develop进行运行

2.创建管理员账户

项目运行后会生成一个地址,到浏览器打开地址是一个管理员登录界面,初次进入项目相当于注册账号了,因此第一次进入项目切记账号密码不要忘记,使用可视化工具打开.tmp/data.db会发现本质上是在admin_users表里面新增了一条管理员数据,但是邮箱和密码是被加密了

3.将项目改成中文界面

  • 找到src/admin/app.example.js(用于参考的配置文件)
  • ctrl+c/ctrl+v复制一模一样的一份到同级目录下
  • 将新复制的改名app.js
  • 将app.js里面的第二十七行的zh-Hans注释放开
  • 重启项目
  • 根据生成的管理界面的链接再次打开界面
  • 登录后点击左下角的头像部分
  • 点击Profile
  • 最下面一行第一个选择框是选择语言的,这时候会发现多了个中文选择
  • 勾选即可(原来是没有中文选择的,默认英文)
  • 点击右上角的save即可

4.创建数据表,添加字段

4.1数据表创建

Strapi提供了两种内容类型

  • Collection Types:数据集合
  • Single Types:单个数据

这里根据实际需求创建对应的数据表即可

注意:最下面的一栏的组件是字段的组合,可以用它来创建可重用的字段集

4.2字段创建

根据实际需求的数据,选择对应的类型,并添加字段

注意:

  1. 数据默认会添加ID作为标记
  2. 数据默认会添加创建日期字段(因此这部 分可以不用自行创建)

创建单个数据表步骤:

  • 点击左侧的Content-Type Builder
  • 点击Create new single type
  • 在弹出的框设置下显示名称(右边两个框会自动生成,这里不用管)
  • 可以看下高级设置,根据自己需求选择,这里默认勾选了草稿,这里不需要,就先去掉了,本地化也不需要
  • 点击继续(这时候已经创建好了单个数据表,后面是给这张表添加字段了)
  • 例如新增个文本类型字段,点击文本,输入字段名,选择是较短类型文字还是较长类型文字
  • 点击高级设置,将字段的限制更为严谨点(这里我只勾选了必须的和唯一的)
  • 点击添加另一个字段或者点击完成后,在界面上找到添加一个新字段都是新增字段
  • 直到符合需求的字段都写好后,点击完成即可

这里说一下媒体类型

  • 选择类型为媒体文件
  • 写完名称后面可以选择单一或者是多个媒体(像头像之类的直接选择单一头像)
  • 点击高级设置,选择类型,图片类型的只限制图片即可,也就是选择第一个
  • 点击完成

这样就新建好了一个test表,里面有三个字段了

在这里插入图片描述

点击保存才会真正保存起来,各位不要忘了点击右上角的保存按钮

点击了保存之后,会重启项目,稍微等待重启即可

创建多个数据表步骤

  • 点击左侧的Content-Type Builder
  • 点击->创建一个新的 Content Type
  • 跟刚刚一样,填写表名,点击高级设置,草稿取消,点击继续
  • 然后就是添加字段了,跟刚刚一样(这里就不重复了)

删除表步骤

  • 点击左侧的Content-Type Builder
  • 点击某个表进到页面
  • 点击表名旁边的编辑
  • 点击删除即可(然后等服务器重启)

手动添加数据

  • 点击左侧的内容管理器
  • 点击某一需要修改数据的表
  • 修改即可

5.添加媒体库(相当于一个仓库,可以存一堆媒体文件,并且可以留着使用)

  • 点击媒体库
  • 点击新建文件夹(也可以直接上传,个人建议新建文件夹分类管理)
  • 点击上传即可(这里支持本地上传和URL链接上传)
  • 手动新增数据为媒体文件数据时就可以选择媒体库里面的文件了

6.开放接口

默认接口没开,需要开放接口才可以访问接口

默认提供REST API风格的接口

开放接口步骤如下:

  • 找到左侧设置点一下
  • 点击用户及权限插件下面的角色
  • 找到public(公共的)
  • 点击编辑
  • 下面权限名称和我们表名称相同的就是对应的表权限了
  • 点击旁边的箭头展开(这时就可以看到对应的接口类型了)
  • 例如这里先开放查询接口,点击find,右侧菜单就会同步出现一个接口路由啦
  • 点击右上角保存(注意看管理系统端口开放的是1337端口)
  • 打开ApiFox调用get请求,地址为(http://localhost:1337/api/test)

在这里插入图片描述

在这里插入图片描述

populate参数

通过上面接口 可以发现媒体文件没有被查询出来,这是由于Strapi由于为了性能考虑,默认不会将媒体文件查询出来

默认情况下,查询结果不填充任何关系、媒体字段、组件或动态区域通过 population 查询参数为查询填充各种字段

核心用法:

  1. populate=*填充所有
  2. populate[0]=字段名1&populate[1]=字段名2 :按需填充字段

使用 populate 参数获取上一步没有查询到的媒体字段

使用方式如下

  • 在ApiFox中get请求地址如下:http://localhost:1337/api/test?populate[0]=icon
  • 在ApiFox中get请求地址如下:http://localhost:1337/api/test?populate=*

有多个媒体参数情况下

  • 在ApiFox中get请求地址如下:http://localhost:1337/api/test?populate[0]=icon&populate[1]=icon2

然后就会发现媒体文件也能查询出来了

创建分类表并设置数据

创建分类的集合数据表

  • 点击左侧的Content-Type Builder

  • 点击->创建一个新的 Content Type

  • 设置显示名称为tag(因为是集合类型,生成接口会自动拼成tags)

  • 点击高级设置,取消草稿模式,点击继续

  • 选择文本字段,起名为title,较短的文字

  • 点击高级设置,选择必须的,唯一的

  • 点击完成并点击右上角保存

  • 点击内容管理器,选择刚刚创建的tag类型

  • 点击右侧创建新条目

  • 创建新条目,输入名字后点击保存,然后点击发布,再次点击集合页面就会发现已经添加了

  • 我这里重复创建四次代表四个分类(美食,运动,萌宠,美景)

  • 找到左侧设置点一下

  • 点击用户及权限插件下面的角色

  • 找到public(公共的)

  • 点击编辑

  • 下面权限名称和我们表名称相同的就是对应的表权限了

  • 点击旁边的箭头展开(这时就可以看到对应的接口类型了)

这里也就是集合类型和单张表的区别啦,可以看到接口类型和单张表相比会多出几个

在这里插入图片描述

  • 这里我选择find和findOne,然后右边自动生成接口路由
  • 点击保存
  • 去apifox查询接口
  • 执行find接口链接:http://localhost:1337/api/tags

在这里插入图片描述

  • 执行findOne接口链接:http://localhost:1337/api/tags/1

在这里插入图片描述

创建对应的分类的下面的文章表

  • 创建方式跟上面一样
  • 名称选择article
  • 字段名为title(文章标题,text类型,较短文字,必须的,唯一的)
  • cover(封面,媒体类型,图片类型)
  • content(内容,富文本类型)
  • 创建完之后点击保存
  • 跟之前一样去设置这个集合的数据以及开放接口

设置分类表和文章表之间的关系

建立关系字段

关系字段:
关系字段允许与另一个内容类型建立关系,该内容类型必须是集合类型

有6种不同类型的关系
1.单程:内容类型A有一个内容类型B
2.一对一:内容类型A具有并属于一个内容类型B
3.一对多:内容类型A属于多个内容类型B
4.多对一:内容类型B有许多内容类型A
5.多对多:内容类型A具有并属于许多内容类型B
6.多种方式:内容类型A有许多内容类型B

建立关系

  • 点击左侧的content-type-builder
  • 找到tag分类表,点击右上角添加一个新字段
  • 找到引用类型,设置和文章表的关系(这里会有六个图标,分别对应上面介绍的六种类型的关系)
  • 在右侧下拉框选择article(文章表),设置关联的字段名tag
  • 选择第三个图标,也就是一对多的关系
  • 右上角点击保存
  • 点击左侧内容管理器
  • 找到文章表随便点击一个编辑,会发现增加了一个tag标签,下拉就可以看到分类的名称
  • 选择对应的分类
  • 点击保存发布

接口测试

建立了关系之后,就可以在查询的时候通过populate字段查询出建立关系的数据

1.基于文章查询所属分类

  • 使用路径参数id查询出对应的分类(这时候会发现没查出来,出于性能考虑,携带下下面参数才能真正查询出来)
    • 使用查询参数populate[0]=tag查询分类 http://localhost:1337/api/articles/1?populate[0]=tag
  • 使用查询参数populate[1]=cover查询封面 http://localhost:1337/api/articles/1?populate[1]=cover
  • 使用populate=*一并查询 http://localhost:1337/api/articles/1?populate= *

2.基于分类查询出对应文章

  • 使用路径参数id查询出对应的分类

  • 使用populate填充2个字段形式populate[0]=articles查询出文章 http://localhost:1337/api/articles/1?populate[0]=articles

  • 执行完上面第二步以后会发现,关联的文章能查到,但是封面没了(还是出于性能考虑,Strapi默认不会查询多级,可以按照第四步将封面查询出来)

  • http://localhost:1337/api/tags/1?populate[articles][populate][0]=cover
    // 上面这个链接参数意思就是告诉Strapi要查询articles下面的参数[populate][0]代表要查询1个参数,值cover就代表要查询的就是cover这个字段
    

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/19941.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

5.25.1 用于组织病理学图像分类的深度注意力特征学习

提出了一种基于深度学习的组织病理学图像分类新方法。我们的方法建立在标准卷积神经网络 (CNN) 的基础上,并结合了两个独立的注意力模块,以实现更有效的特征学习。 具体而言,注意力模块沿不同维度推断注意力图,这有助于将 CNN 聚焦于关键图像区域,并突出显示判别性特征通…

基于Python的校园预约打印网站的实现

基于Python的校园预约打印网站的实现 开发语言:Python 数据库:MySQL所用到的知识:Django框架工具:pycharm、Navicat、Maven 系统功能实现 注册 新用户首先要进行注册信息填写,填写完成以后进行登录即可使用此网站 打印社 分别有…

同元软控受邀出席2024工业软件创新发展学术会议

5月24日至26日,以“工业软件与新质生产力”为主题的2024工业软件创新发展学术会议在武汉顺利召开。会议由《软件导刊》编辑部主办,复杂关键软件环境全国重点实验室、武汉人工智能研究院、武汉轻工大学电气与电子工程学院承办,百度公司等单位协…

RandLA-Net 训练自定义数据集

https://arxiv.org/abs/1911.11236 搭建训练环境 git clone https://github.com/QingyongHu/RandLA-Net.git搭建 python 环境 , 这里我用的 3.9conda create -n randlanet python3.9 source activate randlanet pip install tensorflow2.15.0 -i https://pypi.tuna.tsinghua.e…

数据结构与算法 :数据结构绪论,时间和空间复杂度 推导大O阶

各位少年 大家好 我是博主那一脸阳光,今天开始给大家分享数据结构,由于我个人当初学的时候是自学,并没有看培训机构的视频 所以接下来我分享的数据结构的内容,源头来自一本书叫做大话数据结构。顺便一提为了方面大家理解&#xff…

unicloud 云对象

背景和优势 20年前,restful接口开发开始流行,服务器编写接口,客户端调用接口,传输json。 现在,替代restful的新模式来了。 云对象,服务器编写API,客户端调用API,不再开发传输json…

二叉树—堆(C语言实现)

一、树的概念及结构 1.树的概念 树是一种非线性的数据结构,它是有n(n > 0)个有限结点组成一个具有层次关系的集合。把它叫做树是因为它看起来像一颗倒挂的树,也就是说它是根朝上,而叶朝下。 ● 有一个特殊的结点…

结构设计模式 - 代理设计模式 - JAVA

代理设计模式 一. 介绍二. 代码示例2.1 定义 CommandExecutor 类2.2 定义 CommandExecutorProxy代理类2.3 模拟客户端2.4 测试结果 三. 结论 前言 这是我在这个网站整理的笔记,有错误的地方请指出,关注我,接下来还会持续更新。 作者:神的孩子…

虚幻引擎5 Gameplay框架(四)

Gameplay重要类及重要功能使用方法(三) 虚幻的委托机制 虚幻委托之间的区别序列化就是是否可以在蓝图中执行 多播与单播的创建 制作功能:使用多播与单播将血条与血量进行实时更新首先新建一个单播与一个多播委托 实例化这两个委托的标签…

神经网络---卷积神经网络CNN

一、从前馈神经网络到CNN 前馈神经网络(Feedforward Neural Networks)是最基础的神经网络模型,也被称为多层感知机(MLP)。 它由多个神经元组成,每个神经元与前一层的所有神经元相连,形成一个“…

Ubuntu24.04 LTS安装中文输入法

前言 最近,windows玩没了,一怒之下决定换一个操作系统,当然就是最新的Ubuntu24.04 LTS.,其中魔法和咒语(汉语)是inux遇到的第一大难关,我权限不够教不了魔法,但我可以教你咒语(๑•…

大模型之路,从菜鸟到模型大师只需要一步

前言: 在这个数据爆炸的时代,大模型技术正以前所未有的速度发展。从自然语言处理到计算机视觉,从智能推荐到自动驾驶,大模型正逐渐渗透到我们生活的方方面面。那么,如何从菜鸟成长为模型大师呢?本文将为你…

1.8k Star!RAGApp:在任何企业中使用 Agentic RAG 的最简单方法!

原文链接:(更好排版、视频播放、社群交流、最新AI开源项目、AI工具分享都在这个公众号!) 1.8k Star!RAGApp:在任何企业中使用 Agentic RAG 的最简单方法! 🌟在任何企业中使用 Agent…

9.Halcon3D点云力矩求解-平面拟合用法

1.实现效果 我们在使用3d相机对产品进行扫描生成点云的时候,由于安装问题,所以我们不可能保证每次产品扫描出来都在坐标系中位置和姿态非常标准。 上述算法描述的就是在某一个维度或者某几个维度上将点云数据和坐标系对齐; 至于怎么对齐,如何实现就是今天的内容。 本人能…

如何评价GPT-4o?GPT-4o和ChatGPT4.0的区别是啥呢?

如何评价GPT-4o? GPT-4o代表了人工智能领域的一个重要里程碑,它不仅继承了GPT-4的强大智能,还在多模态交互方面取得了显著进步。以下是几个方面的分析: 技术特点 多模态交互能力:GPT-4o支持文本、音频和图像的任意组合输入与输出…

vue3组件通信与props

title: vue3组件通信与props date: 2024/5/31 下午9:00:57 updated: 2024/5/31 下午9:00:57 categories: 前端开发 tags: Vue3组件Props详解生命周期数据通信模板语法Composition API单向数据流 Vue 3 组件基础 在 Vue 3 中,组件是构建用户界面的基本单位&#…

判断自守数-第13届蓝桥杯选拔赛Python真题精选

[导读]:超平老师的Scratch蓝桥杯真题解读系列在推出之后,受到了广大老师和家长的好评,非常感谢各位的认可和厚爱。作为回馈,超平老师计划推出《Python蓝桥杯真题解析100讲》,这是解读系列的第75讲。 判断自守数&#…

蓝桥杯高频考点-与日期相关的题目

文章目录 前言1. 如何枚举合法日期1.1 预存每个月的天数1.2 封装一个判断日期是否合法的函数1.3 枚举日期并判断日期是否合法 2. 判断日期是否为回文日期2.1 将日期当作字符串进行处理2.2 将日期当作一个8位数进行处理 3. 给定初始日期,计算经过n天后对应的日期3.1 …

职场中,那些35岁以上的测试猿到底去哪了?

🔥 交流讨论:欢迎加入我们一起学习! 🔥 资源分享:耗时200小时精选的「软件测试」资料包 🔥 教程推荐:火遍全网的《软件测试》教程 📢欢迎点赞 👍 收藏 ⭐留言 &#x1…

使用KEPServer连接欧姆龙PLC获取对应标签数据(标签值类型改为字符串型)

1.创建通道(通道),(选择对应的驱动,跟当前型号PLC型号对应)。 2.创建设备,(填入IP地址以及欧姆龙的默认端口号:44818) 3.创建对应的标签。这里关键讲诉下字…