当前位置: 首页 > news >正文

HTML转PDF模板

一、准备pom依赖

       <dependency><groupId>com.itextpdf</groupId><artifactId>html2pdf</artifactId><version>1.0.2</version></dependency><dependency><groupId>org.freemarker</groupId><artifactId>freemarker</artifactId><version>2.3.28</version></dependency>

二、准备sparePartsProcurePoCatalogTemplate.html     

相对路径:templates\attrchs\sparePartsProcurePoCatalogTemplate.html

<!DOCTYPE html>
<html>
<meta charset='utf-8'>
<style type='text/css'>body {margin: 0;}.pdfdom {/* width: 900px; */background: #fff;box-sizing: border-box;}.clearfix {clear: both;height: 0;overflow: hidden;align: center}.pdfdom .a4-container {background: #fff;border: 1px solid #ddd;box-sizing: border-box;position: relative;}.pdfdom .a4-container .delivery-title {border-bottom: 2px solid #ddd;box-sizing: border-box;}.pdfdom .a4-container .delivery-title img {width: 100px;box-sizing: border-box;padding-left: 10px;}.pdfdom .a4-container .delivery-title .title {margin: 0;height: 88px;line-height: 88px;margin-left: 30px;}.pdfdom .a4-container .delivery-title .delivery-company-name {float: left;font-weight: bold;line-height: 10px;margin: 15px 0px 0px 25px;}.pdfdom .a4-container .delivery-title .allocate-code {width: 200px;line-height: 15px;font-size: 12px;float: left;margin: 28px 0px 0px 8px;}.pdfdom .a4-container .main-content {border-bottom: 1px solid #ddd;}.pdfdom .a4-container .main-content table tr th,.pdfdom .a4-container .main-content table tr td {border-right: 1px solid #ddd;border-bottom: 1px solid #ddd;padding: 10px;font-size: 13px;font-weight: 700;box-sizing: border-box;}.pdfdom .a4-container .main-content table tr th:last-child,.pdfdom .a4-container .main-content table tr td:last-child {border-right: 0px solid #ddd;}.pdfdom .a4-container .test-container {border-bottom: 1px solid #ddd;display: flex;}.pdfdom .a4-container .test-container .test-container-table {/* width: 100%; */height: 300px;}.pdfdom .a4-container .test-container table tr th,.pdfdom .a4-container .test-container table tr td {border: 1px solid #ddd;padding: 10px 4px;font-size: 12px;/* width: 16%; */box-sizing: border-box;}#body-bottom table tr td {font-size: 14px;}.pdfdom .a4-container .a4-remarks {padding: 14px 10px;line-height: 20px;font-size: 16px;border-bottom: 2px solid #ddd;box-sizing: border-box;}.pdfdom .a4-container .a4-img-container {padding: 14px 10px;font-size: 20px;border-bottom: 2px solid #ddd;}.pdfdom .a4-container .a4-img-container .img-box {float: left;width: 20%;}.pdfdom .a4-container .a4-img-container .img-box .img {display: inline-block;margin: 0 auto;width: 125px;height: 125px;}.pdfdom .a4-container .bottom-content {box-sizing: border-box;}.pdfdom .a4-container .bottom-content table tr th,.pdfdom .a4-container .bottom-content table tr td {border-right: 1px solid #ddd;border-bottom: 1px solid #ddd;width: 50%;padding: 10px;font-size: 16px;vertical-align: middle}.pdfdom .a4-container .bottom-content table tr th:last-child,.pdfdom .a4-container .bottom-content table tr td:last-child {border-right: 0px solid #ddd;}.pdfdom .a4-container .bottom-content .img {height: 90px;}.green {color: #14A16A;}.red {color: #F14855;}.pdfdom .a4-container table {width: 100%;border-collapse: collapse;}.a4-remarks {padding: 14px 10px;line-height: 26px;font-size: 16px;border-bottom: 2px solid #ddd;}.a4-remarks .tc {text-align: center;}.a4-remarks .indent2 {text-indent: 2em;}.a4-remarks .indent3 {text-indent: 3em;}.a4-remarks .lt {margin-top: 15px;color: #333333;}
</style><body>
<div class='pdfdom'><div class='a4-container'><div class='delivery-title'><div style="float:left;"><img style="width: 85px; height:85px;" src=""></div><div class='delivery-company-name'><h3>采购订单</h3></div><div class='clearfix'></div></div><div class='main-content'><table><tr><td>订单时间:${orderTime!}</td><td>订单编号:${orderCode!}</td></tr><tr><td>需方(甲方):${partyAName!}</td><td>供方(乙方):${partyBName!}</td></tr><tr><td>授权代表:${demandAgent!}</td><td>授权代表:${supplierAgent!}</td></tr><tr><td>地址:${demandAddress!}</td><td>地址:${supplierAddress!}</td></tr><tr><td>联系方式:${demandContactsStyle!}</td><td>联系方式:${supplierContactsStyle!}</td></tr><tr><td colspan="2">经双方友好协议确认,根据下列条款订立本合同:</td></tr><tr><td colspan="2">一、内容:(甲方向乙方订购以下货物):</td></tr></table></div><div class='test-container'><table cellspacing="0" class="test-container-table"><tr><th width="50px">序号</th><th width="100px">零配件SKU名称</th><th width="100px">零配件SKU编码</th><th width="100px">适用车型</th><th width="100px">品牌</th><th width="100px">零配件型号</th><th width="80px">单位</th><th width="80px">数量</th><th width="100px">含税单价(元)</th><th width="100px">含税金额(元)</th><th width="80px">收货人</th><th width="120px">收货人联系方式</th><th width="100px">收货地址</th><th width="100px">预估交期</th></tr><#list a  as detail ><tr><td width="50px">${detail.sequence}</td><td width="100px">${detail.skuName}</td><td width="100px">${detail.skuCode}</td><td width="100px">${detail.brandModelName}</td><td width="100px">${detail.brandName}</td><td width="100px">${detail.modelName}</td><td width="80px">${detail.productUnitName}</td><td width="80px">${detail.purchaseQuantity}</td><td width="100px">${detail.unitPriceIncludeTax}</td><td width="100px">${detail.includeTotalAmount}</td><td width="80px">${detail.receivedPerson}</td><td width="120px">${detail.receivedPhone}</td><td width="100px">${detail.receivedAddress}</td><td width="100px">${detail.estimateTime}</td></tr></#list><tr><td colspan="2">货款合计(大写):(含税费及运费)</td><td colspan="6">${totalAmountStr!}</td><td colspan="1">小写合计</td><td colspan="5">${totalAmount!}</td></tr><tr><td colspan="2">备注</td><td colspan="12">${data.remark}</td></tr></table></div><div id="body-bottom" class='test-container'><table cellspacing="0" class="test-container-table"><tr><td colspan="2">二、本订单未约定事宜以关联采购合同编号: ${data.contractCode!}为准。</td></tr><tr><td colspan="2">三、其他约定</td></tr><tr><td colspan="2">1)收货允差天数:正三负零,即提前三天范围内交货是可以接受的,禁止晚交货。</td></tr><tr><td colspan="2">2)供方在收到订单后,请确认品名规格、数量、交期并于1个工作日内签回。</td></tr><tr><td colspan="2">3)本订单未约定的内容以框架合同为准;本订单约定的内容与框架合同不一致的,以本订单为准。</td></tr><tr><td colspan="2">4)本订单中的物料明细不在关联框架合同和补充协议的《供应商产品价格确认表》中的,关于该物料的相关约束使用本订单关联框架合同所有的条款约定 。</td></tr><tr><td colspan="2">5)本合同正本一式贰份,甲乙双方各执壹份,经双方盖章生效;甲方通过指定邮箱向乙方下达的订单与原合同具有同等效力。</td></tr><tr><td align="center">甲方</td><td align="center">乙方</td></tr><tr><td>甲 方(盖章): ${partyAName!}</td><td>乙 方(盖章): ${partyBName!}</td></tr><tr><td>授权代表(签字):</td><td>授权代表(签字):</td></tr></table></div></div>
</div>
</body></html>

三、准备转换代码

 /*** 生成 PDF 文件** @param procurePoDTO*/public void generatePdfFile(SparePartsProcurePoDTO procurePoDTO,SSOUser ssoUser) {this.generatePoCatalogPdfToOss(procurePoDTO,ssoUser);}/*** @Description 生成pdf到阿里云* @Param procurePoDTO* @Return void* @Date 2023/10/20 10:24* @Author lwp*/public String generatePoCatalogPdfToOss(SparePartsProcurePoDTO procurePoDTO,SSOUser ssoUser) {SparePartsProcurePo sparePartsProcurePo = procurePoDTO.getSparePartsProcurePo();String orderCode = sparePartsProcurePo.getOrderCode();String htmlStr = this.getHtmlFromPoCatalog(procurePoDTO);String url = "";//渲染pdfFile file = null;String name = AliOSSUtil.generateUUIDName(".pdf");try {File fileDir = new File(System.getProperty("user.dir") + "/pdf/");if (!fileDir.exists()) {fileDir.mkdirs();}file = new File(fileDir.getPath() + "/" + name);file.createNewFile();log.info("采购订单:{} 创建临时文件 {} 是否创建成功:{}", orderCode, file.getPath(), file.exists());} catch (IOException e) {log.error("采购订单:{} PDF生成失败", orderCode, e);}try (FileOutputStream fos = new FileOutputStream(file)) {PdfSupport.convertStringToPdf(htmlStr, fos);log.info("采购订单:{} 上传文件 {} 到阿里云OSS,文件大小 {} byte", orderCode, file.getName(), file.length());url = aliossClient.uploadFile(file, "/procurePo/basic/pdf/"+name);log.info("采购订单:{} PDFURL:{} 上传到阿里云OSS成功", orderCode, url);if (Objects.nonNull(ssoUser)) {uploadExcel(AliOSSHelper.getAccessUrl(url), "易维&四川泰瑞达新能源汽车有限公司-采购订单", ssoUser);}log.info("采购订单:{} PDFURL:{} 数据库更新成功", orderCode, url);} catch (IOException e) {log.error("采购订单:{} PDF生成失败", orderCode, e);} finally {if (file.exists()) {file.delete();}}return  url;}/*** @Description 解析生成html格式* @Param procurePoDTO* @Return java.lang.String* @Date 2023/10/20 10:25* @Author lwp*/public String getHtmlFromPoCatalog(SparePartsProcurePoDTO procurePoDTO) {SpareParsProcurePoCatalogTemplateData data = buildData(procurePoDTO);Map<String, Object> params = new HashMap<>();params.put("orderTime",data.getOrderTime());// 订单时间params.put("orderCode", data.getOrderCode());// 订单编号params.put("partyAName", data.getPartyAName());// 需方(甲方)params.put("partyBName", data.getPartyBName());// 供方(乙方)params.put("demandAgent", data.getDemandAgent());// 甲方授权代表params.put("supplierAgent", data.getSupplierAgent());// 乙方授权代表params.put("demandAddress", data.getDemandAddress());// 甲方地址params.put("supplierAddress", data.getSupplierAddress());// 乙方地址params.put("demandContactsStyle", data.getDemandContactsStyle());// 甲方联系方式params.put("supplierContactsStyle", data.getSupplierContactsStyle());// 乙方联系方式params.put("totalAmountStr", data.getTotalAmountStr());// 货款合计(大写):(含税费及运费)params.put("totalPurchaseQuantity", data.getTotalPurchaseQuantity());// 总数量params.put("totalAmount", data.getTotalAmount());// 小写合计params.put("contractCode", data.getContractCode());// 合同编码params.put("paymentMethodName",data.getPaymentMethodName()); //结算方式params.put("invoiceTypeName",data.getInvoiceTypeName()); //发票类型params.put("a", data.getDetails());// 采购订单明细列表return FreemarkerHelper.renderHtml("attrchs/sparePartsProcurePoCatalogTemplate.html", params);}/*** 上传到导出记录* @param url* @param fileName*/public  void uploadExcel(String url, String fileName, SSOUser ssoUser){Date date = new Date();ExportRecord exportRecord = new ExportRecord();exportRecord.setFileUrl(url);exportRecord.setFileName(fileName);exportRecord.setModule(10);exportRecord.setModuleName("零配件采购订单");//处理完成exportRecord.setStatus(2);exportRecord.setSource(0);exportRecord.setFileClassification(1);exportRecord.setRequestMethod("GET");exportRecord.setServerName("dst-operate-basic-api");exportRecord.setFileType(FileTypeConstant.PDF);exportRecord.setCreateUserId(ssoUser.getId());exportRecord.setCreateUserName(ssoUser.getRealname());exportRecord.setCreateTime(date);exportRecord.setUpdateUserId(ssoUser.getId());exportRecord.setUpdateUserName(ssoUser.getRealname());exportRecord.setUpdateTime(date);exportRecordService.save(exportRecord);}

四、转换工具 FreemarkerHelper 

package com.dst.common.service;import freemarker.cache.URLTemplateLoader;
import freemarker.template.Configuration;
import freemarker.template.Template;
import freemarker.template.TemplateException;
import lombok.extern.slf4j.Slf4j;import java.io.BufferedWriter;
import java.io.IOException;
import java.io.StringWriter;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;@Slf4j
public class FreemarkerHelper {private static Configuration config;static {config = new Configuration(Configuration.DEFAULT_INCOMPATIBLE_IMPROVEMENTS);config.setClassicCompatible(true);config.setLocalizedLookup(false);config.setDateFormat("yyyy-MM-dd");config.setDateTimeFormat("yyyy-MM-dd HH:mm:ss");config.setDefaultEncoding("UTF-8");}public static String renderHtml(String tplName, Map<String,Object> dataModel){String htmlStr = "";try {config.setClassLoaderForTemplateLoading(FreemarkerHelper.class.getClassLoader(),"/templates/");Template tpl = config.getTemplate(tplName);StringWriter stringWriter = new StringWriter();BufferedWriter writer = new BufferedWriter(stringWriter);tpl.process(dataModel,writer);htmlStr = stringWriter.toString();} catch (IOException | TemplateException e) {log.error("【renderHtml】处理html异常:",e);}return htmlStr;}public static String renderHtmlFromUrl(String tplUrl, Map<String,Object> dataModel){String htmlStr = "";try {config.setTemplateLoader(new RemoteTemplateLoader());Template tpl = config.getTemplate(tplUrl);StringWriter stringWriter = new StringWriter();BufferedWriter writer = new BufferedWriter(stringWriter);tpl.process(dataModel,writer);htmlStr = stringWriter.toString();} catch (IOException | TemplateException e) {log.error("【renderHtmlFromUrl】处理html异常:",e);}return htmlStr;}static class RemoteTemplateLoader extends URLTemplateLoader{@Overrideprotected URL getURL(String name) {URL url = null;try {url = new URL(name);} catch (MalformedURLException e) {log.error("【getURL】获取URL异常:",e);}return url;}}public static void main(String[] args) throws Exception {/*URL url = new URL("http://dst2.oss-cn-shenzhen.aliyuncs.com/test_contract_template_af3404a51225458da3ae5a587076f1cf");URLConnection connection = url.openConnection();BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream(),"UTF-8"));reader.lines().forEach(line -> System.out.println(line));*/Map<String,Object> dataModel = new HashMap<>();dataModel.put("myDate",new Date());String result = renderHtml("test.html",dataModel);System.out.println(result);//        System.out.println(InetAddress.getByName("dst2.oss-cn-shenzhen.aliyuncs.com").getHostAddress());}
}

五、HTML转PDF工具类PdfSupport

package com.dst.common.service;import com.itextpdf.html2pdf.ConverterProperties;
import com.itextpdf.html2pdf.HtmlConverter;
import com.itextpdf.html2pdf.attach.ITagWorkerFactory;
import com.itextpdf.io.font.FontProgram;
import com.itextpdf.io.image.ImageData;
import com.itextpdf.kernel.pdf.PdfDocument;
import com.itextpdf.kernel.pdf.PdfWriter;
import com.itextpdf.layout.Document;
import com.itextpdf.layout.font.FontProvider;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.OutputStream;public abstract class PdfSupport {private static final Logger LOGGER = LoggerFactory.getLogger(PdfSupport.class);public static FontProgram simsun;public static FontProgram awesome;public static ImageData logo;public static FontProvider fontProvider;public static FontProvider createFontProvider() {if (fontProvider == null){fontProvider = new FontProvider();fontProvider.addStandardPdfFonts();fontProvider.addFont(simsun);fontProvider.addFont(awesome);}return fontProvider;}protected static ConverterProperties createConverterProperties(){ConverterProperties prop = new ConverterProperties();prop.setFontProvider(createFontProvider());
//        prop.setBaseUri("/static");return prop;}public static void convertToPdf(String htmlStr, OutputStream pdfStream, ConverterProperties converterProperties) throws IOException {HtmlConverter.convertToPdf(htmlStr,pdfStream,converterProperties);}public static void convertStringToPdf(String htmlStr, OutputStream pdfStream, ITagWorkerFactory tagWorkerFactory) throws IOException {ConverterProperties converterProperties = createConverterProperties();converterProperties.setTagWorkerFactory(tagWorkerFactory);HtmlConverter.convertToPdf(htmlStr,pdfStream,converterProperties);}public static void convertStringToPdf(String htmlStr, OutputStream pdfStream) throws IOException {HtmlConverter.convertToPdf(htmlStr,pdfStream,createConverterProperties());}public static PdfDocument createPdfDocument(OutputStream outputStream) throws Exception {return new PdfDocument(new PdfWriter(outputStream));}public static Document convertToDocument(String html, PdfDocument pdfDoc, ConverterProperties prop) throws IOException {return HtmlConverter.convertToDocument(html,pdfDoc,prop);}public void outFile(String fileName, String htmlStr,HttpServletResponse response) {try {String value = "attachment;filename=" + new String((fileName + System.currentTimeMillis() + ".pdf").getBytes("gb2312"), "ISO8859-1");response.setHeader("Content-Disposition", value);response.setContentType("application/octet-stream;charset=utf-8");response.setHeader("Cache-Control", "no-cache");//设置头response.setDateHeader("Expires", 0);//设置日期头OutputStream out = response.getOutputStream();convertToPdf(htmlStr,out);out.flush();} catch (Exception e) {LOGGER.error("OutputStream error", e);}}protected abstract void convertToPdf(String htmlStr, OutputStream out) throws Exception;}

六、转换实体类

package com.dstcar.entitys.sparepartsprocurepo;import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;import java.io.Serializable;
import java.math.BigDecimal;
import java.util.Date;
import java.util.List;@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class SpareParsProcurePoCatalogTemplateData implements Serializable {/** 采购订单号 规则:CGDD+日期+流水号,按日期累加 **/private String orderCode;/** 订单日期 **/@JsonFormat(pattern = "yyyy-MM-dd",timezone = "GMT+8")private String orderTime;/** 甲方名称 **/private String partyAName;/** 乙方名称 **/private String partyBName;/** 需方授权代表 **/private String demandAgent;/** 供方授权代表 **/private String supplierAgent;/** 需方地址 **/private String demandAddress;/** 供方地址 **/private String supplierAddress;/** 需方联系方式 **/private String demandContactsStyle;/** 供方联系方式 **/private String supplierContactsStyle;/** 结算方式:1月结30天|2月结60天|3月结90天|4先款后货(字典:spare_parts_payment_method) **/private String paymentMethodName;/** 发票类型:1增值税发票2普通发票(字典:spare_parts_po_invoice_type) **/private String invoiceTypeName;/** 订单总额(产品明细含税总额合计【含税总额(含税单价unitPriceIncludeTax * 采购数量purchaseQuantity)】) **/private BigDecimal totalAmount;/*** 订单总额大写文字*/private String totalAmountStr;/*** 总的采购数量*/private BigDecimal totalPurchaseQuantity;/** 备注 **/private String remark;/** 关联合同号 **/private String contractCode;/** po订单明细 */private List<SpareParsProcurePoCatalogSkuTemplateData> details;}package com.dstcar.entitys.sparepartsprocurepo;import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;import java.io.Serializable;
import java.math.BigDecimal;@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class SpareParsProcurePoCatalogSkuTemplateData implements Serializable {/*** 序号*/private Integer sequence;/** 零配件sku名称 **/private String skuName;/** 零部件SKU编码 **/private String skuCode;/*** 适用车型名称* 备注:适用车型下拉框选择‘通用’时该字段为空*      适用车型下拉框选择‘部分车型适用’时该字段翻译(适用车型里面的品牌+型号拼接而成)*/private String brandModelName;/*** 零配件品牌名称*/private String brandName;/*** 零配件型号名称*/private String  modelName;/** 计量单位 */private String productUnitName;/** 采购数量 **/private BigDecimal purchaseQuantity;/** 含税单价 **/private BigDecimal unitPriceIncludeTax;/** 含税总额(含税单价*采购数量) **/private BigDecimal includeTotalAmount;/** 收货人 **/private String receivedPerson;/** 收货人联系电话 **/private String receivedPhone;/** 收货人地址 **/private String receivedAddress;/** 预估交期 **/@JsonFormat(pattern = "yyyy-MM-dd",timezone = "GMT+8")private String estimateTime;}

 七、最终转换效果

相关文章:

HTML转PDF模板

一、准备pom依赖 <dependency><groupId>com.itextpdf</groupId><artifactId>html2pdf</artifactId><version>1.0.2</version></dependency><dependency><groupId>org.freemarker</groupId><artifactId&g…...

Clickhouse学习笔记(14)—— Clickhouse监控

ClickHouse 运行时会将一些个自身的运行状态记录到众多系统表中&#xff0c;如下所示&#xff1a; 为了直观方便地监控ck的运行情况&#xff0c;使用Prometheus Grafana 的组合来进行监控 Prometheus 负责收集各类系统的运行指标&#xff1b;Grafana 负责可视化 Prometheus&a…...

Vue3 + Three.js + gltf-pipeline大型园区场景渲染与3D业务

在非使用unity作为3D渲染方案的前提下&#xff0c;对与目前web开发者比较友好的除了canvas场景需要的2D babylon.js&#xff0c;fabric.js, Three.js是目前针对于jsWeb用户最直接且比较友好的3D引擎方案了。 准备工作&#xff1a; 1.明确需要用的场景方案都有那些&#xff0c;模…...

基于FPGA的PS端的Si5340的控制

1、功能 Si5340/41-D可以输出任意频率&#xff0c;当然有范围&#xff0c;100Hz1GHz。外部输入为24M或者4854M的XTAL&#xff0c;VCO在13500~14256Mhz之间&#xff0c;控制接口采用IIC或者SPI。 芯片架构图 2、IIC控制方式 3、直接上控制代码 使用米联客ZU3EG&#xff0c;将…...

安装 Lua 的 HTTP 库

首先&#xff0c;你需要安装 Lua 的 HTTP 库。可以使用 LuaRocks 来安装。以下是安装命令&#xff1a; luarocks install http然后&#xff0c;你可以使用以下代码来爬取网页内容&#xff1a; local http require http-- 设置代理信息 http.set_proxy(jshk.com.cn)-- 网页UR…...

Redis解决缓存问题

目录 一、引言二、缓存三、Redis缓存四、缓存一致性1.缓存更新策略2.主动更新 五、缓存穿透六、缓存雪崩七、缓存击穿1.基于互斥锁解决具体业务2.基于逻辑过期解决具体业务 一、引言 在一些大型的网站中会有十分庞大的用户访问流量&#xff0c;而过多的用户访问对我们的MySQL数…...

七个合法学习黑客技术的网站,让你从萌新成为大佬

大家好我是若风&#xff0c;一个8年网络安全攻防经验的白帽黑客。 合法的学习网站&#xff0c;以下这些网站&#xff0c;虽说不上全方位的满足你的需求&#xff0c;但是大部分也都能。能带你了解到黑客有关的技术&#xff0c;视频&#xff0c;电子书&#xff0c;实践&#xff0…...

【数据结构】面试OJ题——带环链表(数学推论)

目录 1.环形链表Ⅰ ​编辑 思路 &#xff1a; 思路拓展 问题一&#xff1a; 问题二&#xff1a; 总结&#xff1a; 问题三&#xff1a; 证明总结第三点 总结&#xff1a; 2. 环形链表Ⅱ 思路一 思路二 3.相交链表 思路&#xff1a; 1.环形链表Ⅰ 141. 环形链…...

PostgreSQL中pg_ctl工具的使用

pg_ctl工具有以下功能&#xff1a; &#xff08;1&#xff09;初始化postgresql数据库实例 &#xff08;2&#xff09;启动、终止或重启postgresql数据库服务 &#xff08;3&#xff09;查看postgresql数据库服务的状态 &#xff08;4&#xff09;让数据库实例重新读取配置…...

深入理解Kafka3.6.0的核心概念,搭建与使用

Kafka是最初由Linkedin公司开发&#xff0c;是一个分布式、支持分区的&#xff08;partition&#xff09;、多副本的&#xff08;replica&#xff09;&#xff0c;基于zookeeper协调的分布式消息系统&#xff0c;它的最大的特性就是可以实时的处理大量数据以满足各种需求场景&a…...

【python】编程题小代码

空心题&#xff08;平行四边形&#xff09; layer int(input("请输入你要打印的行数:")) for i in range(1,layer // 2 2): space_num layer - i for j in range(0,space_num): print(" ",end "") star_num 2 * i - 1 for j in range(0,sta…...

抖音小程序开发全攻略:如何规划项目和选择合适的开发团队

在数字化时代&#xff0c;抖音小程序成为企业推广和服务的重要渠道。本文将为您提供抖音小程序开发的全面攻略&#xff0c;重点介绍如何规划项目和选择合适的开发团队&#xff0c;并附有一些关键的技术代码示例。 1. 项目规划 在开始抖音小程序开发之前&#xff0c;详细的项…...

PSP - 蛋白质复合物结构预测 模版配对(Template Pair) 逻辑的特征分析

欢迎关注我的CSDN&#xff1a;https://spike.blog.csdn.net/ 本文地址&#xff1a;https://spike.blog.csdn.net/article/details/134328447 在 蛋白质复合物结构预测 的过程中&#xff0c;模版 (Template) 起到重要作用&#xff0c;提供预测结果的关于三维结构的先验信息&…...

喜报不断!箱讯平台获评2023年上海市促进现代航运服务业创新示范项目

近期&#xff0c;可谓捷报频传&#xff01;在箱讯科技子公司苏州箱讯获评苏州市软件和信息服务业 “头雁”培育企业没过多久&#xff0c;就又迎来好消息&#xff01; 日前&#xff0c;上海市交通委发布“2023年上海市促进现代航运服务业创新项目”评选结果&#xff0c;箱讯An…...

SOME/IP学习笔记3

目录 1.SOMEIP Transformer 1.1 SOME/IP on-wire format 1.2 协议指定 2. SOMEIP TP 2.1 SOME/IP TP Header 3.小结 1.SOMEIP Transformer 根据autosar CP 相关规范&#xff0c;SOME/IP Transformer主要用于将SOME/IP格式的数据序列化&#xff0c;相当于一个转换器。总体…...

【ATTCK】ATTCK开源项目Caldera学习笔记

CALDERA是一个由python语言编写的红蓝对抗工具&#xff08;攻击模拟工具&#xff09;。它是MITRE公司发起的一个研究项目&#xff0c;该工具的攻击流程是建立在ATT&CK攻击行为模型和知识库之上的&#xff0c;能够较真实地APT攻击行为模式。 通过CALDERA工具&#xff0c;安全…...

黑窗口连接远程服务

ssh root192.168.x.x 回车输入密码 查看docker docker ps 停止正在运行的服务 docker stop xxxxx 删除服务 docker rm xxxxx 查看镜像 docker images 删除镜像 docker rmi xxxxx 删除镜像 启动并运行整个服务 docker compose up -d jar包名称 idea 使用tcp方式连接docker 配置d…...

好消息!2023年汉字小达人市级比赛在线模拟题大更新:4个组卷+11个专项,助力孩子更便捷、有效、有趣地备赛

自从《中文自修》杂志社昨天发通知&#xff0c;官宣了2023年第十届汉字小达人市级比赛的日期和安排后&#xff0c;各路学霸们闻风而动&#xff0c;在自己本就繁忙的日程中又加了一项&#xff1a;备赛汉字小达人市级比赛&#xff0c;11月30日&#xff0c;16点-18点。 根据这几年…...

SAP 70策略测试简介

在前面的文章中我们已经测试了10、11、20、40、50、52、60、62策略的测试,接下来我们需要对70策略进行测试,很多的项目中也都会用到70策略。 70策略是一种比较常见的、基于按库存且主要用于半成品或者原材料的计划策略。 我们还是按照之前的惯例,先看下70策略的后台配置 我…...

uniapp+vue3+ts+vite+echarts开发图表类小程序,将echarts导入项目使用的详细步骤,耗时一天终于弄好了

想在uniapp和vue3环境中使用echarts是一件相当前卫的事情&#xff0c;官方适配的还不是很好&#xff0c;echarts的使用插件写的是有些不太清晰的&#xff0c;这里我花费了一天的时间&#xff0c;终于将这个使用步骤搞清楚了&#xff0c;并且建了一个仓库&#xff0c;大家可以直…...

地震勘探——干扰波识别、井中地震时距曲线特点

目录 干扰波识别反射波地震勘探的干扰波 井中地震时距曲线特点 干扰波识别 有效波&#xff1a;可以用来解决所提出的地质任务的波&#xff1b;干扰波&#xff1a;所有妨碍辨认、追踪有效波的其他波。 地震勘探中&#xff0c;有效波和干扰波是相对的。例如&#xff0c;在反射波…...

【杂谈】-递归进化:人工智能的自我改进与监管挑战

递归进化&#xff1a;人工智能的自我改进与监管挑战 文章目录 递归进化&#xff1a;人工智能的自我改进与监管挑战1、自我改进型人工智能的崛起2、人工智能如何挑战人类监管&#xff1f;3、确保人工智能受控的策略4、人类在人工智能发展中的角色5、平衡自主性与控制力6、总结与…...

ubuntu搭建nfs服务centos挂载访问

在Ubuntu上设置NFS服务器 在Ubuntu上&#xff0c;你可以使用apt包管理器来安装NFS服务器。打开终端并运行&#xff1a; sudo apt update sudo apt install nfs-kernel-server创建共享目录 创建一个目录用于共享&#xff0c;例如/shared&#xff1a; sudo mkdir /shared sud…...

工程地质软件市场:发展现状、趋势与策略建议

一、引言 在工程建设领域&#xff0c;准确把握地质条件是确保项目顺利推进和安全运营的关键。工程地质软件作为处理、分析、模拟和展示工程地质数据的重要工具&#xff0c;正发挥着日益重要的作用。它凭借强大的数据处理能力、三维建模功能、空间分析工具和可视化展示手段&…...

【Go】3、Go语言进阶与依赖管理

前言 本系列文章参考自稀土掘金上的 【字节内部课】公开课&#xff0c;做自我学习总结整理。 Go语言并发编程 Go语言原生支持并发编程&#xff0c;它的核心机制是 Goroutine 协程、Channel 通道&#xff0c;并基于CSP&#xff08;Communicating Sequential Processes&#xff0…...

第一篇:Agent2Agent (A2A) 协议——协作式人工智能的黎明

AI 领域的快速发展正在催生一个新时代&#xff0c;智能代理&#xff08;agents&#xff09;不再是孤立的个体&#xff0c;而是能够像一个数字团队一样协作。然而&#xff0c;当前 AI 生态系统的碎片化阻碍了这一愿景的实现&#xff0c;导致了“AI 巴别塔问题”——不同代理之间…...

ardupilot 开发环境eclipse 中import 缺少C++

目录 文章目录 目录摘要1.修复过程摘要 本节主要解决ardupilot 开发环境eclipse 中import 缺少C++,无法导入ardupilot代码,会引起查看不方便的问题。如下图所示 1.修复过程 0.安装ubuntu 软件中自带的eclipse 1.打开eclipse—Help—install new software 2.在 Work with中…...

AI编程--插件对比分析:CodeRider、GitHub Copilot及其他

AI编程插件对比分析&#xff1a;CodeRider、GitHub Copilot及其他 随着人工智能技术的快速发展&#xff0c;AI编程插件已成为提升开发者生产力的重要工具。CodeRider和GitHub Copilot作为市场上的领先者&#xff0c;分别以其独特的特性和生态系统吸引了大量开发者。本文将从功…...

大数据学习(132)-HIve数据分析

​​​​&#x1f34b;&#x1f34b;大数据学习&#x1f34b;&#x1f34b; &#x1f525;系列专栏&#xff1a; &#x1f451;哲学语录: 用力所能及&#xff0c;改变世界。 &#x1f496;如果觉得博主的文章还不错的话&#xff0c;请点赞&#x1f44d;收藏⭐️留言&#x1f4…...

技术栈RabbitMq的介绍和使用

目录 1. 什么是消息队列&#xff1f;2. 消息队列的优点3. RabbitMQ 消息队列概述4. RabbitMQ 安装5. Exchange 四种类型5.1 direct 精准匹配5.2 fanout 广播5.3 topic 正则匹配 6. RabbitMQ 队列模式6.1 简单队列模式6.2 工作队列模式6.3 发布/订阅模式6.4 路由模式6.5 主题模式…...