symfony学习笔记3.4(bundle、service、doctrine的使用…)
yii、laravel框架都是基于symfony组件衍生,symfony的强大不用多说。文档里有的,很好找的就不写了
附:
- symfony官网 https://symfony.com/doc/3.4
- yml语法(秒懂的那种)https://www.jianshu.com/p/a8252bf2a63d
- 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>注册服务
- 在需要的Bundle下新建服务文件夹(service)
- 在新建的文件夹(service)下,建立class(名字根据业务逻辑来,symfony会自动注册/src下的类)
- 也可以在/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>连接多数据库:
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、常用操作方式
- Repository
- dql
queryBuilder
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的使用…)的更多相关文章
- symfony学习笔记2—纯的PHP代码和symfony的区别
Symfony vs 纯PHP为啥symfony比普通的php文件访问要好?这一章我们写一个简单的php文件项目,然后组织它,你会发现为什么web应用会发展到现在这个样子.最后我们将学习symfony ...
- symfony学习笔记1—简介
1.symfony快速入门还是先看代码结构把,这个是拿到代码的第一印象,app/:整个应用的配置,模版,translations,这个可能是多语言文件什么,src/:项目php文件,vendor/:第 ...
- android菜鸟学习笔记28----Android中的Service生命周期及本地和远程服务绑定的实现
Service是Android中长期在后台运行的没有界面的组件,使用服务的优势在于:能够提高进程的优先级,系统不容易回收掉进程,即便回收了,内存充足的时候,会把进程重新创建. 1.服务的简单使用示例: ...
- Android(java)学习笔记146:Bundle和Intent类使用和交互
Bundle只是一个信息的载体 将内部的内容以键值对组织 ,Intent负责Activity之间的交互自己是带有一个Bundle的.Intent.putExtras(Bundle bu ...
- Android(java)学习笔记181:利用Service在后台播放背景音乐
1.在android应用程序里,有一种没有UI的类(android.app.Service)——Service.简单来说,Service是一个 background process(背景程序),通过背 ...
- 【ASP.NET MVC 学习笔记】- 18 Bundle(捆绑)
本文参考:http://www.cnblogs.com/willick/p/3438272.html 1.捆绑(Bundle),一个在 View 和 Layout 中用于组织优化浏览器请求的 CSS ...
- k8s学习笔记之九: Service Account
第一章.前言 每一个用户对API资源进行操作都需要通经过以下三个步骤: 第一步:对客户端访问进行认证操作,确认是否具有访问k8s权限 token(共享秘钥) SSL(双向SSL认证) ....通过任何 ...
- Sharepoint2013商务智能学习笔记之Secure Store Service服务配置(二)
Secure Store Service 是运行在应用程序服务器上的授权服务,它提供一个存储用户凭据的数据库,Secure Store Service 在商务智能中的地位很重要,Sharepoint商 ...
- Android(java)学习笔记89:Bundle和Intent类使用和交互
1. Bundle 和 Intent: Bundle只是一个信息的载体 将内部的内容以键值对组织 ,Intent负责Activity之间的交互自己是带有一个Bundle的.Intent.putE ...
- Android(java)学习笔记124:利用Service在后台播放背景音乐
1. 在android应用程序里,有一种没有UI的类(android.app.Service)——Service.简单来说,Service是一个 background process(背景程序),通过 ...
随机推荐
- C# Dev GridView当前行
DEV获取GridControl当前行 //直接通过gridView获取当前行 dr=this.gridView1.GetDataRow(this.gridView1.FocusedRowHandle ...
- 2025年这些实用的C#/.NET知识点你都知道吗?
前言 在这个快速发展的技术世界中,时常会有一些重要的知识点.信息或细节被忽略或遗漏.<C#/.NET/.NET Core拾遗补漏>专栏我们将探讨一些可能被忽略或遗漏的重要知识点.信息或细节 ...
- List<Map<String, Object>> 排序
一.代码 public class Test { public static void main(String[] args) { Map<String, Object> map = ne ...
- AI探索:通过宏脚本给小众编辑器EverEdit插上AI的翅膀!
1 AI探索:通过宏脚本给小众编辑器EverEdit插上AI的翅膀! 1.1 背景 在AI编程大行其道的背景下,各种AI编程工具:Cursor.VSCode的各种插件.Trae等等搞得不亦乐乎!您 ...
- PKUWC2025 游记
哈哈哈哈哈,我糖完了,哈哈哈哈哈. Day \(-998244353\) 被波波抓到机房充军集训去了,听到了很多新奇的算法,然后拼尽全力仍难以 \(AC\)--然后被各种巨佬疯狂单调队列. Day \ ...
- 如何在JMeter中配置断言,将非200状态码视为测试成功
如何在JMeter中配置断言,将非200状态码视为测试成功 引言 在接口测试中,HTTP响应状态码是判断请求是否成功的重要依据.通常情况下,状态码200表示请求成功,而其他状态码则可能表示各种类型的错 ...
- Linux - vi & vim 编辑器
vim 具有程序编辑的能力,可以主动的以字体颜色辨别语法的正确性,方便程序设计. vim 是从vi发展出来的一个文本编辑器.代码补全.编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用. 使 ...
- 1Panel 专业版评测:全面超越宝塔的运维面板新标杆
一. UX体验与移动端适配:更直观的跨平台交互 1Panel 专业版在用户体验上实现了对宝塔的全面超越.其界面采用现代化设计语言,以黑金主题为代表的可定制化主题系统支持一键切换,视觉风格更符合技术审美 ...
- VMware16虚拟机安装激活教程
1.开始安装前需要准备好的软件 VMware-workstation-full-16--虚拟机软件(必要) 获取方式: 官方下载地址:https://www.vmware.com/cn/product ...
- 基于ThreeJs的大屏3D地图(二)——气泡图、渐变柱体与热力图
前提 上一篇文章中我们完成了地图区块模型的渲染,在此基础之上本篇来讲解气泡图.3D柱形图以及3D热力图的实现方式. 首先,为了更好的关注点分离及与地图渲染模块的解耦,我们可以把所有类型的可视化元素抽象 ...