当前位置: 首页 > news >正文

Symfony 表单构建器:创建和管理表单的最佳实践

Symfony 表单构建器:创建和管理表单的最佳实践

Symfony 是一个流行的 PHP 框架,以其强大的功能和灵活性闻名。表单构建器是 Symfony 中一个非常重要的组件,它提供了简单且高效的方式来创建和管理表单。本文将详细介绍 Symfony 表单构建器的最佳实践,包括表单创建、数据处理、表单验证、表单定制化以及表单安全性等方面的内容,并提供详细的代码示例。

一、表单构建器概述

Symfony 的表单构建器提供了一套简洁且强大的 API,用于定义和处理表单。它支持多种表单类型、数据绑定、验证、数据转换和 CSRF 保护等功能。以下是 Symfony 表单构建器的主要特点:

  • 易于使用:通过简洁的 API,可以快速创建表单。
  • 可扩展性强:支持自定义表单类型和数据转换器。
  • 内置验证:与 Symfony 验证组件集成,提供强大的验证功能。
  • 数据绑定:自动处理表单数据的绑定和转换。

二、创建表单

1. 表单类型

在 Symfony 中,表单类型(Form Types)用于定义表单的结构和字段。创建表单类型的步骤如下:

  1. 创建一个表单类型类,继承 AbstractType
  2. 在表单类型类中定义表单字段和配置。
  3. 在控制器中使用表单类型创建表单。

以下是一个示例,演示如何创建一个简单的用户注册表单类型:

// src/Form/RegistrationType.phpnamespace App\Form;use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolver;
use Symfony\Component\Form\Extension\Core\Type\TextType;
use Symfony\Component\Form\Extension\Core\Type\EmailType;
use Symfony\Component\Form\Extension\Core\Type\PasswordType;
use Symfony\Component\Form\Extension\Core\Type\SubmitType;
use App\Entity\User;class RegistrationType extends AbstractType
{public function buildForm(FormBuilderInterface $builder, array $options){$builder->add('username', TextType::class, ['label' => 'Username','attr' => ['placeholder' => 'Enter your username'],])->add('email', EmailType::class, ['label' => 'Email','attr' => ['placeholder' => 'Enter your email'],])->add('password', PasswordType::class, ['label' => 'Password','attr' => ['placeholder' => 'Enter your password'],])->add('submit', SubmitType::class, ['label' => 'Register',]);}public function configureOptions(OptionsResolver $resolver){$resolver->setDefaults(['data_class' => User::class,]);}
}

2. 使用表单类型

在控制器中使用表单类型来创建和处理表单。以下是一个控制器示例:

// src/Controller/RegistrationController.phpnamespace App\Controller;use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
use App\Form\RegistrationType;
use App\Entity\User;class RegistrationController extends AbstractController
{/*** @Route("/register", name="user_register")*/public function register(Request $request): Response{$user = new User();$form = $this->createForm(RegistrationType::class, $user);$form->handleRequest($request);if ($form->isSubmitted() && $form->isValid()) {// 处理表单数据// 通常是保存用户数据到数据库return $this->redirectToRoute('registration_success');}return $this->render('registration/register.html.twig', ['form' => $form->createView(),]);}
}

3. 渲染表单

在 Twig 模板中渲染表单。以下是一个 Twig 模板示例:

{# templates/registration/register.html.twig #}{% extends 'base.html.twig' %}{% block body %}<h1>Register</h1>{{ form_start(form) }}{{ form_widget(form) }}{{ form_end(form) }}
{% endblock %}

三、表单数据处理

1. 数据绑定

Symfony 表单构建器提供了自动的数据绑定功能。当表单提交时,表单的数据会自动绑定到表单对象上。以下是一个示例:

$form->handleRequest($request);if ($form->isSubmitted() && $form->isValid()) {// $user 对象已经包含表单数据// 处理用户数据,例如保存到数据库
}

2. 数据转换

有时候表单字段的数据类型和实体属性的数据类型不同,Symfony 提供了数据转换功能来解决这个问题。例如,将字符串转换为日期对象。以下是一个示例:

// src/Form/RegistrationType.phpuse Symfony\Component\Form\Extension\Core\Type\DateType;$builder->add('birthdate', DateType::class, ['widget' => 'single_text','attr' => ['placeholder' => 'Enter your birthdate'],
]);

四、表单验证

Symfony 表单构建器与验证组件集成,提供了强大的验证功能。验证规则可以在表单类型中定义,也可以在实体类中定义。

1. 在表单类型中定义验证规则

可以使用表单字段的 constraints 选项来定义验证规则。以下是一个示例:

// src/Form/RegistrationType.phpuse Symfony\Component\Validator\Constraints\NotBlank;
use Symfony\Component\Validator\Constraints\Email;
use Symfony\Component\Validator\Constraints\Length;$builder->add('username', TextType::class, ['constraints' => [new NotBlank(['message' => 'Username cannot be blank']),new Length(['min' => 3, 'minMessage' => 'Username must be at least 3 characters long']),],])->add('email', EmailType::class, ['constraints' => [new NotBlank(['message' => 'Email cannot be blank']),new Email(['message' => 'Please enter a valid email address']),],]);

2. 在实体类中定义验证规则

更推荐的做法是在实体类中定义验证规则,这样可以确保数据的一致性。以下是一个示例:

// src/Entity/User.phpuse Symfony\Component\Validator\Constraints as Assert;class User
{/*** @Assert\NotBlank(message="Username cannot be blank")* @Assert\Length(min=3, minMessage="Username must be at least 3 characters long")*/private $username;/*** @Assert\NotBlank(message="Email cannot be blank")* @Assert\Email(message="Please enter a valid email address")*/private $email;/*** @Assert\NotBlank(message="Password cannot be blank")* @Assert\Length(min=6, minMessage="Password must be at least 6 characters long")*/private $password;// getters and setters
}

五、表单定制化

1. 自定义表单类型

除了 Symfony 提供的内置表单类型外,还可以创建自定义表单类型。自定义表单类型通常用于复用表单组件或封装复杂的表单逻辑。以下是一个示例:

// src/Form/Type/CustomTextType.phpnamespace App\Form\Type;use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\Extension\Core\Type\TextType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolver;class CustomTextType extends AbstractType
{public function buildForm(FormBuilderInterface $builder, array $options){$builder->add('custom_text', TextType::class, ['label' => $options['label'],'attr' => $options['attr'],]);}public function configureOptions(OptionsResolver $resolver){$resolver->setDefaults(['label' => 'Custom Text','attr' => ['placeholder' => 'Enter custom text'],]);}public function getParent(){return TextType::class;}
}

使用自定义表单类型:

// src/Form/ExampleType.phpuse App\Form\Type\CustomTextType;$builder->add('custom_field', CustomTextType::class, ['label' => 'Custom Field','attr' => ['placeholder' => 'Enter your custom text'],
]);

2. 自定义表单主题

可以通过自定义表单主题来改变表单的渲染方式。表单主题使用 Twig 模板定义,以下是一个示例:

{# templates/form/fields.html.twig #}{% block custom_text_widget %}<div class="custom-text-field">{{ form_widget(form) }}</div>
{% endblock %}

在 `config/packages

/twig.yaml` 文件中注册自定义表单主题:

twig:form_themes:- 'form/fields.html.twig'

六、表单安全性

1. CSRF 保护

Symfony 表单构建器内置了 CSRF 保护功能,默认情况下,表单会包含一个 CSRF 令牌字段。以下是一个示例:

// 在表单类型中启用 CSRF 保护
$builder->add('_token', CsrfTokenType::class, ['csrf_token_id' => 'form_intention',
]);

在 Twig 模板中渲染 CSRF 令牌字段:

{{ form_row(form._token) }}

2. 验证用户输入

除了使用 Symfony 的验证组件外,还可以通过事件监听器或表单事件来自定义验证逻辑。以下是一个示例:

// src/EventListener/FormValidationListener.phpnamespace App\EventListener;use Symfony\Component\EventDispatcher\EventSubscriberInterface;
use Symfony\Component\Form\FormEvent;
use Symfony\Component\Form\FormEvents;
use Symfony\Component\Validator\Constraints\NotBlank;class FormValidationListener implements EventSubscriberInterface
{public static function getSubscribedEvents(){return [FormEvents::PRE_SUBMIT => 'onPreSubmit',];}public function onPreSubmit(FormEvent $event){$data = $event->getData();$form = $event->getForm();if (empty($data['username'])) {$form->addError(new FormError('Username cannot be blank'));}}
}

在表单类型中注册事件监听器:

// src/Form/RegistrationType.phpuse App\EventListener\FormValidationListener;$builder->addEventSubscriber(new FormValidationListener());

七、表单的国际化

Symfony 提供了强大的国际化(i18n)支持,表单的标签、错误信息等都可以进行本地化。以下是一个示例:

1. 配置翻译

首先,在 config/packages/translation.yaml 文件中配置翻译:

framework:default_locale: '%locale%'translator:default_path: '%kernel.project_dir%/translations'

2. 创建翻译文件

translations 目录下创建翻译文件,例如 messages.en.yamlmessages.fr.yaml,内容如下:

# translations/messages.en.yaml
registration.form.username: 'Username'
registration.form.email: 'Email'
registration.form.password: 'Password'
registration.form.submit: 'Register'
# translations/messages.fr.yaml
registration.form.username: 'Nom d\'utilisateur'
registration.form.email: 'Email'
registration.form.password: 'Mot de passe'
registration.form.submit: 'S\'inscrire'

3. 在表单类型中使用翻译

// src/Form/RegistrationType.php$builder->add('username', TextType::class, ['label' => 'registration.form.username',])->add('email', EmailType::class, ['label' => 'registration.form.email',])->add('password', PasswordType::class, ['label' => 'registration.form.password',])->add('submit', SubmitType::class, ['label' => 'registration.form.submit',]);

4. 渲染翻译内容

在 Twig 模板中,Symfony 会自动翻译表单标签和错误信息:

{# templates/registration/register.html.twig #}{% extends 'base.html.twig' %}{% block body %}<h1>{{ 'registration.form.title'|trans }}</h1>{{ form_start(form) }}{{ form_widget(form) }}{{ form_end(form) }}
{% endblock %}

八、表单的文件上传

文件上传是表单处理中的常见需求。Symfony 提供了方便的文件上传处理机制。

1. 表单类型中添加文件字段

// src/Form/RegistrationType.phpuse Symfony\Component\Form\Extension\Core\Type\FileType;$builder->add('profile_picture', FileType::class, ['label' => 'Profile Picture','mapped' => false, // 因为这个字段不在 User 实体中'required' => false,
]);

2. 在控制器中处理文件上传

// src/Controller/RegistrationController.phpuse Symfony\Component\HttpFoundation\File\Exception\FileException;if ($form->isSubmitted() && $form->isValid()) {// 处理文件上传$file = $form->get('profile_picture')->getData();if ($file) {$originalFilename = pathinfo($file->getClientOriginalName(), PATHINFO_FILENAME);$newFilename = $originalFilename.'-'.uniqid().'.'.$file->guessExtension();try {$file->move($this->getParameter('profile_pictures_directory'),$newFilename);} catch (FileException $e) {// 处理文件上传异常}// 保存文件名到用户实体$user->setProfilePicture($newFilename);}// 保存用户数据到数据库
}

3. 配置文件上传目录

config/services.yaml 文件中配置文件上传目录参数:

parameters:profile_pictures_directory: '%kernel.project_dir%/public/uploads/profile_pictures'

4. 显示上传的文件

在 Twig 模板中显示上传的文件:

{# templates/registration/profile.html.twig #}{% extends 'base.html.twig' %}{% block body %}<h1>Profile</h1><img src="{{ asset('uploads/profile_pictures/' ~ user.profilePicture) }}" alt="Profile Picture">
{% endblock %}

结论

Symfony 表单构建器提供了一套强大且灵活的工具,用于创建和管理表单。本文详细介绍了表单的创建、数据处理、验证、定制化、安全性、国际化和文件上传等方面的最佳实践,并提供了详细的代码示例。

通过遵循这些最佳实践,您可以更高效地构建和管理 Symfony 表单,确保表单的安全性、可维护性和用户体验。希望本文能为您在实际开发中提供有价值的参考。如果您对 Symfony 表单构建器有任何疑问或需求,欢迎随时交流。

相关文章:

Symfony 表单构建器:创建和管理表单的最佳实践

Symfony 表单构建器&#xff1a;创建和管理表单的最佳实践 Symfony 是一个流行的 PHP 框架&#xff0c;以其强大的功能和灵活性闻名。表单构建器是 Symfony 中一个非常重要的组件&#xff0c;它提供了简单且高效的方式来创建和管理表单。本文将详细介绍 Symfony 表单构建器的最…...

Intel电脑CPU的选择

酷睿 i5/i7/i9 系列至强 Xeon 系列应用场景家用消费级电脑企业服务器工作站PCIe通道数 16X 最多识别到2张显卡&#xff0c;且每张降速为8X 64X 最多支持8张显卡同时使用 内存信道2通道8通道内存容量最大128GB最大6TB工作时长不建议长期不间断连续使用专为365*24不断电使用而设…...

MySQL字段设置的varchar长度小于数据长度自动截取丢弃超出的长度而不是报错?

MySQL字段设置的varchar长度小于数据长度自动截取丢弃超出的长度而不是报错&#xff1f; 事情是这样的&#xff0c;我们一个订单表存放了商品的快照信息其中快照信息存储的是json格式商品信息&#xff0c;当查看订单是报错了&#xff0c;发现我们后端服务查询到订单的快照信息…...

Linux|多线程(三)

线程池 线程池是一种多线程处理形式&#xff0c;处理过程中它将被提交的任务分配给预先创建好的多个线程中的一个去执行。 线程池的实现 #pragma once #include <pthread.h> #include <vector> #include <string> #include <unistd.h> #include <…...

智能合约中如何返回mapping

在 Solidity 中&#xff0c;直接返回一个 mapping 的所有数据是不可能的&#xff0c;因为 mapping 本身不支持直接遍历。但是&#xff0c;可以使用一些技巧来实现这一目标&#xff0c;例如通过维护一个额外的数组来跟踪 mapping 中的键&#xff0c;并通过这个数组来返回所有的键…...

nginx的学习(二):负载均衡和动静分离

简介 nginx的负载均衡和动静分离的简单使用 负载均衡配置 外部访问linux的ip地址:80/edu/a.html地址&#xff0c;会轮询访问Tomcat8080和Tomcat8081服务。 Tomcat的准备 准备两个Tomcat&#xff0c;具体准备步骤在nginx的学习一的反向代理例子2中&#xff0c;在Tomcat8080…...

普中51单片机:DS1302时钟芯片讲解与应用(十)

文章目录 引言基本特性什么是RAM&#xff1f;什么是涓流充电&#xff1f; 电路图和引脚说明通信协议以及工作流程寄存器控制寄存器日历/时钟寄存器 DS1302读写时序代码演示——数码管显示时分秒 引言 DS1302 是一款广泛使用的实时时钟 (RTC) 芯片&#xff0c;具有低功耗、内置…...

Preact:轻量级替代React的选择

Preact是一个轻量级的JavaScript库&#xff0c;它提供了与React相似的API&#xff0c;但体积更小&#xff0c;性能更优。Preact的核心理念是尽可能地保持与React的兼容性&#xff0c;同时去除不必要的部分&#xff0c;使其成为一个理想的替代品&#xff0c;尤其是在对性能和包大…...

全栈嵌入式C++、STM32、Modbus、FreeRTOS和MQTT协议:工业物联网(IIoT)可视化系统设计思路(附部分代码解析)

项目概述 随着工业4.0时代的到来&#xff0c;工业物联网&#xff08;IIoT&#xff09;在提高生产效率、降低运营成本和实现智能制造方面得到了广泛应用。本项目旨在开发一个全面的工业物联网监控系统&#xff0c;能够实时监测设备的温度、压力、振动和电流等参数&#xff0c;并…...

Greenplum数据库中的数据倾斜问题及处理方法

一、数据倾斜问题的原因 数据分布不均匀&#xff1a;当数据在表的分区或分片中不均匀分布时&#xff0c;会导致某些分区或分片的数据量较大&#xff0c;从而引发数据倾斜问题。连接键存在热点数据&#xff1a;如果连接操作中使用的键值存在热点数据&#xff0c;即某些键值出现…...

缓存设计理论

缓存设计理论是一个涉及多个方面的复杂主题&#xff0c;主要目标是优化数据访问速度&#xff0c;减少数据访问延迟&#xff0c;提高系统性能&#xff0c;并同时保持数据的一致性和系统的稳定性。以下是从几个关键方面对缓存设计理论的概述&#xff1a; 一、缓存的作用与目的 …...

IDEA-安装插件 驼峰下划线转换

第一步&#xff1a;安装 file-settings-plugins-在marketplace搜索“CamelCase”-点击安装 第二步&#xff1a;设置 file-settings-editor-camel_case 第三步&#xff1a;使用 选中想转换的遍历 使用快捷键 Alt Shift U...

乾坤: 微前端项目切换时样式闪动(从无样式变为正常样式需要等 css chunk 文件加载完成, 加载延时受网速影响)

背景: 点击基座项目页面左侧目录, 进入微前端子项目页面, 会有短暂的样式未加载效果一闪而过, 造成页面闪烁或更严重的其他样式错位问题 定位: 同事查了 qiankun git 项目的 issue: https://github.com/umijs/qiankun/issues/219 , 找到解决方案 解决: 项目 webpack 打包配…...

《电子元器件之固态电容》

固态电容全称是固态铝质电解电容&#xff0c;它与普通液态铝质电解电容的最大差别在于采用了不同的介电材料。液态铝电容介电材料为电解液&#xff0c;而固态电容的介电材料是固态的导电性高分子材料。 固态电容和液态电容&#xff0c;从外观上区分&#xff0c;就是固态电容顶…...

PLC 远程下载网关

一、 产品概述 SSF-BOX-100 是三石峰科技有限公司推出的工业级 PLC 远程下载网关&#xff0c;主 要用于 PLC 远程调试、程序上下载&#xff0c;为用户提供一种简单可靠的远程维护方案。 1.1 SGBOX 软件 SGBOX 软件是 SSF-BOX-100 网关的配套软件&#xff0c;可以查看设备状态…...

【Django】 读取excel文件并在前端以网页形式显示-安装使用Pandas

文章目录 安装pandas写views写urls安装openpyxl重新调试 安装pandas Pandas是一个基于NumPy的Python数据分析库&#xff0c;可以从各种文件格式如CSV、JSON、SQL、Excel等导入数据&#xff0c;并支持多种数据运算操作&#xff0c;如归并、再成形、选择等。 更换pip源 pip co…...

自动控制:带死区的PID控制算法

带死区的PID控制算法 在计算机控制系统中&#xff0c;为了避免控制动作过于频繁&#xff0c;消除因频繁动作所引起的振荡&#xff0c;可采用带死区的PID控制。带死区的PID控制通过引入一个死区&#xff0c;使得在误差较小的范围内不进行控制动作&#xff0c;从而减少控制系统的…...

橙单后端项目下载编译遇到的问题与解决

今天下载orange-admin项目&#xff0c;不过下载下来运行出现一些问题。 1、涉及到XMLStreamException的几个类都出现下面的错误 The package javax.xml.stream is accessible from more than one module: <unnamed>, java.xml ctrl-shift-t 可以找到这个引入是哪些包里…...

EasyExcel 初使用—— Java 实现多种写入 Excel 功能

前言 大家好&#xff0c;我是雪荷。之前有一篇博客&#xff08;EasyExcel 初使用—— Java 实现读取 Excel 功能_java easyexcel.read-CSDN博客&#xff09;介绍了 Java 如何读取 Excel 表格&#xff0c;那么此篇博客就和大家介绍下 Java 如何利用 EasyExcel 写入 Excel。 Ea…...

MySQL 和 SQL Server 中的连表更新 UPDATE JOIN 写法比较

MySQL 和 SQL Server 中的连表更新 UPDATE JOIN 写法比较 一、前言1. MySQL 写法1.1 解释 2. SQL Server 写法2.1 解释 二、总结 一、前言 在关系型数据库管理系统&#xff08;RDBMS&#xff09;中&#xff0c;使用 UPDATE 语句进行表格更新是非常常见的操作。特别是当需要根据…...

手把手教你FL Studio 24.1.1.4234中文破解安装激活图文激活教程

在数字化音乐制作的浪潮中&#xff0c;FL Studio 24.1.1.4234中文破解版的发布无疑又掀起了一股新的热潮。这款由Image-Line公司开发的数字音频工作站&#xff08;DAW&#xff09;软件&#xff0c;以其强大的功能和易用的界面&#xff0c;赢得了全球无数音乐制作人的青睐。本文…...

使用Spring Boot与Spire.Doc实现Word文档的多样化操作

​ 博客主页: 南来_北往 系列专栏&#xff1a;Spring Boot实战 前言 使用Spring Boot与Spire.Doc实现Word文档的多样化操作具有以下优势&#xff1a; 强大的功能组合&#xff1a;Spring Boot提供了快速构建独立和生产级的Spring应用程序的能力&#xff0c;而Spire.Doc则…...

从食堂采购系统源码到成品:打造供应链采购管理平台实战详解

本篇文章&#xff0c;笔者将详细介绍如何从食堂采购系统的源码开始&#xff0c;逐步打造一个完备的供应链采购管理平台&#xff0c;帮助企业实现采购流程的智能化和高效化。 一、需求分析与规划 一般来说&#xff0c;食堂采购系统需要具备以下基本功能&#xff1a; 1.供应商…...

在window将Redis注册为服务

将redis注册为系统服务&#xff0c;开启自启动 安装服务 默认注册完之后会自动启动&#xff0c;在window中的服务看一下&#xff0c;如果启动类型为自动&#xff0c;状态是自动运行则启动完成。如果是手动&#xff0c;需要右键属性调整为自动&#xff0c;在点击启动&#xff0c…...

PHP商城案例

http://www.e9933.com/...

Linux:bash在被调用时会读取哪些启动文件?

(本文基于5.1-6ubuntu1.1版本的bash) bash在被调用时会读取哪些启动文件&#xff1f;要回答这个问题&#xff0c;首先要弄清楚两个概念&#xff1a;login shell和interactive shell。 login shell login shell是指这样的shell&#xff1a; 第一个命令行参数&#xff08;进程…...

帆软FineReport之替换函数

在日常帆软FineReport中经常会使用字符串替换函数&#xff0c;记录下来&#xff0c;方便备查。 一、字符串替换 第一种、指定文本替换 使用SUBSTITUTE函数&#xff0c;语法如下所示 SUBSTITUTE(text&#xff0c;old_text&#xff0c;new_text&#xff0c;instance_num) 字段…...

Redis的应用场景及类型

目录 一、Redis的应用场景 1、限流 2、分布式锁 3、点赞 4、消息队列 二、Redis类型的命令及用法 1、String类型 2、Hash类型 3、List类型 4、Set类型 5、Zset类型 6、Redis工具类 Redis使用缓存的目的就是提升读写性能 实际业务场景下&#xff0c;我们就可以把 Mys…...

【图像处理】不智能的目标识别

目录 目标识别的划分 识别入门 概念学习 滤波 模版 阈值化 形态学操作 开运算 闭运算 编程语言 示例 大家有没有想过在没有人工智能或者说没有机器学习的的时候&#xff0c;计算机是怎么做目标识别的&#xff1f; 计算机视觉时至今日也是急需人才的领域&…...

《500 Lines or Less》(5)异步爬虫

https://aosabook.org/en/500L/a-web-crawler-with-asyncio-coroutines.html ——A. Jesse Jiryu Davis and Guido van Rossum 介绍 网络程序消耗的不是计算资源&#xff0c;而是打开许多缓慢的连接&#xff0c;解决此问题的现代方法是异步IO。 本章介绍一个简单的网络爬虫&a…...

Transformer!自注意力机制的高层级理解Attention Is All You Need!

背景 最近在不断深入学习LLM的相关内容&#xff0c;那么transformer就是一个绕不开的话题。然而对于一个NLP门外汉来说&#xff0c;论文看得是真头疼&#xff0c;总览全网&#xff0c;我们似乎缺少一个至高而下的高层级理解。所以本文就来弥补此方面的缺失~ 本文并不讲解有关…...

关于使用Postman在请求https网址没有响应,但是用浏览器有响应的问题解决

一、问题描述 使用postman调用正式环境的公共接口&#xff0c;无需鉴权&#xff0c;但是产生了返回状态码200&#xff0c;但是data中却无数据&#xff0c;如下 {"code": "200","message": "操作成功","data": {"qr_c…...

【React 】开发环境搭建详细指南

文章目录 一、准备工作1. 安装 Node.js 和 npm2. 选择代码编辑器 二、创建 React 项目1. 使用 Create React App2. 手动配置 React 项目 三、集成开发工具1. ESLint 和 Prettier2. 使用 Git 进行版本控制 在现代前端开发中&#xff0c;React 是一个非常流行的框架&#xff0c;用…...

结构体笔记

结构体 C语言中的数据类型&#xff1a; 基本数据类型&#xff1a;char/int/short/double/float/long 构造数据类型&#xff1a;数组&#xff0c;指针&#xff0c;结构体&#xff0c;共用体&#xff0c;枚举 概念&#xff1a; 结构体是用户自定义的一种数据类型&#xff0c…...

Elasticsearch:Golang ECS 日志记录 - zerolog

ECS 记录器是你最喜欢的日志库的格式化程序/编码器插件。它们可让你轻松地将日志格式化为与 ECS 兼容的 JSON。在本教程中&#xff0c;我将详述如何 编码器以 JSON 格式记录日志&#xff0c;并以 ECS 错误格式处理错误字段的记录。 默认情况下&#xff0c;会添加以下字段&…...

Ip2region - 基于xdb离线库的Java IP查询工具提供给脚本调用

文章目录 Pre效果实现git clone编译测试程序将ip2region.xdb放到指定目录使用改进最终效果 Pre OpenSource - Ip2region 离线IP地址定位库和IP定位数据管理框架 Ip2region - xdb java 查询客户端实现 效果 最终效果 实现 git clone git clone https://github.com/lionsou…...

研发管理革命:探索顶尖的工时系统选择

国内外主流的10款研发工时管理系统对比&#xff1a;PingCode、Worktile、无鱼项目工时系统、Toggl Track、泽众ALM、Asana、Jira、GitHub、Trello、TrackingTime。 在研发团队中&#xff0c;工时管理常常成为效率瓶颈&#xff0c;尤其是在资源分配和项目进度跟踪方面。选择合适…...

微服务-MybatisPlus下

微服务-MybatisPlus下 文章目录 微服务-MybatisPlus下1 MybatisPlus扩展功能1.1 代码生成1.2 静态工具1.3 逻辑删除1.4 枚举处理器1.5 JSON处理器**1.5.1.定义实体****1.5.2.使用类型处理器** **1.6 配置加密&#xff08;选学&#xff09;**1.6.1.生成秘钥**1.6.2.修改配置****…...

【python_将一个列表中的几个字典改成二维列表,并删除不需要的列】

def 将一个列表中的几个字典改成二维列表(original_list,headersToRemove_list):# 初始化一个列表用于存储遇到的键&#xff0c;保持顺序ordered_keys []# 遍历data中的每个字典&#xff0c;添加其键到ordered_keys&#xff0c;如果该键还未被添加for d in original_list:for …...

IDEA的pom.xml显示ignored 的解决办法

问题&#xff1a; idea中创建Maven module时&#xff0c;pom.xml出现ignored。 原因&#xff1a; 相同名称的module在之前被创建删除过&#xff0c;IDEA会误以为新的同名文件是之前删除掉的&#xff0c;将这个新的module的pom.xml文件忽略掉显示ignored. 解决&#xff1a; 在…...

2. 卷积神经网络无法绕开的神——LeNet

卷积神经网络无法绕开的大神——LeNet 1. 基本架构2. LeNet 53. LeNet 5 代码 1. 基本架构 特征抽取模块可学习的分类器模块 2. LeNet 5 LeNet 5: 5 表示的是5个核心层&#xff0c;2个卷积层&#xff0c;3个全连接层.核心权重层&#xff1a;卷积层、全连接层、循环层&#xff…...

【区块链】JavaScript连接web3钱包,实现测试网络中的 Sepolia ETH余额查询、转账功能

审核看清楚了 &#xff01; 这是以太坊测试网络&#xff01;用于学习的测试网络&#xff01;&#xff01;&#xff01; 有关web3 和区块链的内容为什么要给我审核不通过&#xff1f; 别人凭什么可以发&#xff01; 目标成果&#xff1a; 实现功能分析&#xff1a; 显示账户信…...

关于珞石机器人二次开发SDK的posture函数的算法RX RY RZ纠正 C#

在珞石SDK二次开发的函数钟&#xff0c;获取当前机器人位姿的函数posture函数在输出时会发现数据不正确&#xff0c;与示教器数据不一致。 其中第一个数据正确 第二三各数据为相反 第四五六各数据为弧度制 转换方法为(弧度/PI)*180度 然后发现第四个数据还要加上180度 第五…...

【Three.js基础学习】17.imported-models

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 前言 课程回顾&#xff1a; 如何在three.js 中引入不同的模型&#xff1f; 1. 格式 &#xff08;不同的格式&#xff09; https://en.wikipedia.org/wiki/List_of_file_form…...

Spring Bean - xml 配置文件创建对象

类型&#xff1a; 1、值类型 2、null &#xff08;标签&#xff09; 3、特殊符号 &#xff08;< -> < &#xff09; 4、CDATA <?xml version"1.0" encoding"UTF-8"?> <beans xmlns"http://www.springframework.org/schema/bea…...

uniapp map组件自定义markers标记点

需求是根据后端返回数据在地图上显示标记点&#xff0c;并且根据数据状态控制标记点颜色&#xff0c;标记点背景通过两张图片实现控制 <mapstyle"width: 100vw; height: 100vh;":markers"markers":longitude"locaInfo.longitude":latitude&…...

Windows:批处理脚本学习

目录 一、第一个批处理文件 1. &&和 | | 2. | 和 & 二、变量 1.传参变量%name 2.初始化变量set命令 3.变量的使用 4.局部变量与全局变量 5.使用环境变量 6.扩充变量语法 三、注释REM和 &#xff1a;&#xff1a; 四&#xff1a;函数 1.定义函数 2.…...

Dav_笔记10:Using SQL Plan Management之4

SQL管理库 SQL管理库(SMB)是驻留在SYSAUX表空间中的数据字典的一部分。它存储语句日志,计划历史记录,SQL计划基准和SQL配置文件。为了允许每周清除未使用的计划和日志,SMB使用自动空间管理。 您还可以手动将计划添加到SMB以获取一组SQL语句。从Oracle Database 11g之前的…...

通过json传递请求参数,如何处理动态参数和接口依赖

嗨&#xff0c;大家好&#xff0c;我是兰若姐姐&#xff0c;今天给大家讲一下如何通过json传递请求参数&#xff0c;如何处理动态参数和接口依赖 1. 使用配置文件和模板 在 test_data.json 中&#xff0c;你可以使用一些占位符或模板变量&#xff0c;然后在运行测试之前&…...

[240727] Qt Creator 14 发布 | AMD 推迟 Ryzen 9000芯片发布

目录 Qt Creator 14 发布Qt Creator 14 版本发布&#xff0c;带来一系列新功能和改进终端用户可通过命令行方式查看此新闻终端用户可通过命令行方式安装软件&#xff1a; AMD 推迟 Ryzen 9000芯片发布 Qt Creator 14 发布 Qt Creator 14 版本发布&#xff0c;带来一系列新功能…...