PHP框架详解 - symfony框架

        首先说一下为什么要写symfony框架,这个框架也属于PHP的一个框架,小编接触也是3年前,原因是小编接触Golang,发现symfony框架有PHP框架的东西也有Golang的东西,所以决定总结一下,有需要的同学可以参看小编的Golang相关博客,看完之后在学习symfony效果更佳

symfony安装

3版本安转:

composer create-project symfony/framework-standard-edition symfony

php bin/console server:run

4版本安装:

composer create-project symfony/skeleton symfony

composer require --dev symfony/web-server-bundle

php bin/console server:start

控制器:

创建地址:symfony\src\AppBundle\Controller\TestController.php

<?php

namespace AppBundle\Controller;//命名空间

use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;//路由文件
use Symfony\Bundle\FrameworkBundle\Controller\Controller;//基础控制器


//基础类
class TestController extends Controller
{
    /**
     * 一定要写,定义路由(page表示参数,requirements表示数据验证)
     * @Route("/test/index/{page}", requirements = {"page": "\d+"})
     */
    public function indexAction($page="") {
        echo "Hellow word"."<br />";
        echo "获取参数:".$page;die;
    }
}

路由参数:

单参数

访问地址:http://127.0.0.1:8000/test/index/1

访问地址:http://127.0.0.1:8000/test/index/2

​​

多参数:

public function indexAction($page="",$limit="") {
    echo "Hellow word"."<br />";
    echo "获取参数1:".$page."<br />";
    echo "获取参数2:".$limit;die;
}

访问地址:http://127.0.0.1:8000/test/index/1&10

​​

重定向:

访问地址:http://127.0.0.1:8000/test/jump

/**
 * @Route("/test/jump")
 */
public function jump(){
    echo "当前方法是:jump";
    return $this->redirect("/test/index/2&10");die;
}

模板引擎:

Twig语法:

{{...}} - 将变量或表达式的结果打印到模板。

{%...%} - 控制模板逻辑的标签。 它主要用于执行功能。

{#...#} - 评论语法。 它用于添加单行或多行注释。

控制器:

/**
 * @Route("/test/template_en")
 */
public function template_en(){
    return $this->render("default/test.html.twig",[
        'controller_name' => "Test",
        'func_name' => "template_en",
    ]);
}

页面:

{% extends 'base.html.twig' %}

{% block body %}
    <div id="wrapper">
        <div id="container">
            <h1>WELCOM TO TEST</h1>
            <div>控制器:{{controller_name}}</div>
            <div>方法名:{{func_name}}</div>
        </div>
    </div>
{% endblock %}

{% block stylesheets %}
<style>
    body { background: #F5F5F5; font: 18px/1.5 sans-serif; }
    h1, h2 { line-height: 1.2; margin: 0 0 .5em; }
    h1 { font-size: 36px; }
    h2 { font-size: 21px; margin-bottom: 1em; }
    p { margin: 0 0 1em 0; }
    a { color: #0000F0; }
    a:hover { text-decoration: none; }
    code { background: #F5F5F5; max-width: 100px; padding: 2px 6px; word-wrap: break-word; }
    #wrapper { background: #FFF; margin: 1em auto; max-width: 800px; width: 95%; }
    #container { padding: 2em; }
    #welcome h1 span { display: block; font-size: 75%; }
</style>
{% endblock %}

项目配置:

通过.yml文件实现配置文件自定义(Golang使用.yaml定义,实际上两者是一个东西)

一个Symfony项目有三种环境(dev、test和prod)

 

环境切换:AppKernel类负责加载你指定的配置文件(修改配置实现环境的切换)

基础方法:

切换目标文件:

表单:

        传统意义上表单是通过构建一个表单对象并将其渲染到模版来完成的。现在,在控制器里即可完成所有这些,这个是啥意思?简单点来说就是:使用PHP创建表单,而不是使用H5表单,具体代码如下:

类:

地址:symfony\src\AppBundle\Entity\Task.php
<?php
namespace AppBundle\Entity;

class Task
{
    private $studentName;
    private $studentId;
    public $password;
    private $address;
    public $joined;
    public $gender;
    private $email;
    private $marks;
    public $sports;

    public function getUserName() {
        return $this->studentName;
    }
    public function setUserName($studentName) {
        $this->studentName = $studentName;
    }


    public function getUserId() {
        return $this->studentId;
    }
    public function setUserId($studentid) {
        $this->studentid = $studentid;
    }


    public function getAddress() {
        return $this->address;
    }
    public function setAddress($address) {
        $this->address = $address;
    }


    public function getEmail() {
        return $this->email;
    }
    public function setEmail($email) {
        $this->email = $email;
    }


    public function getMarks() {
        return $this->marks;
    }
    public function setMarks($marks) {
        $this->marks = $marks;
    }
}
?>

控制器:

地址:symfony\src\AppBundle\Controller\TestController.php

<?php

namespace AppBundle\Controller;//命名空间


use Symfony\Component\Form\Extension\Core\Type\ChoiceType;
use Symfony\Component\Form\Extension\Core\Type\PasswordType;
use Symfony\Component\Form\Extension\Core\Type\EmailType;
use Symfony\Component\Form\Extension\Core\Type\CheckboxType;
use Symfony\Component\Form\Extension\Core\Type\TextareaType;
use Symfony\Component\Form\Extension\Core\Type\PercentType;
use Symfony\Component\Form\Extension\Core\Type\RepeatedType;
use Symfony\Component\HttpFoundation\Request;

//基础类
class TestController extends Controller
{


    /**
     * @Route("/test/form_test")
     */
    public function form_test(Request $request){
        //初始化对象
        $task = new Task();
        //创建
        $form = $this->createFormBuilder($task)
            ->add('UserName', TextType::class,array('label'=>'姓名'))
            ->add('UserId', TextType::class,array('label'=>'ID'))
            ->add('password', RepeatedType::class, array('type'=>PasswordType::class,'invalid_message'=>'请填写密码','options'=>array('attr'=>array('class'=>'password-field')),'required'=>true,'first_options'=> array('label'=>'密码'),'second_options'=>array('label'=>'确认密码'),))
            ->add('address', TextareaType::class,array('label'=>'地址'))
            ->add('joined', DateType::class, array('widget'=>'choice','label'=>'生日'))
            ->add('gender', ChoiceType::class,array('choices'=> array('男'=>true,'女'=>false,),'label'=>'性别'))
            ->add('email', EmailType::class,array("label"=>"邮箱"))
            ->add('marks', PercentType::class,array("label"=>"百分比"))
            ->add('sports', CheckboxType::class, array('label'=>'是否班干部','required'=>false,))
            ->add('save', SubmitType::class, array('label'=>'提交'))
            ->getForm();

        $form->handleRequest($request);

        if ($form->isSubmitted() && $form->isValid()) {
            $task = $form->getData();
            echo "获取数据:<br />";
            var_dump($task);
            die;
        }

        //渲染
        return $this->render('default/form_test.html.twig', array(
            'form' => $form->createView(),
        ));
    }
}

页面:

地址:symfony\app\Resources\views\default\form_test.html.twig

{% extends 'base.html.twig' %}

{% block body %}
   <h3>表单示例</h3>
   <div id="simpleform">
       {{ form_start(form) }}
       {{ form_widget(form) }}
       {{ form_end(form) }}
   </div>
{% endblock %}

{% block stylesheets %}
    <style>
        h3{
            text-align: center;
        }
        #simpleform {
            width:50%;
            border:2px solid grey;
            padding:14px;
            margin-left: 25%;
        }
        #simpleform label {
            font-size:14px;
            float:left;
            width:300px;
            text-align:right;
            display:block;
        }
        #simpleform span {
            font-size:11px;
            color:grey;
            width:100px;
            text-align:right;
            display:block;
        }
        #simpleform input {
            border:1px solid grey;
            font-family:verdana;
            font-size:14px;
            color:light blue;
            height:24px;
            margin: 0 0 10px 10px;
        }
        #simpleform textarea {
            border:1px solid grey;
            font-family:verdana;
            font-size:14px;
            color:light blue;
            height:120px;
            width:250px;
            margin: 0 0 20px 10px;
        }
        #simpleform select {
            margin: 0 0 20px 10px;
        }
        #simpleform button {
            clear:both;
            margin-left:30%;
            background: grey;
            color:#FFFFFF;
            border:solid 1px #666666;
            font-size:16px;
            width: 20rem;
        }
    </style>
{% endblock %}

打印数据:

object(AppBundle\Entity\Task)#2714 (10) 
{
     ["studentName":"AppBundle\Entity\Task":private]=> string(1) "1" 
     ["studentId":"AppBundle\Entity\Task":private]=> NULL 
     ["password"]=> string(7) "3456789" 
     ["address":"AppBundle\Entity\Task":private]=> string(1) "4" 
     ["joined"]=> object(DateTime)#5649 (3) 
        { 
            ["date"]=> string(26) "2019-01-01 00:00:00.000000" 
            ["timezone_type"]=> int(3)
            ["timezone"]=> string(3) "UTC" 
        } 
     ["gender"]=> bool(true) 
     ["email":"AppBundle\Entity\Task":private]=> string(8) "6@qq.com" 
     ["marks":"AppBundle\Entity\Task":private]=> float(0.07) 
     ["sports"]=> bool(true) 
     ["studentid"]=> string(1) "2" 
 }

文件上传:

修改配置文件:

打开扩展:php.ini    extension=php_fileinfo.dll
修改配置文件:symfony\app\config\config.yml

类:

<?php
namespace AppBundle\Entity;

class Task
{
    public $photo;

    public function getPhoto() {
        return $this->photo;
    }
    public function setPhoto($photo) {
        $this->photo = $photo;
        return $this;
    }
}
?>

控制器:

<?php

namespace AppBundle\Controller;//命名空间

//基础类
class TestController extends Controller
{
    /**
     * @Route("/test/form_test")
     */
    public function form_test(Request $request){
        //初始化对象
        $task = new Task();
        //创建
        $form = $this->createFormBuilder($task)
            ->add('UserName', TextType::class,array('label'=>'姓名'))
            ->add('UserId', TextType::class,array('label'=>'ID'))
            ->add('password', RepeatedType::class, array('type'=>PasswordType::class,'invalid_message'=>'请填写密码','options'=>array('attr'=>array('class'=>'password-field')),'required'=>true,'first_options'=> array('label'=>'密码'),'second_options'=>array('label'=>'确认密码'),))
            ->add('address', TextareaType::class,array('label'=>'地址'))
            ->add('joined', DateType::class, array('widget'=>'choice','label'=>'生日'))
            ->add('gender', ChoiceType::class,array('choices'=> array('男'=>true,'女'=>false,),'label'=>'性别'))
            ->add('email', EmailType::class,array("label"=>"邮箱"))
            ->add('marks', PercentType::class,array("label"=>"百分比"))
            ->add('sports', CheckboxType::class, array('label'=>'是否班干部','required'=>false,))
            ->add('photo', FileType::class, array('label' => '图片(格式:png, jpeg)'))
            ->add('save', SubmitType::class, array('label'=>'提交'))
            ->getForm();

        $form->handleRequest($request);

        if ($form->isSubmitted() && $form->isValid()) {
            $file = $task->getPhoto();
            $fileName = md5(uniqid()).'.上传文件';
            $file->move($this->getParameter('photos_directory'), $fileName);
            $task->setPhoto($fileName);
            return new Response("上传成功");
            die;
        }else{
            //渲染
            return $this->render('default/form_test.html.twig', array(
                'form' => $form->createView(),
            ));
        }
    }
}

结果:

完整代码:

完整类:

<?php
namespace AppBundle\Entity;

class Task
{
    private $studentName;
    private $studentId;
    public $password;
    private $address;
    public $joined;
    public $gender;
    private $email;
    private $marks;
    public $sports;
    public $photo;

    public function getUserName() {
        return $this->studentName;
    }
    public function setUserName($studentName) {
        $this->studentName = $studentName;
    }


    public function getUserId() {
        return $this->studentId;
    }
    public function setUserId($studentid) {
        $this->studentid = $studentid;
    }


    public function getAddress() {
        return $this->address;
    }
    public function setAddress($address) {
        $this->address = $address;
    }


    public function getEmail() {
        return $this->email;
    }
    public function setEmail($email) {
        $this->email = $email;
    }


    public function getMarks() {
        return $this->marks;
    }
    public function setMarks($marks) {
        $this->marks = $marks;
    }

    public function getPhoto() {
        return $this->photo;
    }
    public function setPhoto($photo) {
        $this->photo = $photo;
        return $this;
    }
}
?>

完整控制器:

<?php

namespace AppBundle\Controller;//命名空间

use AppBundle\Entity\Task;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;//路由文件
use Symfony\Bundle\FrameworkBundle\Controller\Controller;//基础控制器
use Symfony\Component\Form\Extension\Core\Type\TextType;
use Symfony\Component\Form\Extension\Core\Type\DateType;
use Symfony\Component\Form\Extension\Core\Type\SubmitType;

use Symfony\Component\Form\Extension\Core\Type\ChoiceType;
use Symfony\Component\Form\Extension\Core\Type\PasswordType;
use Symfony\Component\Form\Extension\Core\Type\EmailType;
use Symfony\Component\Form\Extension\Core\Type\CheckboxType;
use Symfony\Component\Form\Extension\Core\Type\TextareaType;
use Symfony\Component\Form\Extension\Core\Type\PercentType;
use Symfony\Component\Form\Extension\Core\Type\RepeatedType;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\Form\Extension\Core\Type\FileType;
use AppBundle\Form\FormValidationType;
use Symfony\Component\HttpFoundation\Response;

//基础类
class TestController extends Controller
{
    /**
     * 一定要写,定义路由(page表示参数,requirements表示数据验证)
     * @Route("/test/index/{page}&{limit}", name = "test_index", requirements = {"page": "\d+"})
     */
    public function indexAction($page="",$limit="") {
        echo "Hellow word"."<br />";
        echo "获取参数1:".$page."<br />";
        echo "获取参数2:".$limit;die;
    }

    /**
     * @Route("/test/jump")
     */
    public function jump(){
        echo "当前方法是:jump";
        return $this->redirect("/test/index/2&10");die;
    }

    /**
     * @Route("/test/template_en")
     */
    public function template_en(){
        return $this->render("default/test.html.twig",[
            'controller_name' => "Test",
            'func_name' => "template_en",
        ]);
    }

    /**
     * @Route("/test/form_test")
     */
    public function form_test(Request $request){
        //初始化对象
        $task = new Task();
        //创建
        $form = $this->createFormBuilder($task)
            ->add('UserName', TextType::class,array('label'=>'姓名'))
            ->add('UserId', TextType::class,array('label'=>'ID'))
            ->add('password', RepeatedType::class, array('type'=>PasswordType::class,'invalid_message'=>'请填写密码','options'=>array('attr'=>array('class'=>'password-field')),'required'=>true,'first_options'=> array('label'=>'密码'),'second_options'=>array('label'=>'确认密码'),))
            ->add('address', TextareaType::class,array('label'=>'地址'))
            ->add('joined', DateType::class, array('widget'=>'choice','label'=>'生日'))
            ->add('gender', ChoiceType::class,array('choices'=> array('男'=>true,'女'=>false,),'label'=>'性别'))
            ->add('email', EmailType::class,array("label"=>"邮箱"))
            ->add('marks', PercentType::class,array("label"=>"百分比"))
            ->add('sports', CheckboxType::class, array('label'=>'是否班干部','required'=>false,))
            ->add('photo', FileType::class, array('label' => '图片(格式:png, jpeg)'))
            ->add('save', SubmitType::class, array('label'=>'提交'))
            ->getForm();

        $form->handleRequest($request);

        if ($form->isSubmitted() && $form->isValid()) {
            $file = $task->getPhoto();
            $fileName = md5(uniqid()).'.上传文件';
            $file->move($this->getParameter('photos_directory'), $fileName);
            $task->setPhoto($fileName);
            return new Response("上传成功");
            die;
        }else{
            //渲染
            return $this->render('default/form_test.html.twig', array(
                'form' => $form->createView(),
            ));
        }
    }

}

完整页面:

{% extends 'base.html.twig' %}
{% block javascripts %}
    <script language = "javascript" src = "https://code.jquery.com/jquery-2.2.4.min.js"></script>
{% endblock %}

{% block body %}
   <h3>表单示例</h3>
   <div id="simpleform">
       {{ form_start(form) }}
       {{ form_widget(form) }}
       {{ form_end(form) }}
   </div>
{% endblock %}

{% block stylesheets %}
    <style>
        h3{
            text-align: center;
        }
        #simpleform {
            width:50%;
            border:2px solid grey;
            padding:14px;
            margin-left: 25%;
        }
        #simpleform label {
            font-size:14px;
            float:left;
            width:300px;
            text-align:right;
            display:block;
        }
        #simpleform span {
            font-size:11px;
            color:grey;
            width:100px;
            text-align:right;
            display:block;
        }
        #simpleform input {
            border:1px solid grey;
            font-family:verdana;
            font-size:14px;
            color:light blue;
            height:24px;
            margin: 0 0 10px 10px;
        }
        #simpleform textarea {
            border:1px solid grey;
            font-family:verdana;
            font-size:14px;
            color:light blue;
            height:120px;
            width:250px;
            margin: 0 0 20px 10px;
        }
        #simpleform select {
            margin: 0 0 20px 10px;
        }
        #simpleform button {
            clear:both;
            margin-left:30%;
            background: grey;
            color:#FFFFFF;
            border:solid 1px #666666;
            font-size:16px;
            width: 20rem;
        }
    </style>
{% endblock %}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

yolov1到v8的变化

目录 1.YOLO介绍&#xff1a;1.变化&#xff1a;小结&#xff1a; 1.YOLO介绍&#xff1a; YOLO&#xff08;You Only Look Once&#xff09;是一种流行的目标检测算法&#xff0c;它的版本从YOLOv1到YOLOv8经历了多次改进。以下是YOLOv1到YOLOv8的一些不同之处和改变&#xf…

快来使用Portainer让测试环境搭建飞起来吧

Portainer是Docker的图形化管理工具&#xff0c;提供状态显示面板、应用模板快速部署、容器镜像网络数据卷的基本操作&#xff08;包括上传下载镜像&#xff0c;创建容器等操作&#xff09;、事件日志显示、容器控制台操作、Swarm集群和服务等集中管理和操作、登录用户管理和控…

PM圆桌派:同事不愿意告诉你的职场套路有哪些?

职场是社会的缩影&#xff0c;想要崭露头角&#xff0c;获得更多升职加薪的机会&#xff0c;就不要做着和多数人一样的事情&#xff0c;却期待着不一样的结果。 职场上有很多潜在的规则&#xff0c;要会做事&#xff0c;也要会说话&#xff0c;更要会做人。如果不懂规则&#…

Python 数据可视化:配色方案

1、引言 在这篇文章中&#xff0c;我们将研究Python的一些配色方案&#xff0c;主要是Seaborn库。这将采用 Python Notebook 格式&#xff0c;其中包括绘图的代码。 2、实验数据 首先导入必要的库&#xff1a; import pandas as pd import seaborn as sns import matplotlib…

【Vue】3-2、组合式 API

一、setup 选项 <script> export default {/*** 1、setup 执行时机早于 beforeCreate* 2、setup 中无法获取 this* 3、数据和函数需要在 setup 最后 return&#xff0c;才能在模板中使用* 4、可以通过 setup 语法糖简化代码*/setup(){// console.log(setup function, thi…

Flink容错机制

目录 一&#xff0c;检查点&#xff1a; 二&#xff0c;保存点&#xff1a; ①版本管理和归档存储&#xff1a; ②更新Flink版本&#xff1a; ③更新应用程序&#xff1a; ④调整并行度&#xff1a; ⑤暂停应用程序&#xff1a; Flink容错机制 一&#xff0c;检查点&#xff…

RedHat8.4安装邮件服务器

一、配置发件服务器 1.1 根据现场IP&#xff0c;配置主机名 vim /etc/hosts 192.168.8.120 mail.test.com 将主机名更改为邮件服务器域名mail.test.com 1.2 关闭防火墙&#xff0c;禁止开机启动 systemctl stop firewalld systemctl disable firewalld 1.3 关闭selinux v…

java之ReentrantLock

在讲RentrantLock之前需要先讲一下AQS和LockSupport&#xff0c;因为rentrantLock底层是用AQS实现的&#xff0c;而AQS中获取阻塞和唤醒底使用LockSupport实现的。 1、LockSupport实现 下面代码中&#xff0c;LockSupport.park方法是当前线程等待&#xff0c;直到获得许可&am…

React Native学习记录

一、创建RN项目的时候是空文件夹的问题 1.使用npx react-native init RNDemos初始化项目的时候&#xff0c;会报错&#xff0c;模版错误&#xff0c;然后创建出来一个空的文件夹 2.如果出现这种情况&#xff0c;需要设置npm install -g react-native-cli 3.安装完成以后再次初…

Postgres与DynamoDB:选择哪个数据库

启动新项目时需要做出的决定之一是使用哪个数据库。如果您使用的是Django这样的包含电池的框架&#xff0c;那么没有理由再三考虑。选择一个受支持的数据库引擎&#xff0c;就可以了。另一方面&#xff0c;如果你使用像FastAPI或Flask这样的微框架&#xff0c;你需要自己做出这…

聚簇索引、回表与覆盖索引

聚簇索引一般指的是主键索引&#xff08;如果存在主键索引的话&#xff09;。 作为一个正常开发&#xff0c;建表时主键肯定是必须的。 而即使如果表中没有定义主键&#xff0c;InnoDB 会隐式选择一个唯一的非空索引代替。 所以我们就直接含糊点说&#xff1a; 聚簇索引就是…

crmebAI名片小程序全开源全端uniapp

应用介绍 AI名片小程序是一种基于人工智能技术的数字化智能名片&#xff0c;具有多种功能和特点。以下是AI名片小程序的简介&#xff1a; 智能化管理&#xff1a;AI名片小程序具备智能化的管理系统&#xff0c;用户可以方便地管理名片信息&#xff0c;包括个人信息、职位、公司…

jmeter-02切换中文,改为白色背景

文章目录 一、切换中文问题&#xff1a;jmeter设置中文后无法保存&#xff0c;下次启动还是英文 二、改为白色背景 一、切换中文 问题&#xff1a;jmeter设置中文后无法保存&#xff0c;下次启动还是英文 解决办法&#xff1a; 在jmeter路径下找到文件jmeter.bat开启编辑模式&…

如何在Shopee平台上进行手机类目选品?

在Shopee平台上进行手机类目的选品是一个关键而复杂的任务。卖家需要经过一系列的策略和步骤&#xff0c;以确保选品的成功和销售业绩的提升。下面将介绍一些有效的策略&#xff0c;帮助卖家在Shopee平台上进行手机类目选品。 先给大家推荐一款shopee知虾数据运营工具知虾免费…

指针的学习2

目录 数组名的理解 使用指针访问数组 一维数组传参的本质 冒泡排序 二级指针 指针数组 指针数组模拟二维数组 数组名的理解 数组名是数组首元素的地址 例外&#xff1a; sizeof(数组名),sizeof中单独放数组名&#xff0c;这里的数组名表示整个数组&#xff0c;计算的…

从零开始手写mmo游戏从框架到爆炸(三)— 服务启动接口与网络事件监听器

上一章我们完成了netty服务启动的相关抽象&#xff08;https://blog.csdn.net/money9sun/article/details/136025471&#xff09;&#xff0c;这一章我们再新增一个全局的服务启动类&#xff0c;方便后续扩展。 服务启动 新增的两个类如下&#xff1a; 定义一个接口IServer …

6款超好用的IDEA插件,开发必备!

今天给大家介绍几款开发必备的IDEA插件&#xff1a; JRebel 热部署插件&#xff0c;让你在修改完代码后&#xff0c;不用再重新启动&#xff0c;很实用&#xff01;但是&#xff0c;不是免费的&#xff0c;需要大家继续发挥下自己的聪明才智才能happy的使用 Json Parser 厌倦…

Linux 多线程 | 线程的概念

线程的概念 线程是一个执行分支&#xff0c;执行粒度比进程更细&#xff0c;调度成本更低&#xff1b; 线程是进程内部的一个执行流&#xff1b; 线程是CPU调度的基本单位&#xff0c;进程是承担分配系统资源的基本实体。 之前我们学习过虚拟地址空间的知识&#xff0c;知道…

SpringFramework实战指南(五)

SpringFramework实战指南(五) 4.3 基于 注解 方式管理 Bean4.3.1 实验一: Bean注解标记和扫描 (IoC)4.3.2 实验二: 组件(Bean)作用域和周期方法注解4.3.3 实验三: Bean属性赋值:引用类型自动装配 (DI)4.3.4 实验四: Bean属性赋值:基本类型属性赋值 (DI)4.3.5 实验五:…