yii、laravel框架都是基于symfony组件衍生,symfony的强大不用多说。文档里有的,很好找的就不写了

附:

  1. symfony官网  https://symfony.com/doc/3.4
  2. yml语法(秒懂的那种)https://www.jianshu.com/p/a8252bf2a63d
  3. twig语法  https://www.kancloud.cn/yunye/twig-cn/159454

--------------------------

学习笔记(v 3.4.22 附symfony5.0笔记) :

# 展示所有命令
php bin/console

1、bundle

1>创建

  php bin/console generate:bundle --namespace=BundleNamespace\YourBundle

2>注册

// app/AppKernel.php
public function registerBundles()
{
$bundles = [
//…,
new BundleNamespace\YourBundle(),
]; if (in_array($this->getEnvironment(), ['dev', 'test'])) {
$bundles[] = new Symfony\Bundle\WebProfilerBundle\WebProfilerBundle();
$bundles[] = new Sensio\Bundle\DistributionBundle\SensioDistributionBundle();
$bundles[] = new Sensio\Bundle\GeneratorBundle\SensioGeneratorBundle();
} return $bundles;
}

2、服务

一旦你启动一个Symfony应用程序,你的容器已经包含许多服务。这些就像工具*等待你利用它们。

可以通过如下命令查看全部服务:

  php bin/console debug:container

1>注册服务

  1. 在需要的Bundle下新建服务文件夹(service)
  2. 在新建的文件夹(service)下,建立class(名字根据业务逻辑来,symfony会自动注册/src下的类)
  3. 也可以在/config/service.yml手动注册
#   /config/service.yml

services:
# ... # this is the service's id
App\Service\SiteUpdateManager:
public: true

附.官网文档 》

2>调用服务

//方式1、在controller中 $this->container->get('服务的id')
$doctrine = $this->container->get('doctrine'); //方式2、在controller中 $service = $this->get(服务的类名::class);
//!!!此方式必须先use,即:use youerNamespace\yourServiceClass;
$service = $this->get(yourServiceClass::class); //方式3、从服务容器获取服务
$doctrine = $this->getContainer()->get('doctrine'); //方式4、依赖注入方式获取服务
use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
use Symfony\Component\DependencyInjection\ContainerInterface;
class RunActionListenter
{
protected $em;
protected $tokenStorage;
public function __construct(TokenStorageInterface $tokenStorage,ContainerInterface $container){
$this->tokenStorage = $tokenStorage;
$this->em = $container->get('doctrine')->getManager();
}
}

3、数据库

1>常用命令:

#)、通过数据库生成实体类
php bin/console doctrine:mapping:import --force AppBundle annotation
//AppBundle:bundle名
//annotation:实体类格式 xml,yml, annotation #)、通过交互式的问题生成实体类
php bin/console doctrine:generate:entity #)、验证映射:
php bin/console doctrine:schema:validate #)、生成geter、seter
php bin/console doctrine:generate:entities AppBundle/Entity --no-backup #)、根据实体类更新数据库
php bin/console doctrine:schema:update --force

注意:每次更新完实体(entity)后要运行上面的update命令,否则对实体的更改不能同步到数据库,查询时会报错!

2>连接多数据库:

Symfony2 多数据库连接 - d&lufd - 博客园

3>一些概念:

// 一对多:当前表(entity)的一条记录和目标表(targetEntity值指向的那个表)的多条记录对应;

//Disasters.php

/**
* @ORM\OneToMany(targetEntity="Chatmessages", mappedBy="disasterid", cascade={"persist", "remove"})
*
*/
protected $chatmessages;

// 多对一:当前表(entity)多条记录和目标表(targetEntity值指向的那个表)的一条记录对应;

//Chatmessages.php

/**
* @ORM\ManyToOne(targetEntity="App\Entity\Role", inversedBy="users")
* @ORM\JoinColumn(name="roles", referencedColumnName="id")
* :
* targetEntity 目标实体类
* inversedBy/mappedBy 要映射到的目标类里的那个属性
* (inversedBy一般和Joincolumns并存,处于name外键所在的类;mappedBy为要映射到的类)
* name 当前表中外键的名字
* referencedColumnName 参考属性
*/
private $roles;

其他的一对一,多对多概念和上面类似,相信不用再多写废话了···

4>操作数据库:

1、常用操作方式

  1. Repository
  2. dql
  3. queryBuilder

  4. executeQuery 执行原生sql


# 使用Repository查询
// find($id) 通过id查询记录
// findBy(array('id' => $id)) 查询满足条件的条记录
// findOneBy(array('id' => $id)) 查询满足条件的一条记录
!!!注意,条件数组里的key(比如这里的id)不是数据库里的表字段,必须是entity里存在的属性。
// eg
$this->em->getRepository('App\Entity\ResourceType')->find($id);
$this->em->getRepository(ResourceType::class)->find($id);
$this->em->getRepository(ResourceType::class)->findBy(array('id' => $id)); # 使用DQL查询
$query = $em->createQuery('SELECT s FROM AppBundle\Entity\Signin s
WHERE s.userid = :uId
AND s.signintime BETWEEN :date AND :endDate');
$query->setParameters(array(
'uId' => $u->getId(),
'date' => date('Y',time()).'-01-01',
'endDate' => date('Y-m-d',time())
)); #$query->setMaxResults(10); 取10条记录
$res = $query->getResult(); # 使用executeQuery
$query = $this->em->getConnection()->prepare("SELECT * FROM project WHERE `open`=1 ORDER BY RAND() LIMIT 1");
$res = $query->executeQuery()->fetchAllAssociative();

4、文件系统

1>获取上传的文件

  • $request->files->all();获取上传的文件。

2>文件操作

  • Symfony\Component\Filesystem\Filesystem;  new这个类即可使用syfmony文件系统。

5、http

1>从Request获取请求的所有数据

适用于GET POST PUT DELETE等所有常用方式,

public function getParams($request){
$query = $request->query->all(); # get
$request = $request->request->all(); # post和其他
$data = json_decode($request->getContent(), true); # json return array_merge($query,$params);
} // 接收文件
$files = $request->files->all(); # 文件

参考自:Symfony\Component\HttpFoundation\Request.php

2>http响应/Response

# 返回一个http状态码
return new Response('parameter error', 400); # 返回json
$this->json([]);
$this->json($entiyObj); # 返回file
return $this->file(new File('path/to/file'));

6、获取配置的参数值

# 在控制器里 可以直接调用getParameter获取参数
$this->getParameter('参数名'); # 在其他服务里 use Symfony\Component\DependencyInjection\ContainerInterface; class SceneSplit
{
protected $container; // 先注入服务容器
public function __construct(ContainerInterface $container)
{
$this->container = $container;
} public function split($file)
{
// 调用getParameter获取参数
$url = $this->container->getParameter('参数名');
}
}

--------------------------

未完待续……

最后更新于:2022-3-22

symfony学习笔记3.4(bundle、service、doctrine的使用…)的更多相关文章

  1. symfony学习笔记2—纯的PHP代码和symfony的区别

    Symfony vs 纯PHP为啥symfony比普通的php文件访问要好?这一章我们写一个简单的php文件项目,然后组织它,你会发现为什么web应用会发展到现在这个样子.最后我们将学习symfony ...

  2. symfony学习笔记1—简介

    1.symfony快速入门还是先看代码结构把,这个是拿到代码的第一印象,app/:整个应用的配置,模版,translations,这个可能是多语言文件什么,src/:项目php文件,vendor/:第 ...

  3. android菜鸟学习笔记28----Android中的Service生命周期及本地和远程服务绑定的实现

    Service是Android中长期在后台运行的没有界面的组件,使用服务的优势在于:能够提高进程的优先级,系统不容易回收掉进程,即便回收了,内存充足的时候,会把进程重新创建. 1.服务的简单使用示例: ...

  4. Android(java)学习笔记146:Bundle和Intent类使用和交互

            Bundle只是一个信息的载体 将内部的内容以键值对组织 ,Intent负责Activity之间的交互自己是带有一个Bundle的.Intent.putExtras(Bundle bu ...

  5. Android(java)学习笔记181:利用Service在后台播放背景音乐

    1.在android应用程序里,有一种没有UI的类(android.app.Service)——Service.简单来说,Service是一个 background process(背景程序),通过背 ...

  6. 【ASP.NET MVC 学习笔记】- 18 Bundle(捆绑)

    本文参考:http://www.cnblogs.com/willick/p/3438272.html 1.捆绑(Bundle),一个在 View 和 Layout 中用于组织优化浏览器请求的 CSS ...

  7. k8s学习笔记之九: Service Account

    第一章.前言 每一个用户对API资源进行操作都需要通经过以下三个步骤: 第一步:对客户端访问进行认证操作,确认是否具有访问k8s权限 token(共享秘钥) SSL(双向SSL认证) ....通过任何 ...

  8. Sharepoint2013商务智能学习笔记之Secure Store Service服务配置(二)

    Secure Store Service 是运行在应用程序服务器上的授权服务,它提供一个存储用户凭据的数据库,Secure Store Service 在商务智能中的地位很重要,Sharepoint商 ...

  9. Android(java)学习笔记89:Bundle和Intent类使用和交互

    1. Bundle 和 Intent:    Bundle只是一个信息的载体 将内部的内容以键值对组织 ,Intent负责Activity之间的交互自己是带有一个Bundle的.Intent.putE ...

  10. Android(java)学习笔记124:利用Service在后台播放背景音乐

    1. 在android应用程序里,有一种没有UI的类(android.app.Service)——Service.简单来说,Service是一个 background process(背景程序),通过 ...

随机推荐

  1. C# Dev GridView当前行

    DEV获取GridControl当前行 //直接通过gridView获取当前行 dr=this.gridView1.GetDataRow(this.gridView1.FocusedRowHandle ...

  2. 2025年这些实用的C#/.NET知识点你都知道吗?

    前言 在这个快速发展的技术世界中,时常会有一些重要的知识点.信息或细节被忽略或遗漏.<C#/.NET/.NET Core拾遗补漏>专栏我们将探讨一些可能被忽略或遗漏的重要知识点.信息或细节 ...

  3. List<Map<String, Object>> 排序

    一.代码 public class Test { public static void main(String[] args) { Map<String, Object> map = ne ...

  4. AI探索:通过宏脚本给小众编辑器EverEdit插上AI的翅膀!

    1 AI探索:通过宏脚本给小众编辑器EverEdit插上AI的翅膀! 1.1 背景   在AI编程大行其道的背景下,各种AI编程工具:Cursor.VSCode的各种插件.Trae等等搞得不亦乐乎!您 ...

  5. PKUWC2025 游记

    哈哈哈哈哈,我糖完了,哈哈哈哈哈. Day \(-998244353\) 被波波抓到机房充军集训去了,听到了很多新奇的算法,然后拼尽全力仍难以 \(AC\)--然后被各种巨佬疯狂单调队列. Day \ ...

  6. 如何在JMeter中配置断言,将非200状态码视为测试成功

    如何在JMeter中配置断言,将非200状态码视为测试成功 引言 在接口测试中,HTTP响应状态码是判断请求是否成功的重要依据.通常情况下,状态码200表示请求成功,而其他状态码则可能表示各种类型的错 ...

  7. Linux - vi & vim 编辑器

    vim 具有程序编辑的能力,可以主动的以字体颜色辨别语法的正确性,方便程序设计. vim 是从vi发展出来的一个文本编辑器.代码补全.编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用. 使 ...

  8. 1Panel 专业版评测:全面超越宝塔的运维面板新标杆

    一. UX体验与移动端适配:更直观的跨平台交互 1Panel 专业版在用户体验上实现了对宝塔的全面超越.其界面采用现代化设计语言,以黑金主题为代表的可定制化主题系统支持一键切换,视觉风格更符合技术审美 ...

  9. VMware16虚拟机安装激活教程

    1.开始安装前需要准备好的软件 VMware-workstation-full-16--虚拟机软件(必要) 获取方式: 官方下载地址:https://www.vmware.com/cn/product ...

  10. 基于ThreeJs的大屏3D地图(二)——气泡图、渐变柱体与热力图

    前提 上一篇文章中我们完成了地图区块模型的渲染,在此基础之上本篇来讲解气泡图.3D柱形图以及3D热力图的实现方式. 首先,为了更好的关注点分离及与地图渲染模块的解耦,我们可以把所有类型的可视化元素抽象 ...