PHP框架详解 - symfony框架

news2025/1/15 23:31:11

        首先说一下为什么要写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.coloradmin.cn/o/1432796.html

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

相关文章

【数据结构与算法】(7)基础数据结构之双端队列的链表实现、环形数组实现示例讲解

目录 2.6 双端队列1) 概述2) 链表实现3) 数组实现习题E01. 二叉树 Z 字层序遍历-Leetcode 103 2.6 双端队列 1) 概述 双端队列、队列、栈对比 定义特点队列一端删除&#xff08;头&#xff09;另一端添加&#xff08;尾&#xff09;First In First Out栈一端删除和添加&…

电脑上常见的绘图软件有哪些?

现在在电脑上绘图很流行&#xff0c;不仅可以随时更改&#xff0c;还可以提高绘图效率&#xff0c;绘图软件中有很多工具。市场上的计算机绘图软件种类繁多。包括艺术设计、工业绘图和3D绘图。那么每个绘图软件都有自己的特点。那么&#xff0c;哪个更适合计算机绘画软件呢&…

信任与创新 | 回顾通付盾的2023!

-END- 数信云&#xff0c;基于区块链与人工智能的数据安全应用与服务平台

基于SpringBoot的后端导出Excel文件

后端导出Excel&#xff0c;前端下载。 文章目录 后端导出Excel引入依赖写入响应 前端下载后端导出失败和成功返回的内容类型不同&#xff0c;因此需要分别判断。 工具类ServletUtils.javaFileUtils.javafile.js 后端导出Excel 引入依赖 poi 操作xls&#xff0c;doc…&#xff…

【Script】使用pyOpenAnnotate搭建半自动标注工具(附python源码)

文章目录 0. Background1. Method2. Code3. Example: 雄鹿红外图像标注3.1 选择色彩空间3.2 执行阈值3.3 执行形态学操作3.4 轮廓分析以找到边界框3.5 过滤不需要的轮廓3.6 绘制边界框3.7 以需要的格式保存Reference本文将手把手教你用Python和OpenCV搭建一个半自动标注工具(包…

Flutter开发模仿百度云盘创建文件夹功能Draggable和DragTarget的混合使用

使用LongPressDraggable和DragTarget写了个类似于百度云盘管理文件和文件夹的功能&#xff08;为了避免和列表的滑动手势冲突&#xff0c;所以采用LongPressDraggable而不是Draggable&#xff09;&#xff1a; 1、拖拽文件到文件夹中 2、拖拽两个文件可以合并成一个新的文件夹…

【linux】git和gdb调试工具

在linux下提交代码同步到gitee 1.创建一个新的仓库&#xff08;演示步骤&#xff09; 2.init 这两个步骤用于识别提交代码的身份&#xff0c;一个你的名字&#xff0c;一个你的邮箱 开启本地仓库 克隆本地仓库成功 我们将这个仓库拷到了111目录底下. 我们发现少了一个.gitig…

window 镜像---负载篇

前提&#xff1a;需要修改window的powershell执行脚本的策略 步骤&#xff1a;以管理员身份打开powershell&#xff0c;执行 Get-ExecutionPolicy查看当前执行策略&#xff0c;若返回值是Restricted&#xff0c;需执行Set-ExecutionPolicy RemoteSigned powershell 版本信息&am…

SpringMVC精简知识点

SpringMVC 数据格式化基本数据类型和字符串自动转换特殊数据类型和字符串自动转换 验证及国际化应用实例注意事项和使用细节注解的结合使用数据类型转换校验核心类-DatBinder取消某个属性的绑定中文乱码解决处理json和HttpMessageConverter<T>作业布置SpringMVC文件上传自…

笔记本电脑的WIFI模块,突然不显示了,网络也连接不上

问题复现&#xff1a; 早上&#xff0c;在更新完笔记本电脑的系统之后&#xff0c;连网之后&#xff0c;网络突然直接断开&#xff0c;一查看&#xff0c;WiFi模块居然不见了&#xff0c;开机重启也是如此&#xff0c;这种情况常常出现在更新系统之后&#xff0c;WiFi模块驱动就…

MySQL集群 1主1从 主从复制(原理 及配置命令)

CSDN 成就一亿技术人&#xff01; 今天分享一期 MySQL集群方案&#xff1a;主从集群 也是最常用的一种 CSDN 成就一亿技术人&#xff01; 目录 使用主从复制的原因&#xff08;优点&#xff09; 主从复制的过程&#xff08;原理&#xff09; 了解两大线程&#xff08; I/O…

7min到40s:SpringBoot 启动优化实践!

目录 背景 1 耗时问题排查 1.1 观察 SpringBoot 启动 run 方法 1.2 监控 Bean 注入耗时 2 优化方案 2.1 如何解决扫描路径过多&#xff1f; 2.2 如何解决 Bean 初始化高耗时&#xff1f; 3 新的问题 3.1 SpringBoot 自动化装配&#xff0c;让人防不胜防 3.2 使用 sta…

大带宽服务器托管的特点和考虑因素

很多公司和企业对于使用大带宽服务器的需求和存储不一样&#xff0c;为了满足不同的用户需求&#xff0c;大带宽服务器托管是个不错的选择&#xff0c;小编为您整理发布大带宽服务器托管的特点和要考虑的因素。 大带宽服务器托管是一种服务器托管服务&#xff0c;其主要特点是…

GLIP:零样本学习 + 目标检测 + 视觉语言大模型

GLIP 核心思想GLIP 对比 BLIP、BLIP-2、CLIP 主要问题: 如何构建一个能够在不同任务和领域中以零样本或少样本方式无缝迁移的预训练模型&#xff1f;统一的短语定位损失语言意识的深度融合预训练数据类型的结合语义丰富数据的扩展零样本和少样本迁移学习 效果 论文&#xff1a;…

JetPackCompose之Text使用指北

Jetpack Compose系列(6) - 文本组件 对应View体系中传统的TextView&#xff0c;Jetpack Compose中用Text组件来显示文本信息。跟其他组件一样&#xff0c;它在构造函数里就包含控制文本显示样式的一些属性&#xff0c;下面是其参数及解释&#xff1a; Composable fun Text(te…

从零开始手写mmo游戏从框架到爆炸(一)— 开发环境

一、创建项目 1、首先创建一个maven项目&#xff0c;pom文件如下&#xff1a; <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/POM/4.0.0…

力扣面试150 只出现一次的数字Ⅱ 哈希 统计数位 DFA有穷自动机

Problem: 137. 只出现一次的数字 II 文章目录 思路&#x1f496; 哈希&#x1f496; 位数统计&#x1f496; DFA 状态机 思路 &#x1f468;‍&#x1f3eb; 参考 &#x1f496; 哈希 ⏰ 时间复杂度: O ( n ) O(n) O(n) &#x1f30e; 空间复杂度: O ( n ) O(n) O(n) cl…

《动手学深度学习(PyTorch版)》笔记7.1

注&#xff1a;书中对代码的讲解并不详细&#xff0c;本文对很多细节做了详细注释。另外&#xff0c;书上的源代码是在Jupyter Notebook上运行的&#xff0c;较为分散&#xff0c;本文将代码集中起来&#xff0c;并加以完善&#xff0c;全部用vscode在python 3.9.18下测试通过&…

vue 下载二进制文件

文章目录 概要技术细节 概要 vue 下载后端返回的二进制文件流 技术细节 import axios from "axios"; const baseUrl process.env.VUE_APP_BASE_API; //downLoadPdf("/pdf/download?pdfName" res .pdf, res); export function downLoadPdf(str, fil…

【Linux】信号-上

欢迎来到Cefler的博客&#x1f601; &#x1f54c;博客主页&#xff1a;折纸花满衣 &#x1f3e0;个人专栏&#xff1a;题目解析 &#x1f30e;推荐文章&#xff1a;【LeetCode】winter vacation training 目录 &#x1f449;&#x1f3fb;信号的概念与产生jobs命令普通信号和实…