0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看威廉希尔官方网站 视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

源码补丁神器—patch-package

京东云 来源:jf_75140285 作者:jf_75140285 2024-07-30 10:51 次阅读

一、背景

vue项目中使用 vue-pdf 第三方插件预览pdf,书写业务代码完美运行,pdf文件内容正常预览无问题。后期需求有变,业务需求增加电子签章功能。这个时候pdf文件的内容可以显示出来,但是公司的电子签章无法显示。这令人沮丧,因为已经编写了许多特定于此依赖项的代码,如果替换依赖库,这些代码很可能会被浪费。更重要的是其已经在生产环境运行。

在不更改依赖库进行大改动的前提下,先查找问题所在。经查发现此为官方bug 无法显示签章。进一步查询发现根源是其依赖包 pdf.js 的 电子签章不显示。

问题已定位到,要修改显示电子签章的代码是在node_modules的依赖包中。

如何解决此问题?

二、常用方法

1. 给依赖包提 issue 等待他人修复并发布

2. 给依赖包提 pr 自行修复并等待发布

3. 整体copy项目法

直接引用法

直接copy依赖包的源码,本地引用,不再通过npm包方式引用

发布私库法

适合多项目中使用同一个依赖包的场景,可以把修改后的源码发布到私有的仓库上

4. 修改引用法

配置一个webpack alias别名,如'原始文件的引用路径': '修改后文件的引用路径',使得最终修改后的文件被引用,如:

resolve: {  
    alias: {  
        'pdfjs': path.resolve(__dirname, './patched/pdfjs/*'), 
    }
}

以上方法均有弊端:

前两种修复周期很长且依赖第三方,修复时间不定,不适合解决当前问题。

后几种方法都比较复杂,并且会导致项目臃肿,更容易忘记自己修改了源码的哪个部分,而且更新麻烦,每次都需要手动去更新代码,无法与插件同步更新。

有没有一种方法,可以优雅修改node_modules的源码?

三、patch-package

patch-package 让程序开发者立即修复并保留 npm 依赖项。是一个给依赖项打补丁的完美方案。

# fix a bug in one of your dependencies
vim node_modules/some-package/brokenFile.js

# run patch-package to create a .patch file
npx patch-package some-package

# commit the patch file to share the fix with your team
git add patches/some-package+3.14.15.patch
git commit -m "fix brokenFile.js in some-package"

使用方法:

1.安装

npm i patch-package

如果你不需要在生产中运行

npm i patch-package --save-dev

yarn、pnpm、docker安装命令可查看其 git官网。

2. 修改npm包

更改node_modules 文件夹中要修改依赖包的文件

3. 生成补丁

npx patch-package package-name

4. 添加自动执行命令

In package.json

 "scripts": {
    +  "postinstall": "patch-package"
 }

在本文示例中,在node_modules找到要修改的依赖包pdfjs-dist,修改代码如下:

wKgaomandYWAK35GAAJIUePYles986.jpg



执行npx patch-package pdfjs-dist,生成补丁,会在文件目录中生成一个patches文件夹,如下:

wKgZomandYaAKxFOAAIRwSjkvNM629.jpg



至此项目中的bug已修复,如何让更改内容在团队其他同事拉取代码后执行?

添加自执行命令如下,会在 npm install 后知执行。

wKgaomandYeAS_qtAAMMGc6ABoY933.jpg



patch文件是什么?

其实就是一些git diff记录描述。

原理: patch-package会将当前 node_modules下的源码与原始源码进行 git diff,并在项目根目录下生成一个patch补丁文件。

如何自测补丁是否生效?

手动删除项目中的node_modules,并重新执行npm install命令安装依赖包。安装成功后查看之前修改的 node_modules 依赖包中的文件,查看修改的代码是否依然存在,如果之前修改代码依然存在即表明补丁文件已经生效,如果你之前修改的代码不存在即表明补丁文件没有生效。

四、patch-package 好处

版本预检

当依赖项发生更改时,会以红色大写字母通知,需要检查所做修复是否仍然有效。npx patch-package 会直接报错**ERROR** Failed to apply patch for package xxxx at path,通过提示可以更方便定位问题。

节省空间

无需拷贝一份源码,使用git diff来记录补丁更节省空间,安全又便捷。

可审查

补丁可以作为正常审查过程的一部分进行审查。

五、注意事项

◦直接修改 node_modules 下的代码不是被推荐的做法,应该仅在应急情况下考虑

◦长期还是需要彻底修复第三方包缺陷并逐步移除项目中的 .patch 文件

审核编辑 黄宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 源码
    +关注

    关注

    8

    文章

    643

    浏览量

    29264
收藏 人收藏

    评论

    相关推荐

    南亚科技与补丁科技携手开发定制超高带宽内存

    近日,台湾地区知名的DRAM内存制造商南亚科技宣布,已与专业DRAM设计公司补丁科技达成战略合作,共同致力于定制超高带宽内存(Customized Ultra-High-Bandwidth
    的头像 发表于 12-20 14:28 163次阅读

    如何在Petalinux下Patch u-boot源码

    在软件开发过程中我们经常遇到用 Patch 来传递和更新代码的场景。本文以一个端到端的例子来演示在 Petalinux 使用过程中,如何给 u-boot 的源码生成 Patch 并在 Petalinux 中编译。
    的头像 发表于 12-04 16:26 1055次阅读
    如何在Petalinux下<b class='flag-5'>Patch</b> u-boot<b class='flag-5'>源码</b>

    TVP5150AM1补丁代码下载指南

    电子发烧友网站提供《TVP5150AM1补丁代码下载指南.pdf》资料免费下载
    发表于 09-30 14:11 0次下载
    TVP5150AM1<b class='flag-5'>补丁</b>代码下载指南

    TVP5147M1补丁代码下载指南

    电子发烧友网站提供《TVP5147M1补丁代码下载指南.pdf》资料免费下载
    发表于 09-30 11:27 0次下载
    TVP5147M1<b class='flag-5'>补丁</b>代码下载指南

    TVP5160补丁代码下载指南

    电子发烧友网站提供《TVP5160补丁代码下载指南.pdf》资料免费下载
    发表于 09-30 11:01 0次下载
    TVP5160<b class='flag-5'>补丁</b>代码下载指南

    TVP5158补丁代码下载指南

    电子发烧友网站提供《TVP5158补丁代码下载指南.pdf》资料免费下载
    发表于 09-30 10:48 0次下载
    TVP5158<b class='flag-5'>补丁</b>代码下载指南

    TVP5151补丁代码下载指南

    电子发烧友网站提供《TVP5151补丁代码下载指南.pdf》资料免费下载
    发表于 09-30 09:37 0次下载
    TVP5151<b class='flag-5'>补丁</b>代码下载指南

    NONOS_SDK 1.5.4.1导致致命错误的补丁怎么处理?

    将 1.5.4.1 补丁文件应用到我的稳定 1.5.4 代码库后,闪烁我的eagle.flash.bin和eagle.irom0text.bin时,我的ESP8266模块(ESP-12 或
    发表于 07-11 07:57

    UCGUI单片机源码

    UCGUI单片机源码
    发表于 07-04 17:11 1次下载

    【米尔-瑞米派兼容树莓派扩展模块-试用体验】 实时系统移植

    进入到内核源码补丁,如下: hjx@myir-server:~/renesas/04_Sources/myir-renesas-linux for p in `ls -1 ../patches
    发表于 06-19 16:57

    什么是源码源码有什么作用?源码组件是什么?源码可二次开发吗?

    源码,也称为源程序,是指未编译的按照一定的程序设计语言规范书写的文本文件,是一系列人类可读的计算机语言指令。
    的头像 发表于 05-25 14:55 1.6w次阅读
    什么是<b class='flag-5'>源码</b>?<b class='flag-5'>源码</b>有什么作用?<b class='flag-5'>源码</b>组件是什么?<b class='flag-5'>源码</b>可二次开发吗?

    STM32 Cryptographic library package V2.0.6怎么使用?

    谁用过 STM32 Cryptographic library package V2.0.6可以说下怎么使用吗
    发表于 05-14 07:44

    请问Systemverilog中如何使用VHDL的package?

    现在需要使用system verilog写代码,但是想复用之前VHDL的package,里面有写的现成的function等,请问如何调用呢。总是报错说找不到_pkg
    发表于 03-12 15:37

    RX系列的RX Driver Package Ver.1.42的应用说明

    电子发烧友网站提供《RX系列的RX Driver Package Ver.1.42的应用说明.pdf》资料免费下载
    发表于 01-30 15:13 0次下载
    RX系列的RX Driver <b class='flag-5'>Package</b> Ver.1.42的应用说明

    介绍一款基于java的渗透测试神器-CobaltStrike

    Cobalt Strike是一款基于java的渗透测试神器,常被业界人称为CS神器
    的头像 发表于 01-16 09:16 1013次阅读
    介绍一款基于java的渗透测试<b class='flag-5'>神器</b>-CobaltStrike