”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > Drupal:从数据库中删除 Ghost 插件

Drupal:从数据库中删除 Ghost 插件

发布于2024-08-21
浏览:529

Drupal: Rimuovere un plugin fantasma dal database

来源:https://drupal.stackexchange.com/questions/315921/removing-phantom-plugin-from-database/320215#320215

当您卸载模块时,可能会出现该过程未完全执行或不存在任何删除过程的情况,因此数据库仍处于“脏”状态。
通常强行删除插件导致的错误是这样的:

[error]  Drupal\Component\Plugin\Exception\PluginNotFoundException:
         The "name-of-plugin" entity type does not exist.
         in Drupal\Core\Entity\EntityTypeManager->getDefinition()

启用显示所有错误消息的配置可以帮助您了解错误出现的位置以及需要采取操作的位置。
您可以在此处的 admin/config/development/logging 页面上激活完整的日志启用。此配置可以帮助您确定问题是配置问题还是插件名称被硬编码到代码中。

现在我们将解决如何解决与配置相关的问题,为此我们有两种可能的方法:

  • 导出整个配置并在删除插件引用后重新导入
  • 直接作用于数据库中存在的配置并删除插件

导出整个配置并重新导入

如果您遵循 Drupal 社区推荐的标准发布方法,此解决方案很可能是最常用的解决方案。
通过图形界面或使用 drush config:export 命令导出整个配置。在从导出恢复的文件中,使用插件名称执行全文搜索。删除导致错误的配置部分并使用 drush config:import

导入配置

通过直接作用于数据库中存在的配置并删除插件

此解决方案对于像我这样无法导出整个配置并重新导入但需要在站点上“热”工作的人很有用。
要查找哪些配置导致错误,您可以在数据库上运行此查询:

SELECT name FROM config WHERE data LIKE "%name-of-plugin%";

查询在配置表中搜索有问题的插件,并返回调用该插件的配置的名称。

当您知道配置名称后,您可以继续删除插件。
根据插件和错误的配置,删除方法可能会略有不同,现在让我们考虑一个示例,它也可以作为其他情况的良好起点。

前任。
由于 Drupal 10 更新错误,我的 filter_image_lazy_load 插件出现了问题。
上一个查询返回了这些配置:

filter.format.basic_html
filter.format.full_html
filter.format.restricted_html

通过 config.factory 服务,我加载了配置并检查了问题所在。然后你可以像这样继续删除插件:

$configName = 'filter.format.basic_html';
$config = \Drupal::service('config.factory')->getEditable($configName);
$filters = $config->get('filters');
unset($filters['filter_image_lazy_load']);
$config->set('filters', $filters)->save()

您可以使用 drush config:get filter.format.basic_html 和 drush config:set filter.format.basic_html 或使用 drush config:edit filter.format.basic_html 一次性完成完全相同的操作

清理配置后,运行 drush 缓存:重建,错误应该得到解决!

版本声明 本文转载于:https://dev.to/mcale/drupal-rimuovere-un-plugin-fantasma-dal-database-9pj?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 解决MySQL错误1153:数据包超出'max_allowed_packet'限制
    解决MySQL错误1153:数据包超出'max_allowed_packet'限制
    mysql错误1153:故障排除比“ max_allowed_pa​​cket” bytes 更大的数据包,用于面对阴谋mysql错误1153,同时导入数据capase doft a Database dust?让我们深入研究罪魁祸首并探索解决方案以纠正此问题。理解错误此错误表明在导入过程中接...
    编程 发布于2025-04-17
  • 如何将MySQL数据库添加到Visual Studio 2012中的数据源对话框中?
    如何将MySQL数据库添加到Visual Studio 2012中的数据源对话框中?
    在Visual Studio 2012 尽管已安装了MySQL Connector v.6.5.4,但无法将MySQL数据库添加到实体框架的“ DataSource对话框”中。为了解决这一问题,至关重要的是要了解MySQL连接器v.6.5.5及以后的6.6.x版本将提供MySQL的官方Visual...
    编程 发布于2025-04-17
  • 如何使用Regex在PHP中有效地提取括号内的文本
    如何使用Regex在PHP中有效地提取括号内的文本
    php:在括号内提取文本在处理括号内的文本时,找到最有效的解决方案是必不可少的。一种方法是利用PHP的字符串操作函数,如下所示: 作为替代 $ text ='忽略除此之外的一切(text)'; preg_match('#((。 &&& [Regex使用模式来搜索特...
    编程 发布于2025-04-17
  • 找到最大计数时,如何解决mySQL中的“组函数\”错误的“无效使用”?
    找到最大计数时,如何解决mySQL中的“组函数\”错误的“无效使用”?
    如何在mySQL中使用mySql 检索最大计数,您可能会遇到一个问题,您可能会在尝试使用以下命令:理解错误正确找到由名称列分组的值的最大计数,请使用以下修改后的查询: 计数(*)为c 来自EMP1 按名称组 c desc订购 限制1 查询说明 select语句提取名称列和每个名称...
    编程 发布于2025-04-17
  • eval()vs. ast.literal_eval():对于用户输入,哪个Python函数更安全?
    eval()vs. ast.literal_eval():对于用户输入,哪个Python函数更安全?
    称量()和ast.literal_eval()中的Python Security 在使用用户输入时,必须优先确保安全性。强大的python功能eval()通常是作为潜在解决方案而出现的,但担心其潜在风险。 This article delves into the differences betwee...
    编程 发布于2025-04-17
  • 如何使用Depimal.parse()中的指数表示法中的数字?
    如何使用Depimal.parse()中的指数表示法中的数字?
    在尝试使用Decimal.parse(“ 1.2345e-02”中的指数符号表示法表示的字符串时,您可能会遇到错误。这是因为默认解析方法无法识别指数符号。 成功解析这样的字符串,您需要明确指定它代表浮点数。您可以使用numbersTyles.Float样式进行此操作,如下所示:[&& && && ...
    编程 发布于2025-04-17
  • `console.log`显示修改后对象值异常的原因
    `console.log`显示修改后对象值异常的原因
    foo = [{id:1},{id:2},{id:3},{id:4},{id:id:5},],]; console.log('foo1',foo,foo.length); foo.splice(2,1); console.log('foo2', foo, foo....
    编程 发布于2025-04-17
  • 在UTF8 MySQL表中正确将Latin1字符转换为UTF8的方法
    在UTF8 MySQL表中正确将Latin1字符转换为UTF8的方法
    在UTF8表中将latin1字符转换为utf8 ,您遇到了一个问题,其中含义的字符(例如,“jáuòiñe”)在utf8 table tabled tablesset中被extect(例如,“致电。为了解决此问题,您正在尝试使用“ mb_convert_encoding”和“ iconv”转换受...
    编程 发布于2025-04-17
  • 如何配置Pytesseract以使用数字输出的单位数字识别?
    如何配置Pytesseract以使用数字输出的单位数字识别?
    Pytesseract OCR具有单位数字识别和仅数字约束 在pytesseract的上下文中,在配置tesseract以识别单位数字和限制单个数字和限制输出对数字可能会提出质疑。 To address this issue, we delve into the specifics of Te...
    编程 发布于2025-04-17
  • PHP高手 | 使用外观模式简化复杂性
    PHP高手 | 使用外观模式简化复杂性
    Design patterns are built to standardize solutions for common problems faced in software development. When we develop complex applications, we should...
    编程 发布于2025-04-17
  • 如何同步迭代并从PHP中的两个等级阵列打印值?
    如何同步迭代并从PHP中的两个等级阵列打印值?
    同步的迭代和打印值来自相同大小的两个数组使用两个数组相等大小的selectbox时,一个包含country代码的数组,另一个包含乡村代码,另一个包含其相应名称的数组,可能会因不当提供了exply for for for the uncore for the forsion for for ytry...
    编程 发布于2025-04-17
  • 如何解决由于Android的内容安全策略而拒绝加载脚本... \”错误?
    如何解决由于Android的内容安全策略而拒绝加载脚本... \”错误?
    Unveiling the Mystery: Content Security Policy Directive ErrorsEncountering the enigmatic error "Refused to load the script..." when deployi...
    编程 发布于2025-04-17
  • 查找当前执行JavaScript的脚本元素方法
    查找当前执行JavaScript的脚本元素方法
    如何引用当前执行脚本的脚本元素在某些方案中理解问题在某些方案中,开发人员可能需要将其他脚本动态加载其他脚本。但是,如果Head Element尚未完全渲染,则使用document.getElementsbytagname('head')[0] .appendChild(v)的常规方...
    编程 发布于2025-04-17
  • Pandas删除行:基于字符串长度和多条件
    Pandas删除行:基于字符串长度和多条件
    在pandas dataframes中的条件行删除 的错误是“ keyError:keyerror:fluges的,则unye的fortive更高很高):要解决此问题,让我们探索一种有条件行删除的替代方法。) 2].index)In-place Operation:You can also per...
    编程 发布于2025-04-17
  • 触发MySQL操作的SELECT语句技巧
    触发MySQL操作的SELECT语句技巧
    在选择语句上触发mySQL action Alternative SolutionHowever, there is a potential workaround for this unique scenario:Create Stored Procedures for SELECTs:Defin...
    编程 发布于2025-04-17

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3