TCPDF生成PDF文件,含jpjraph生成雷达图

TCPDF生成PDF文件,含jpjraph生成雷达图

依赖自行安装

        "tecnickcom/tcpdf": "^6.6","amenadiel/jpgraph": "4"

雷达图生成

中文字体添加安装

没有封装,只作为测试案例展示

// 创建新的PDF文档$pdf = new \TCPDF(PDF_PAGE_ORIENTATION, PDF_UNIT, PDF_PAGE_FORMAT, true, 'UTF-8', false);
//        $pdf = new \TCPDF('P', 'mm', 'A4', true, 'UTF-8', false, true);$pdf->SetPrintHeader(false);$pdf->SetPrintFooter(false);//禁用自动分页$pdf->SetAutoPageBreak(false);// 设置文档信息
//        $pdf->SetCreator(PDF_CREATOR);  //设置 PDF 文件的创建者。
//        $pdf->SetAuthor('Your Name');   //设置 PDF 文件的作者姓名。
//        $pdf->SetTitle('Radar Chart');      //设置 PDF 文件的标题。
//        $pdf->SetSubject('TCPDF Tutorial');//设置 PDF 文件的主题。
//        $pdf->SetKeywords('TCPDF, PDF, example, test, guide');//设置 PDF 文件的关键词。
// 设置默认的页眉数据
//        $pdf->SetHeaderData(PDF_HEADER_LOGO, PDF_HEADER_LOGO_WIDTH, PDF_HEADER_TITLE.' 006', PDF_HEADER_STRING);
// 设置页眉和页脚字体
//        $pdf->setHeaderFont(Array(PDF_FONT_NAME_MAIN, '', PDF_FONT_SIZE_MAIN));
//        $pdf->setFooterFont(Array(PDF_FONT_NAME_DATA, '', PDF_FONT_SIZE_DATA));
// 设置默认等宽字体
//        $pdf->SetDefaultMonospacedFont(PDF_FONT_MONOSPACED);
// 设置边距
//        $pdf->SetMargins(PDF_MARGIN_LEFT, PDF_MARGIN_TOP, PDF_MARGIN_RIGHT);
//        $pdf->SetHeaderMargin(PDF_MARGIN_HEADER);
//        $pdf->SetFooterMargin(PDF_MARGIN_FOOTER);
// 设置自动分页
//        $pdf->SetAutoPageBreak(TRUE, PDF_MARGIN_BOTTOM);
// 设置图像缩放因子
//        $pdf->setImageScale(PDF_IMAGE_SCALE_RATIO);
// set font
//        $pdf->SetFont('helvetica', '', 10);$pageWidth = $pdf->getPageWidth();// 页宽度$pageHeight = $pdf->getPageHeight();// 页宽度$titleFont = 'yahei'; // 字体$titleFontSize = 16; // 字号//封面$pdf->AddPage();$cover_img = 'https://******.png';$pdf->Image($cover_img, 0, 0, $pageWidth, $pageHeight);// 设置文字颜色$pdf->SetTextColor(0,0,0);// 设置字体和字号$pdf->SetFont($titleFont, '', $titleFontSize-6);$pdf->Text(23, 275, '扫一扫在线浏览报告');//======================编号// 设置文字颜色$pdf->SetTextColor(0,0,0);// 设置字体和字号$pdf->SetFont($titleFont, '', $titleFontSize-6);$pdf->Text(18, 30, '报告编号:');//======================自测时间$dateTime = new \DateTime($row['create_time']);$yearMonthDay = $dateTime->format('Y-m-d');$pdf->Text(157, 265, '自测时间:'.$yearMonthDay);//======================报告单位$pdf->Text(115, 271, '报告提供单位:');//======================企业名称// 设置文字颜色$pdf->SetTextColor(67, 16, 16);// 设置字体和字号$pdf->SetFont($titleFont, '', $titleFontSize+3);$pdf->Text($pdf->GetX()-180, $pdf->GetY()-145, $qy_data['Name'] ?? '');//第一页$pdf->AddPage();$headerImgPath = 'https://*****.png';$footerImgPath = 'https://******.png';$headerImgHeight = 30; // 页眉图片高度$footerImgHeight = 30; // 页脚图片高度// 添加页眉图片$pdf->Image($headerImgPath, 0, 0, $pageWidth, $headerImgHeight, '', '', '', false, 300, '', false, false, 0);// 添加页脚图片$pdf->Image($footerImgPath, 0, 267, $pageWidth, $footerImgHeight, '', '', '', false, 300, '', false, false, 0);$pdf->SetFont($titleFont, '', 8);$pdf->SetTextColor(144, 144, 144);$pdf->Text($pdf->GetX()+8, $pdf->GetY()+2, $qy_data['Name']);//================开始========================// 设置标题样式$titleWidth = $pageWidth - 20; // 标题宽度(以点为单位)$titleHeight = 15; // 标题高度(以点为单位)$titleBackgroundColor = array(0, 130, 237); // 背景颜色(RGB颜色值)$titleTextColor = array(255, 255, 255); // 文字颜色(RGB颜色值)// 设置背景颜色$pdf->SetFillColor($titleBackgroundColor[0], $titleBackgroundColor[1], $titleBackgroundColor[2]);// 设置文字颜色$pdf->SetTextColor($titleTextColor[0], $titleTextColor[1], $titleTextColor[2]);// 设置字体和字号$pdf->SetFont($titleFont, 'B', $titleFontSize);// 绘制带有背景颜色的矩形作为标题$pdf->Rect(10, 25, $titleWidth, $titleHeight, 'F');// 在标题矩形内居中显示标题文本$titleText = '企业概要';$pdf->Text(12, 29, $titleText);//===================黑字文案=================$pdf->SetTextColor(0,0,0);$pdf->SetFont($titleFont, '', 12);$pdf->Text(12, 45, '企业基本信息数据来源于测试主体在相关信息公示、公开信息数据整理分析所得');//======================// 设置背景颜色$pdf->SetFillColor(95, 183, 255);// 设置文字颜色$pdf->SetTextColor($titleTextColor[0], $titleTextColor[1], $titleTextColor[2]);$pdf->Rect(10, 55, $titleWidth, $titleHeight-2, 'F');// 在标题矩形内居中显示标题文本$pdf->SetFont($titleFont, 'B', 12);$titleText = '基本信息';$pdf->Text(12, 59, $titleText);$pdf->Ln(12); // 换行// 设置字体$pdf->SetTextColor(0,0,0);$pdf->SetFont($titleFont, '', 8);// 表格数据$data = [['企业名称', $qy_data['Name'] ?? '', '统一社会信用代码', $qy_data['CreditCode'] ?? ''],['法人代表', $qy_data['OperName'] ?? '', '注册资本', $qy_data['RegistCapi'] ?? ''],['企业类型', $qy_data['EconKind'] ?? '', '登记状态', $qy_data['Status'] ?? ''],['成立日期', $qy_data['StartDate'] ? date('Y-m-d',strtotime($qy_data['StartDate'])) : '', '核准日期', $qy_data['CheckDate'] ? date('Y-m-d',strtotime($qy_data['CheckDate'])) : ''],['营业期限', date('Y-m-d',strtotime($qy_data['TermStart'])).'至'.$qy_data['TeamEnd'] ? date('Y-m-d',strtotime($qy_data['TeamEnd'])) :'无固定期限', '登记机关', $qy_data['BelongOrg'] ?? ''],
//            ['注册地址', 'B4', 'C4', 'D4'],
//            ['经营范围', 'B4', 'C4', 'D4'],];// 遍历表格数据$tHeight = 30;foreach ($data as $key => $val) {foreach ($val as $colIndex => $cell) {// 设置单元格背景颜色if ($colIndex == 0 || $colIndex == 2) {$pdf->SetFillColor(244, 244, 244); // 淡灰色背景$tWidth = 30;$align = 'C';} else {$pdf->SetFillColor(255, 255, 255); // 白色背景$tWidth = 65;$align = 'L';}// 创建单元格$pdf->Cell($tWidth, 10, $cell, ['LTRB' => ['width' => 0.1, 'color' => array(233, 233, 233)]], 0, $align, 1);}$pdf->Ln(); // 换行}// 合并最后一行的后三列
//        $pdf->SetXY(12, $pdf->GetY()); // 设置位置为当前 Y 坐标$tWidth = 30;$pdf->SetFillColor(244, 244, 244); // 淡灰色背景$pdf->Cell($tWidth, 10, '注册地址', 1, 0, 'C',1);$pdf->SetFillColor(255, 255, 255); // 白色背景$pdf->Cell($tWidth + 130, 10, $qy_data['Address']??'', ['LTRB' => ['width' => 0.1, 'color' => array(233, 233, 233)]], 1, 'L', 1, '', 3);$pdf->SetFillColor(244, 244, 244); // 淡灰色背景$contentHeight = $pdf->GetStringHeight($tWidth + 130,$qy_data['Scope']??'');$rowHeight = max(10, $contentHeight)+2; // 行高度,取标题和内容高度的最大值$pdf->Cell($tWidth, $rowHeight, '经营范围', 1, 0, 'C',1);$pdf->MultiCell($tWidth + 130, $rowHeight, $qy_data['Scope']??'', ['LTRB' => ['width' => 0.1, 'color' => array(233, 233, 233)]], 'L', 0, 1,'', '', true, 0, false, true, $rowHeight, 'M');============2. 企业投资人信息=======
/// 表格数据
//        $data = [
//            [
//                "KeyNo" => "1xxxxxxxxxxxxxxxxx",
//                "StockName" => "1xxx",
//                "StockType" => "1自然人股东1",
//                "StockPercent" => "12.8338%",
//                "ShouldCapi" => "1641.6913",
//                "ShoudDate" => "1007-10-22",
//                "StakeDate" => "1007-08-22",
//                "CreditCode" => "1xxxxxxxxxxxxx"
//            ],[
//                "KeyNo" => "2xxxxxxxxxxxxxxxxx",
//                "StockName" => "2xxx",
//                "StockType" => "自然人股东2",
//                "StockPercent" => "22.8338%",
//                "ShouldCapi" => "2641.6913",
//                "ShoudDate" => "2007-10-22",
//                "StakeDate" => "2007-08-22",
//                "CreditCode" => "2xxxxxxxxxxxxxx"
//            ]
//        ];$data = $qy_datas['t']['Result'];if(!$data){$data = [["KeyNo" => "-","StockName" => "-","StockType" => "-","StockPercent" => "-","ShouldCapi" => "-","ShoudDate" => "-","StakeDate" => "-","CreditCode" => "-"]];}// 检查是否需要换页if ($pdf->GetY() + 20 > $pdf->getPageHeight()) {$pdf->AddPage(); // 换页        // 添加页眉图片$pdf->Image($headerImgPath, 0, 0, $pageWidth, $headerImgHeight, '', '', '', false, 300, '', false, false, 0);// 添加页脚图片$pdf->Image($footerImgPath, 0, 267, $pageWidth, $footerImgHeight, '', '', '', false, 300, '', false, false, 0);$pdf->SetFont($titleFont, '', 8);$pdf->SetTextColor(144, 144, 144);$pdf->Text($pdf->GetX()+8, $pdf->GetY()+2, $qy_data['Name']);$pdf->Ln(12);}$pdf->SetFont($titleFont, 'B', 12);// 设置背景颜色$pdf->SetFillColor(95, 183, 255);// 设置文字颜色$pdf->SetTextColor($titleTextColor[0], $titleTextColor[1], $titleTextColor[2]);$pdf->Rect($pdf->GetX(), $pdf->GetY()+3, $titleWidth, $titleHeight-2, 'F');// 在标题矩形内居中显示标题文本$titleText = '企业投资人信息';$pdf->Text(12, $pdf->GetY()+7, $titleText);$pdf->Ln(12); // 换行// 遍历表格数据foreach ($data as $key => $val) {// 检查是否需要换页if ($pdf->GetY() + 30 > $pdf->getPageHeight()) {$pdf->AddPage(); // 换页        // 添加页眉图片$pdf->Image($headerImgPath, 0, 0, $pageWidth, $headerImgHeight, '', '', '', false, 300, '', false, false, 0);// 添加页脚图片$pdf->Image($footerImgPath, 0, 267, $pageWidth, $footerImgHeight, '', '', '', false, 300, '', false, false, 0);$pdf->SetFont($titleFont, '', 8);$pdf->SetTextColor(144, 144, 144);$pdf->Text($pdf->GetX()+8, $pdf->GetY()+2, $qy_data['Name']);$pdf->Ln(12);}// 设置字体$pdf->SetTextColor(0,0,0);$pdf->SetFont($titleFont, '', 8);$pdf->SetFillColor(244, 244, 244); // 淡灰色背景// 创建单元格$pdf->Cell(30, 10, '投资人姓名', 1, 0, 'C', 1);$pdf->SetFillColor(255, 255, 255); // 白色背景// 创建单元格$pdf->Cell(65, 10, $val['StockName'], 1, 0, 'L', 1);$pdf->SetFillColor(244, 244, 244); // 淡灰色背景// 创建单元格$pdf->Cell(30, 10, '投资人类型', 1, 0, 'C', 1);$pdf->SetFillColor(255, 255, 255); // 白色背景// 创建单元格$pdf->Cell(65, 10, $val['StockType'], 1, 1, 'L', 1);$pdf->SetFillColor(244, 244, 244); // 淡灰色背景// 创建单元格$pdf->Cell(30, 10, '持股比例', 1, 0, 'C', 1);$pdf->SetFillColor(255, 255, 255); // 白色背景// 创建单元格$pdf->Cell(65, 10, $val['StockPercent'], 1, 0, 'L', 1);$pdf->SetFillColor(244, 244, 244); // 淡灰色背景// 创建单元格$pdf->Cell(30, 10, '认缴出资额', 1, 0, 'C', 1);$pdf->SetFillColor(255, 255, 255); // 白色背景// 创建单元格$pdf->Cell(65, 10, $val['ShouldCapi'], 1, 1, 'L', 1);$pdf->Ln(2); // 换行}//============3. 企业资质(如高新技术企业、创新型/科技型中小企业)=======// 表格数据
//        $data = [
//            [
//                "Name" => "高新技术企业",
//                "Level" => "国家级",
//                "Source" => "关于辽宁省2020年第三批高新技术企业备案的复函",
//                "PublishOffice" => "全国高新技术企业认定管理工作领导小组办公室",
//                "PublishDate" => "2021-01-18",
//                "BegingDate" => "2020-12-01",
//                "DeadLine" => "2023-12-01"
//            ],
//            [
//                "Name" => "科技型中小企业",
//                "Level" => "国家级",
//                "Source" => "辽宁省2020年第五批入库科技型中小企业名单公告",
//                "PublishOffice" => "辽宁省科学技术厅",
//                "PublishDate" => "2020-11-30",
//                "BegingDate" => "2020-11-30",
//                "DeadLine" => "2023-11-30"
//            ]
//        ];$data = $qy_datas['z']['Result']['Data'];if(!$data){$data = [["Name" => "-","Level" => "-","Source" => "-","PublishOffice" => "-","PublishDate" => "-","BegingDate" => "-","DeadLine" => "-"]];}// 检查是否需要换页if ($pdf->GetY() + 30 > $pdf->getPageHeight()) {$pdf->AddPage(); // 换页        // 添加页眉图片$pdf->Image($headerImgPath, 0, 0, $pageWidth, $headerImgHeight, '', '', '', false, 300, '', false, false, 0);// 添加页脚图片$pdf->Image($footerImgPath, 0, 267, $pageWidth, $footerImgHeight, '', '', '', false, 300, '', false, false, 0);$pdf->SetFont($titleFont, '', 8);$pdf->SetTextColor(144, 144, 144);$pdf->Text($pdf->GetX()+8, $pdf->GetY()+2, $qy_data['Name']);$pdf->Ln(12);}// 设置背景颜色$pdf->SetFillColor(95, 183, 255);// 设置文字颜色$pdf->SetTextColor($titleTextColor[0], $titleTextColor[1], $titleTextColor[2]);$pdf->Rect($pdf->GetX(), $pdf->GetY(), $titleWidth, $titleHeight-2, 'F');$pdf->SetFont($titleFont, 'B', 12);// 在标题矩形内居中显示标题文本$titleText = ' 企业资质(如高新技术企业、创新型/科技型中小企业)';$pdf->Text(12, $pdf->GetY()+4, $titleText);//=====表格$pdf->Ln(12); // 换行// 遍历表格数据foreach ($data as $key => $val) {// 检查是否需要换页if ($pdf->GetY() + 30 > $pdf->getPageHeight()) {$pdf->AddPage(); // 换页        // 添加页眉图片$pdf->Image($headerImgPath, 0, 0, $pageWidth, $headerImgHeight, '', '', '', false, 300, '', false, false, 0);// 添加页脚图片$pdf->Image($footerImgPath, 0, 267, $pageWidth, $footerImgHeight, '', '', '', false, 300, '', false, false, 0);$pdf->SetFont($titleFont, '', 8);$pdf->SetTextColor(144, 144, 144);$pdf->Text($pdf->GetX()+8, $pdf->GetY()+2, $qy_data['Name']);$pdf->Ln(12);}// 设置字体$pdf->SetTextColor(0,0,0);$pdf->SetFont($titleFont, '', 8);$pdf->SetFillColor(244, 244, 244); // 淡灰色背景// 创建单元格$pdf->Cell(30, 10, '资质名称', 1, 0, 'C', 1);$pdf->SetFillColor(255, 255, 255); // 白色背景// 创建单元格$pdf->Cell(65, 10, $val['Name'], 1, 0, 'L', 1);$pdf->SetFillColor(244, 244, 244); // 淡灰色背景// 创建单元格$pdf->Cell(30, 10, '级别', 1, 0, 'C', 1);$pdf->SetFillColor(255, 255, 255); // 白色背景// 创建单元格$pdf->Cell(65, 10, $val['Level'], 1, 1, 'L', 1);$pdf->SetFillColor(244, 244, 244); // 淡灰色背景// 创建单元格$pdf->Cell(30, 10, '来源', 1, 0, 'C', 1);$pdf->SetFillColor(255, 255, 255); // 白色背景// 创建单元格$pdf->Cell(65, 10, $val['Source'], 1, 0, 'L', 1);$pdf->SetFillColor(244, 244, 244); // 淡灰色背景// 创建单元格$pdf->Cell(30, 10, '发布单位', 1, 0, 'C', 1);$pdf->SetFillColor(255, 255, 255); // 白色背景// 创建单元格$pdf->Cell(65, 10, $val['PublishOffice'], 1, 1, 'L', 1);$pdf->Ln(2); // 换行}//===================第二页======================$pdf->AddPage();// 添加页眉图片$pdf->Image($headerImgPath, 0, 0, $pageWidth, $headerImgHeight, '', '', '', false, 300, '', false, false, 0);// 添加页脚图片$pdf->Image($footerImgPath, 0, 267, $pageWidth, $footerImgHeight, '', '', '', false, 300, '', false, false, 0);$pdf->SetFont($titleFont, '', 8);$pdf->SetTextColor(144, 144, 144);$pdf->Text($pdf->GetX()+8, $pdf->GetY()+2, $qy_data['Name']);$pdf->Ln(12);//=============================// 设置背景颜色$pdf->SetFillColor($titleBackgroundColor[0], $titleBackgroundColor[1], $titleBackgroundColor[2]);// 设置文字颜色$pdf->SetTextColor($titleTextColor[0], $titleTextColor[1], $titleTextColor[2]);// 设置字体和字号$pdf->SetFont($titleFont, 'B', $titleFontSize);// 绘制带有背景颜色的矩形作为标题$pdf->Rect(10, 25, $titleWidth, $titleHeight, 'F');// 在标题矩形内居中显示标题文本$titleText = '企业评测结果概览';$pdf->Text(12, 29, $titleText);$pdf->Ln(); // 换行$scoreImg = 'https://******.png';$pdf->Image($scoreImg, 35, 45, 135, 45, '', '', 'C', false, 300, '', false, false, 0);
//============================分数================================$zongScore = Question::with(['record'])->where(['gp_id' => 1, 'pid' => $row['record_id'], 'state' => 0, 'record.test_log_id' => $row['id']])->order('sort','asc')->sum('record.result_value');$pdf->SetTextColor(34, 84, 244);$pdf->SetFont($titleFont, '', 19);if($zongScore>99){$pdf->Text(48, 49, $zongScore); }elseif($zongScore<10){$pdf->Text(53, 49, $zongScore);}else{$pdf->Text(50, 49, $zongScore); }$pdf->SetTextColor(50, 113, 229);$pdf->SetFont($titleFont, '', 24);if($row['score']>100){$pdf->Text(92, 62, $row['score']);}else{$pdf->Text(96, 62, $row['score']); }$pdf->SetTextColor(98, 199, 184);$pdf->SetFont($titleFont, '', 19);if($row['score']-$zongScore>99){$pdf->Text(131, 52, $row['score']-$zongScore);}else{$pdf->Text(133, 52, $row['score']-$zongScore);}$analysis = 'https://********.png';$pdf->Image($analysis, 10, 100, $titleWidth, 52, '', '', 'C', false, 300, '', false, false, 0);$pdf->SetTextColor(44,44,44);$pdf->SetFont($titleFont, '', 12);$zong = '本次报告测评结果分为【综合评汉分数】与【维度评测分数】两部分组成,总分为200分。在本次测评中,您的企业综合评测得分为X分,维度评测分数为Y分。您的综合评指标存在不足,上年度研发占比、上年度获得机构融资总额未满足,需有针对性地加强。维度评测得分<60分,专业化、精细化、特色化、创新力方面需有针对性地加强,经过专业辅导后可满足申报条件。如您的企业有申报需求,可在线咨询平台专家,专家会根据您报告得分的具体情况为您提供专业建议并制定申报辅导方案。';$pdf->MultiCell(145, 0, $zong, 0, 'L', false, 1, 52, 103, true, 0, false, true, 0, 'T', false);//=======================综合评测分数分析=======================================$pdf->SetFillColor($titleBackgroundColor[0], $titleBackgroundColor[1], $titleBackgroundColor[2]);// 设置文字颜色$pdf->SetTextColor($titleTextColor[0], $titleTextColor[1], $titleTextColor[2]);// 设置字体和字号$pdf->SetFont($titleFont, 'B', $titleFontSize);// 绘制带有背景颜色的矩形作为标题$pdf->Rect(10, 166, $titleWidth, $titleHeight, 'F');// 在标题矩形内居中显示标题文本$titleText = '综合评测分数分析';$pdf->Text(12, 170, $titleText);//============================已满足条件分析==============$pdf->Ln(12); // 换行
//        $pdf->SetFont($titleFont, '', 12);
//        $pdf->SetFillColor(95, 183, 255);
//        $pdf->SetTextColor($titleTextColor[0], $titleTextColor[1], $titleTextColor[2]);
//        $pdf->Rect(10, 174, $titleWidth, $titleHeight-2, 'F');
//        $pdf->Text(12, 178, '已满足条件分析');//        $pdf->Ln(14); // 换行// 设置字体$pdf->SetTextColor(0,0,0);$pdf->SetFont($titleFont, '', 8);// 表格数据$data = Question::with(['record'])->where(['gp_id' => 1, 'pid' => $row['record_id'], 'state' => 0, 'record.test_log_id' => $row['id']])->order('sort','asc')->select();
//        echo json_encode($data);
//        $data = [
//            '从事特定细分市场时间达到2年以上',
//            '企业从事特定细分市场已有2年以上,满足条件。',
//        ];// 自定义排序函数,根据 result_value 的值进行排序usort($data, function($a, $b) {if ($a['record']['result_value'] > 0 && $b['record']['result_value'] <= 0) {return -1; // $a 在 $b 之前} elseif ($a['record']['result_value'] <= 0 && $b['record']['result_value'] > 0) {return 1; // $a 在 $b 之后} else {return 0; // 保持原来的顺序}});
//        echo json_encode($datas);// 遍历表格数据$is_true = 0;$is_false = 0;foreach ($data as $key => $val) {if($key < 6){//判断第6题是否选择正确,暂时用下面的空字符串和null判断
//                if($key == 5){
//                    $select_data = QuestionSelect::where(['record_id' => $val['record']['id']])->value('select_data');
//                    $val['record']['result_value']=1;
//                }
//==========已满足、未满足大标题// 检查是否需要换页if ($pdf->GetY() + 35 > $pdf->getPageHeight()) {$pdf->AddPage(); // 换页        // 添加页眉图片$pdf->Image($headerImgPath, 0, 0, $pageWidth, $headerImgHeight, '', '', '', false, 300, '', false, false, 0);// 添加页脚图片$pdf->Image($footerImgPath, 0, 267, $pageWidth, $footerImgHeight, '', '', '', false, 300, '', false, false, 0);$pdf->SetFont($titleFont, '', 8);$pdf->SetTextColor(144, 144, 144);$pdf->Text($pdf->GetX()+8, $pdf->GetY()+2, $qy_data['Name']);$pdf->Ln(12); // 换行}if($val['record']['result_value']>0 || ($val['record']['result_value']==0 && $val['record']['data'] === '')){if($is_true == 0){$pdf->Ln(); // 换行$pdf->SetFont($titleFont, 'B', 12);$pdf->SetFillColor(95, 183, 255);$pdf->SetTextColor($titleTextColor[0], $titleTextColor[1], $titleTextColor[2]);$pdf->Rect($pdf->GetX(), $pdf->GetY()-6, $titleWidth, $titleHeight-2, 'F');$pdf->Text($pdf->GetX(), $pdf->GetY()-2, '  已满足条件分析');$pdf->Ln(12); // 换行$is_true = 1;}$pdf->SetTextColor(95, 188, 102);$successImg = 'https://**********.png';}else{if($is_false == 0){$pdf->Ln(); // 换行$pdf->SetFont($titleFont, 'B', 12);$pdf->SetFillColor(95, 183, 255);$pdf->SetTextColor($titleTextColor[0], $titleTextColor[1], $titleTextColor[2]);$pdf->Rect($pdf->GetX(), $pdf->GetY()-6, $titleWidth, $titleHeight-2, 'F');$pdf->Text($pdf->GetX(), $pdf->GetY()-2, '未满足条件分析');$pdf->Ln(12); // 换行$is_false = 1;}$pdf->SetTextColor(239, 56, 34);$successImg = 'https://**********.png';}// 检查是否需要换页if ($pdf->GetY() + 35 > $pdf->getPageHeight()) {$pdf->AddPage(); // 换页        // 添加页眉图片$pdf->Image($headerImgPath, 0, 0, $pageWidth, $headerImgHeight, '', '', '', false, 300, '', false, false, 0);// 添加页脚图片$pdf->Image($footerImgPath, 0, 267, $pageWidth, $footerImgHeight, '', '', '', false, 300, '', false, false, 0);$pdf->SetFont($titleFont, '', 8);$pdf->SetTextColor(144, 144, 144);$pdf->Text($pdf->GetX()+8, $pdf->GetY()+2, $qy_data['Name']);$pdf->Ln(12); // 换行}$pdf->SetFillColor(233, 233, 233); // 淡灰色背景$pdf->Cell(10, 10, '', ['LTB' => ['width' => 0.1, 'color' => [233, 233, 233]]],0,'L',1);$pdf->SetFont($titleFont, '', 10);$pdf->Cell($titleWidth-30, 10, $val['name'], ['LTRB' => ['width' => 0.1, 'color' => [233, 233, 233]]], 0, 'L', 1);$pdf->SetTextColor(0, 0, 0);$pdf->Cell(20, 10, '', ['LTRB' => ['width' => 0.1, 'color' => [233, 233, 233]]], 1, 'L', 1);$pdf->Image($successImg, $pdf->GetX() + 3, $pdf->GetY()-8, 5);$pdf->SetFillColor(255, 255, 255); // 白色背景$pdf->SetTextColor(0, 140, 255);if($key == 5 && $val['record']['data'] === null){   //第六题没有分数判断data为null还是空字符串$content = '企业已满足1.近三年获得过省级科技奖励,并排名前三2.近三年获得国家级科技奖励,并在获奖单位中排名前五3.近两年研发费用总额均值在1000万元以上4.近两年新增股权融资总额(合格机构投资者实缴金额)达到6000万元以上4.近三年进入“创客中国”中小企业创新创业大赛全国500强企业#其中一项或多项,满足条件。';$contentHeight = $pdf->GetStringHeight($tWidth + 130,$content);$rowHeight = max(10, $contentHeight); // 行高度,取标题和内容高度的最大值$pdf->Cell(25, $contentHeight, '【大师兄点评】', ['LTB' => ['width' => 0.1, 'color' => [233, 233, 233]]],0,'L',0);$pdf->SetTextColor(144, 144, 144);$pdf->MultiCell($tWidth + 135, $rowHeight, $content, ['TRB' => ['width' => 0.1, 'color' => array(233, 233, 233)]], 'L', 0, 1,'', '', true, 0, false, true, $rowHeight, 'M');$pdf->Ln(2); // 换行}elseif ($key == 5 && $val['record']['data'] === ''){$content = '企业已满足1.近三年获得过省级科技奖励,并排名前三2.近三年获得国家级科技奖励,并在获奖单位中排名前五3.近两年研发费用总额均值在1000万元以上4.近两年新增股权融资总额(合格机构投资者实缴金额)达到6000万元以上4.近三年进入“创客中国”中小企业创新创业大赛全国500强企业#其中一项或多项,满足条件。';$contentHeight = $pdf->GetStringHeight($tWidth + 130,$content);$rowHeight = max(10, $contentHeight); // 行高度,取标题和内容高度的最大值$pdf->Cell(25, $contentHeight, '【大师兄点评】', ['LTB' => ['width' => 0.1, 'color' => [233, 233, 233]]],0,'L',0);$pdf->SetTextColor(144, 144, 144);$pdf->MultiCell($tWidth + 135, $rowHeight, $content, ['TRB' => ['width' => 0.1, 'color' => array(233, 233, 233)]], 'L', 0, 1,'', '', true, 0, false, true, $rowHeight, 'M');}else{$content = \app\admin\model\question\Tips::where(['group_id' => $val['standard_group'],'result_value' => $val['record']['result_value']])->value('content');$contentHeight = $pdf->GetStringHeight($tWidth + 130,$content);$rowHeight = max(10, $contentHeight); // 行高度,取标题和内容高度的最大值$pdf->Cell(25, $rowHeight, '【大师兄点评】', ['LTB' => ['width' => 0.1, 'color' => [233, 233, 233]]],0,'L',0);$pdf->SetTextColor(144, 144, 144);$pdf->MultiCell($tWidth + 135, $rowHeight, $content, ['TRB' => ['width' => 0.1, 'color' => array(233, 233, 233)]], 'L', 0, 1,'', '', true, 0, false, true, $rowHeight, 'M');$pdf->Ln(2); // 换行}}}//=======================维度评测分数分析=======================================$pdf->SetFillColor($titleBackgroundColor[0], $titleBackgroundColor[1], $titleBackgroundColor[2]);// 设置文字颜色$pdf->SetTextColor($titleTextColor[0], $titleTextColor[1], $titleTextColor[2]);// 设置字体和字号$pdf->SetFont($titleFont, 'B', $titleFontSize);// 绘制带有背景颜色的矩形作为标题$pdf->Rect($pdf->GetX(), $pdf->GetY()+4, $titleWidth, $titleHeight, 'F');// 在标题矩形内居中显示标题文本$titleText = '维度评测分数分析';$pdf->Text($pdf->GetX()+2, $pdf->GetY()+7, $titleText);//专业化$zScore = Question::with(['record'])->where(['gp_id' => 2, 'pid' => $row['record_id'], 'state' => 0, 'record.test_log_id' => $row['id']])->order('sort','asc')->sum('record.result_value');//精细化$jScore = Question::with(['record'])->where(['gp_id' => 3, 'pid' => $row['record_id'], 'state' => 0, 'record.test_log_id' => $row['id']])->order('sort','asc')->sum('record.result_value');//新颖化$xScore = Question::with(['record'])->where(['gp_id' => 4, 'pid' => $row['record_id'], 'state' => 0, 'record.test_log_id' => $row['id']])->order('sort','asc')->sum('record.result_value');//特色化$tScore = Question::with(['record'])->where(['gp_id' => 5, 'pid' => $row['record_id'], 'state' => 0, 'record.test_log_id' => $row['id']])->order('sort','asc')->sum('record.result_value');
//============================雷达图============================$pdf->Ln(); // 换行
//        // =================创建雷达图$values = array($jScore,$zScore,$xScore,$tScore);$graph = $this->createRadarGraph($values);// 将雷达图输出到缓冲区ob_start();$graph->Stroke();$imgData = ob_get_clean();// 将雷达图插入 PDF$pdf->Image('@' . $imgData, $pdf->GetX()+42, $pdf->GetY()+16, 100, 100, '', '', 'C', false, 300, '', false, false, 0);
// -----------------------四维度分数----------------------------------$pdf->SetTextColor(0, 0, 0);$pdf->SetFont($titleFont, 'B', 14);$pdf->Text(95, $pdf->GetY()+10, '精细化');$pdf->SetFont($titleFont, '', 10);$pdf->Text(95, $pdf->GetY()+10, '评分:');$pdf->SetTextColor(239, 56, 34);$pdf->Text(106, $pdf->GetY(), $jScore);$pdf->SetTextColor(0, 0, 0);$pdf->SetFont($titleFont, 'B', 14);$pdf->Text(45, $pdf->GetY()+38, '专业化');$pdf->SetFont($titleFont, '', 10);$pdf->Text(45, $pdf->GetY()+11, '评分:');$pdf->SetTextColor(239, 56, 34);$pdf->Text(56, $pdf->GetY(), $zScore);$pdf->SetTextColor(0, 0, 0);$pdf->SetFont($titleFont, 'B', 14);$pdf->Text(145, $pdf->GetY()-11, '特色化');$pdf->SetFont($titleFont, '', 10);$pdf->Text(145, $pdf->GetY()+10, '评分:');$pdf->SetTextColor(239, 56, 34);$pdf->Text(156, $pdf->GetY(), $tScore);$pdf->SetTextColor(0, 0, 0);$pdf->SetFont($titleFont, 'B', 14);$pdf->Text(95, $pdf->GetY()+40, '新颖化');$pdf->SetFont($titleFont, '', 10);$pdf->Text(95, $pdf->GetY()+10, '评分:');$pdf->SetTextColor(239, 56, 34);$pdf->Text(106, $pdf->GetY(), $xScore);//================$pdf->Ln(); // 换行$pdf->SetFillColor(237, 237, 237);$pdf->SetTextColor(0,0,0);$pdf->SetFont($titleFont, '', 12);// 绘制带有背景颜色的矩形作为标题$pdf->Rect($pdf->GetX(), $pdf->GetY()+4, $titleWidth, 20, 'F');// 在标题矩形内居中显示标题文本$titleText = '当前企业维度评分为';$pdf->Text(45, $pdf->GetY()+8, $titleText);$pdf->SetTextColor(239, 56, 34);$pdf->SetFont($titleFont, '', 18);$titleText = $zScore + $tScore + $xScore + $jScore;$pdf->Text(84, $pdf->GetY()-2, $titleText);$pdf->SetTextColor(0,0,0);$pdf->SetFont($titleFont, '', 12);$titleText = '分,评分高代表该维度指标最强,';$pdf->Text(93, $pdf->GetY()+2, $titleText);$titleText = '评分低代表该指标有待提高,详细分析见下方。';$pdf->Text(55, $pdf->GetY()+8, $titleText);$pdf->Ln(); // 换行//=========================各维度$pdf->AddPage(); // 换页$pdf->Image($headerImgPath, 0, 0, $pageWidth, $headerImgHeight, '', '', '', false, 300, '', false, false, 0);$pdf->Image($footerImgPath, 0, 267, $pageWidth, $footerImgHeight, '', '', '', false, 300, '', false, false, 0);$pdf->SetFont($titleFont, '', 8);$pdf->SetTextColor(144, 144, 144);$pdf->Text($pdf->GetX()+8, $pdf->GetY()+2, $qy_data['Name']);$pdf->Ln(12); // 换行$data = Question::with(['record'])
//            ->where(['gp_id' => ['in','2,3,4,5'], 'pid' => $row['record_id'], 'state' => 0, 'record.test_log_id' => $row['id']])->where(['gp_id' => ['in','2,3,4,5'], 'pid' => $row['record_id'], 'state' => 0, 'record.test_log_id' => $row['id']])->order('sort','asc')->select();
//        return json_encode($data);
//1综合指标,2专业化,3精细化,4创新力,5特色化$wei = [0 => ['name'=>'专业化','score' => 25,'gScore' => $zScore],4 => ['name'=>'精细化','score' => 25,'gScore' => $jScore],8 => ['name'=>'新颖化','score' => 35,'gScore' => $xScore],12 => ['name'=>'特色化','score' => 15,'gScore' => $tScore],];//==========$lastKey = count($data)-1;foreach ($data as $key => $val){// 检查是否需要换页if ($pdf->GetY() + 30 > $pdf->getPageHeight()) {$pdf->AddPage(); // 换页        // 添加页眉图片$pdf->Image($headerImgPath, 0, 0, $pageWidth, $headerImgHeight, '', '', '', false, 300, '', false, false, 0);// 添加页脚图片$pdf->Image($footerImgPath, 0, 267, $pageWidth, $footerImgHeight, '', '', '', false, 300, '', false, false, 0);$pdf->SetFont($titleFont, '', 8);$pdf->SetTextColor(144, 144, 144);$pdf->Text($pdf->GetX()+8, $pdf->GetY()+2, $qy_data['Name']);$pdf->Ln(8); // 换行}if($key == 0 || $key == 4 || $key == 8 || $key == 12){$pdf->Ln(2); // 换行$pdf->SetFillColor(95, 183, 255);$pdf->SetFont($titleFont, '', 12);$pdf->SetTextColor($titleTextColor[0], $titleTextColor[1], $titleTextColor[2]);$pdf->Rect($pdf->GetX(), $pdf->GetY(), $titleWidth, $titleHeight-2, 'F');$pdf->Text($pdf->GetX()+4, $pdf->GetY()+4, $wei[$key]['name']);
//                $pdf->SetY($pdf->GetY()+4);
//                $pdf->Ln(); // 换行//=========得分框======// 设置边框颜色和填充颜色$pdf->SetDrawColor(148, 172, 250);   // 边框颜色$pdf->SetFillColor(255,255,255);// 绘制圆角长方体的框$width = 50; // 框的宽度$height = 30; // 框的高度$pdf->RoundedRect(10, $pdf->GetY()+10, $width, $height, 2, '1111', 'DF');
//                $pdf->SetY($pdf->GetY()+$height+8);//得分$pdf->SetFont($titleFont, 'B', 32);$pdf->SetTextColor(0,0,0);if($wei[$key]['gScore']<=9){$pdf->Text(30, $pdf->GetY()+15, $wei[$key]['gScore']);}else{$pdf->Text(28, $pdf->GetY()+15, $wei[$key]['gScore']);}//满分$pdf->SetFont($titleFont, 'B', 12);$pdf->SetTextColor(118, 118, 119);$pdf->Text(24, $pdf->GetY()+15, '满分 '.$wei[$key]['score'] . ' 分');
//=========得分条======// 设置底部进度条的位置和尺寸$progressX = 80;$progressY = $pdf->GetY()-5;$progressWidth = 100;$progressHeight = 8;$cornerRadius = 2; // 圆角半径// 设置进度条颜色$progressColor = [71, 136, 255]; // 蓝色// 设置进度百分比(0-100)$progressPercentage = $wei[$key]['gScore'] / $wei[$key]['score'] * 100;// 计算实际进度条的宽度$actualProgressWidth = $progressWidth * ($progressPercentage / 100);// 绘制底部进度条背景(灰色部分)$pdf->SetFillColor(200, 200, 200); // 灰色$pdf->RoundedRect($progressX, $progressY, $progressWidth, $progressHeight, $cornerRadius, '1111', 'DF');// 绘制实际进度// 定义渐变颜色
//                $startColor = [173, 205, 255]; // 浅蓝色
//                $endColor = [71, 136, 255];      // 深蓝色// 创建线性渐变
//                $gradient = $pdf->LinearGradient($progressX, $progressY, $actualProgressWidth, $progressHeight, $startColor, $endColor);
//                $pdf->SetFillColor($gradient);
//                $pdf->SetFillColor($progressColor);if($wei[$key]['gScore'] != 0){$pdf->RoundedRect($progressX, $progressY, $actualProgressWidth, $progressHeight, $cornerRadius, '1111', 'DF','',$progressColor);}// 在进度条内显示数值$textX = $progressX + $actualProgressWidth - 8; // 设置文本位置的 x 坐标$textY = $progressY + $progressHeight / 2 - 14; // 设置文本位置的 y 坐标$pdf->SetFont($titleFont, '', 16);$pdf->SetTextColor(240, 74, 54);$pdf->Text($textX, $textY, $wei[$key]['gScore'] . ' 分');//进度条两边分数$pdf->SetFont($titleFont, '', 12);$pdf->SetTextColor(164, 164, 164);$pdf->Text($progressX - 12, $progressY+2, '0 分');$pdf->Text($progressX+103, $progressY+2, $wei[$key]['score'] . ' 分');$pdf->Ln(14); // 换行}//========建议===$pdf->Ln(4); // 换行$pdf->SetFillColor(233, 233, 233); // 淡灰色背景$pdf->Cell(5, 10, '', ['LTB' => ['width' => 0.1, 'color' => [233, 233, 233]]],0,'L',1);$pdf->SetFont($titleFont, '', 10);$pdf->SetTextColor(0, 0, 0);$pdf->Cell($titleWidth-25, 10, $val['name'], ['LTRB' => ['width' => 0.1, 'color' => [233, 233, 233]]], 0, 'L', 1);$pdf->Cell(20, 10, '得分:'.intval($val['record']['result_value']).'分', ['LTRB' => ['width' => 0.1, 'color' => [233, 233, 233]]], 1, 'L', 1);// 检查是否需要换页if ($pdf->GetY() + 30 > $pdf->getPageHeight()) {$pdf->AddPage(); // 换页        // 添加页眉图片$pdf->Image($headerImgPath, 0, 0, $pageWidth, $headerImgHeight, '', '', '', false, 300, '', false, false, 0);// 添加页脚图片$pdf->Image($footerImgPath, 0, 267, $pageWidth, $footerImgHeight, '', '', '', false, 300, '', false, false, 0);$pdf->SetFont($titleFont, '', 8);$pdf->SetTextColor(144, 144, 144);$pdf->Text($pdf->GetX()+8, $pdf->GetY()+2, $qy_data['Name']);$pdf->Ln(12); // 换行}$contentHeight = $pdf->GetStringHeight($tWidth + 130,$val['option_answer']);$rowHeight = max(10, $contentHeight); // 行高度,取标题和内容高度的最大值$pdf->SetTextColor(106, 192, 112);$pdf->SetFont($titleFont, '', 10);$pdf->Cell(2, $rowHeight, '', ['LTB' => ['width' => 0.1, 'color' => [233, 233, 233]]],0,'L',0);$pdf->MultiCell($tWidth + 138, $rowHeight, '满分指标:'.$val['option_answer'], ['TB' => ['width' => 0.1, 'color' => array(233, 233, 233)]], 'L', 0, 0,'', '', true, 0, false, true, $rowHeight, 'M');$pdf->Cell(20, $rowHeight, '满分:'.$val['option_score'].'分', ['TRB' => ['width' => 0.1, 'color' => [233, 233, 233]]],1,'L',0);// 检查是否需要换页if ($pdf->GetY() + 30 > $pdf->getPageHeight()) {$pdf->AddPage(); // 换页        // 添加页眉图片$pdf->Image($headerImgPath, 0, 0, $pageWidth, $headerImgHeight, '', '', '', false, 300, '', false, false, 0);// 添加页脚图片$pdf->Image($footerImgPath, 0, 267, $pageWidth, $footerImgHeight, '', '', '', false, 300, '', false, false, 0);$pdf->SetFont($titleFont, '', 8);$pdf->SetTextColor(144, 144, 144);$pdf->Text($pdf->GetX()+8, $pdf->GetY()+2, $qy_data['Name']);$pdf->Ln(12); // 换行}
//=============特色化建议区分===if($val['gp_id'] == 5 && $key == $lastKey){
//                    echo $key.'==='.count($data);die;if($tScore <= 4){$result_value = 4;}elseif($tScore > 4 && $tScore <= 10){$result_value = 10;}elseif($tScore > 10 && $tScore <= 15){$result_value = 15;}$content = \app\admin\model\question\Tips::where(['group_id' => 'GP_5','result_value' => $result_value])->value('content');$contentHeight = $pdf->GetStringHeight($tWidth + 130,$content);$rowHeight = max(10, $contentHeight); // 行高度,取标题和内容高度的最大值$pdf->SetTextColor(0, 140, 255);$pdf->Cell(25, $rowHeight, '【大师兄建议】', ['LTB' => ['width' => 0.1, 'color' => [233, 233, 233]]],0,'L',0);$pdf->SetTextColor(144, 144, 144);$pdf->MultiCell($tWidth + 135, $rowHeight, $content, ['TRB' => ['width' => 0.1, 'color' => array(233, 233, 233)]], 'L', 0, 1,'', '', true, 0, false, true, $rowHeight, 'M');}elseif($val['gp_id'] != 5){$content = \app\admin\model\question\Tips::where(['group_id' => $val['standard_group'],'result_value' => $val['record']['result_value']])->value('content');$contentHeight = $pdf->GetStringHeight($tWidth + 130,$content);$rowHeight = max(10, $contentHeight); // 行高度,取标题和内容高度的最大值$pdf->SetTextColor(0, 140, 255);$pdf->Cell(25, $rowHeight, '【大师兄建议】', ['LTB' => ['width' => 0.1, 'color' => [233, 233, 233]]],0,'L',0);$pdf->SetTextColor(144, 144, 144);$pdf->MultiCell($tWidth + 135, $rowHeight, $content, ['TRB' => ['width' => 0.1, 'color' => array(233, 233, 233)]], 'L', 0, 1,'', '', true, 0, false, true, $rowHeight, 'M');}}$pdf->Ln(17); // 换行// 检查是否需要换页if ($pdf->GetY() + 30 > $pdf->getPageHeight()) {$pdf->AddPage(); // 换页        // 添加页眉图片$pdf->Image($headerImgPath, 0, 0, $pageWidth, $headerImgHeight, '', '', '', false, 300, '', false, false, 0);// 添加页脚图片$pdf->Image($footerImgPath, 0, 267, $pageWidth, $footerImgHeight, '', '', '', false, 300, '', false, false, 0);$pdf->SetFont($titleFont, '', 8);$pdf->SetTextColor(144, 144, 144);$pdf->Text($pdf->GetX()+8, $pdf->GetY()+2, $qy_data['Name']);$pdf->Ln(12); // 换行}$pdf->SetTextColor(125, 125, 125);$content = '更详尽的专精特新企业分析报告,请联系平台客服400-123-123,或直接进入《专精特新专区》在线咨询,上千专家在线为您解读报告!';$pdf->MultiCell(145, 30, $content, 0, 'L');$imgPath = 'https://***********.png';$pdf->Image($imgPath, 170, $pdf->GetY()-40, 30, 30, '', '', 'C', false, 300, '', false, false, 0);//Close and output PDF document$file = ROOT_PATH.'/public/uploads/'. $qy_data['report_number'] .'.pdf';$pdf->Output($file, 'FI');

上几个效果图

封面
企业信息
评测分析
雷达图
维度信息

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【代码】表格封装 + 高级查询 + 搜索 +分页器 (极简)

一、标题 查询条件按钮&#xff08;Header&#xff09; <!-- Header 标题搜索栏 --> <template><div><div class"header"><div class"h-left"><div class"title"><div class"desc-test">…

vscode 搭建STM32开发环境

1.需要软件 1.1 vscode 1.2 STM32CubeMX&#xff0c;这个不是必须的&#xff0c;我是为了方便生成STM32代码 2.vscode配置 2.1安装keil Assistant 2.2配置keil Assistant 3.STMCUBE生成个STM32代码 &#xff0c;如果有自己的代码可以忽略 4.代码添加到vscode&#xff0c;并…

简单程度与自负是否相关?探索STM32的学习价值

事实上&#xff0c;无论STM32是否简单并不重要&#xff0c;更重要的是我们能通过学习STM32获得什么。通过STM32&#xff0c;我们可以学习到许多知识&#xff1a;如果我们制作一个键盘或鼠标&#xff0c;我们可以学习USB协议。如果我们制作一个联网设备&#xff0c;我们需要学习…

完整版:TCP、UDP报文格式

目录 TCP报文格式 报文格式 报文示例 UDP报文格式 报文格式 报文示例 TCP报文格式 报文格式 图1 TCP首部格式 字段长度含义Source Port16比特源端口&#xff0c;标识哪个应用程序发送。Destination Port16比特目的端口&#xff0c;标识哪个应用程序接收。Sequence Numb…

Spring Boot读取yml或者properties配置信息

文章目录 Spring Boot读取yml或者properties配置信息方法一&#xff1a;Value获取基本信息&#xff0c;适用于少量信息方法二&#xff1a;通过注解ConfigurationProperties(prefix "spring.datasource")方法三&#xff1a;通过api Environment Spring Boot读取yml或…

第01天 什么是CSRF ?

✅作者简介&#xff1a;大家好&#xff0c;我是Leo&#xff0c;热爱Java后端开发者&#xff0c;一个想要与大家共同进步的男人&#x1f609;&#x1f609; &#x1f34e;个人主页&#xff1a;Leo的博客 &#x1f49e;当前专栏&#xff1a; 每天一个知识点 ✨特色专栏&#xff1…

Spring 知识点

Spring 1.1 Spring 简介 1.1.1 Spring 概念 Spring是一个轻量级Java开发框架&#xff0c;最早有Rod Johnson创建为了解决企业级应用开发的业务逻辑层和其他各层的耦合问题Spring最根本的使命是解决企业级应用开发的复杂性&#xff0c;即简化Java开发。使现有的技术更加容易使…

统信UOS下eclipse使用lombok报错的问题

lombok不兼容问题 lombok不支持高版本jdk&#xff0c;本人在应用商店下载eclipse安装的&#xff0c;默认用的jdk17&#xff0c;不兼容lombok插件&#xff0c;需要调整eclipse.ini配置文件&#xff0c;如下&#xff1a; #/opt/apps/org.eclipse.java-ee/files/eclipse.ini -ja…

静态网页加速器:优化性能和交付速度的 Node.js 最佳实践

如何使用 Node.js 发布静态网页 在本文中&#xff0c;我们将介绍如何使用 Node.js 来发布静态网页。我们将创建一个简单的 Node.js 服务器&#xff0c;将 HTML 文件作为响应发送给客户端。这是一个简单而灵活的方法&#xff0c;适用于本地开发和轻量级应用。 1、创建静态网页…

虚幻引擎游戏开发过程中,游戏鼠标如何双击判定?

UE虚幻引擎对于游戏开发者来说都不陌生&#xff0c;市面上有47%主机游戏使用虚幻引擎开发游戏。作为是一款游戏的核心动力&#xff0c;它的功能十分完善&#xff0c;囊括了场景制作、灯光渲染、动作镜头、粒子特效、材质蓝图等。本文介绍了虚幻引擎游戏开发过程中游戏鼠标双击判…

【STM32】小电流FOC驱控一体板(开源)

FOC驱控一体板http://链接: https://pan.baidu.com/s/12HoV9yDlMC5QVGNCJ5tK0w 提取码: 1111 主控芯片stm32f103c8t6 驱动芯片drv8313 三相电流采样 根据B站一个UP主的改的&#xff08;【【自制】年轻人的第一块FOC驱动器】&#xff09;&#xff0c;大多数元器件是0805&…

c语言--浮点数(float)与0值比较

我们定义一个float类型的数据a&#xff0c;赋值为123456789并输出&#xff1a; int main() {float a;a 123456789;printf("%f\n",a);return 0; }输出结果为&#xff1a; 由此可以看出&#xff0c;程序输出的结果并不是其被赋予的值。即说明了浮点数存在一定的误差。…

STM32入门——ADC模数转换

ADC简介 ADC&#xff08;Analog-Digital Converter&#xff09;模拟-数字转换器ADC可以将引脚上连续变化的模拟电压转换为内存中存储的数字变量&#xff0c;建立模拟电路到数字电路的桥梁12位逐次逼近型ADC&#xff0c;1us转换时间输入电压范围&#xff1a;0~3.3V&#xff0c;…

第三天课程上午

1.Vue生命周期和生命周期的四个阶段 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content&…

WebRTC | 音视频直播客户端框架

端到端通信互动技术可分解为以下几个技术难点&#xff1a;客户端技术、服务器技术、全球设备网络适配技术和通信互动质量监控与展示技术。 一、音视频直播 音视频直播可分成两条技术路线&#xff1a;一条是以音视频会议为代表的实时互动直播&#xff1b;另一条是以娱乐直播为代…

文章被限流了?上不了热榜?

文章目录 惨&#xff01;惨&#xff01;&#xff01;惨&#xff01;&#xff01;&#xff01;热榜&#x1f525;热榜&#x1f525;&#x1f525;热榜&#x1f525;&#x1f525;&#x1f525;粉丝破万INSCODE AI 创作 1INSCODE AI 创作 2INSCODE AI 创作 3联系客服 最近不知道C…

【Windows系统】磁盘、Partition和Volume的联系与区别

1、磁盘 Disk&#xff0c;磁盘。 以下摘自微软 磁盘设备和分区 - Win32 apps | Microsoft Learn 硬盘由一组堆积的盘片组成&#xff0c;其中每个盘片的数据都以电磁方式存储在同心圆或 轨道中。 每个盘片都有两个头&#xff0c;一个在盘片的两侧&#xff0c;在磁盘旋转时读取…

企业服务器数据库中了devos勒索病毒怎么办如何解决预防勒索病毒攻击

随着科学技术的不断发展&#xff0c;计算机可以帮助我们完成很多重要的工作&#xff0c;但是随之而来的网络威胁也不断提升。近期&#xff0c;我们收到很多企业的求助&#xff0c;企业的服务器数据库遭到了devos勒索病毒攻击&#xff0c;导致系统内部的许多重要数据被加密无法正…

【高频面试题】微服务篇

文章目录 Spring Cloud1.Spring Cloud 5大组件有哪些&#xff1f;2.服务注册和发现是什么意思&#xff1f;Spring Cloud 如何实现服务注册发现&#xff1f;3.负载均衡如何实现的 ?4.什么是服务雪崩&#xff0c;怎么解决这个问题&#xff1f;5.微服务是怎么监控的 业务相关6.项…

ubuntu上安装mosquitto服务

1、mosquitto是什么 Mosquitto 项目最初由 IBM 和 Eurotech 于 2013 年开发&#xff0c;后来于 2016 年捐赠给 Eclipse 基金会。Eclipse Mosquitto 基于 Eclipse 公共许可证(EPL/EDL license)发布&#xff0c;用户可以免费使用。作为全球使用最广的 MQTT 协议实现之一 &#x…