CustomActionData 以分号分隔,导致字符串溢出 - 此解决方案的常见解决方法是什么?

CustomActionData with semi-colon separated, causes string overflow - What are the common workaround to this solution?

关于 CustomActionData 的 ICE03(字符串溢出)问题的回答尝试很少,但我似乎无法 determine/conclude 如何解决此问题的正确(或接受)做法。

我目前的解决方案是通过保持键和 属性 名称的简短来减少键值对的长度,即 from:

<CustomAction Id="MyCustomActionData"
  Property="MyCustomActionCA"
  Value="myKeyName1=[SOME_PROPERTY_NAME];myKeyName2=[SOME_DESCRIPTIVE_PROPNAME]"/>

至:

<CustomAction Id="MyCustomActionData"
  Property="MyCustomActionCA"
  Value="k1=[K1];k2=[K2]"/>

但我觉得我只是在掩盖问题,迟早会再次遇到(另外,这是基于我在下面的附加问题的假设)。

更明显的解决方案是重新评估和重新设计它,以便需要将最少数量的数据传递给 C# CustomAction(所有人提出的 classic "why would you want to declare a function method to pass 20 parameters?" 问题代码审查员)。显然,对于今天的大多数语言,我们可以轻松地重新设计 API 并传递一个自包含所需内容的对象(作为 class、结构等 - 取决于语言),但是如何进行进程间调用(我已经看到 JSON RPC 消息具有相当大的数据,我通常想知道这是不是因为有人试图通过添加越来越多的代码来修复一些遗留代码,直到它变得臃肿而不是坐下来重新设计,这在某些“第 11 小时”的截止日期是不可能的,只需要在允许的最短时间内修复)。

也许解决方案是创建一个 XML 文件并使用 expat ('util:XmlFile') 在调用 CustomAction 之前搜索和替换键值对,并传递更改后的文件名 XML 作为 CustomAction 使用的 CustomActionData,然后在 C# CustomAction 代码中,它只是反序列化它并将其视为对象。但这也感觉有点笨拙(它也可能让未来接手我的任务的下一位开发人员感到困惑),更不用说如果它是密码我们不想把它放在 XML 文件中并保留它是 属性 和 Hidden="yes"...

所以我的问题是,解决传递可能超过 table 列大小的 CustomActionData 问题的 clean/elegant 解决方案或模式(或实践)是什么?

如果我还可以问一个有点相关的附加问题,我假设链接器(轻型)警告 LGHT1076 是基于值的长度(即 "keyA=[A];keyB=[B]")太长,并且所以如果我选择非常短的 属性 变量和键名,它很可能不会触发此警告。但据我了解,table 列大小为 255 个字符(如果我错了请纠正我)因此在 运行 期间,如果 属性 值长于列大小,它可能会导致一些问题(或 t运行cated)?

我使用的解决方案是创建多个属性,然后将最后的属性连接成一个属性,这样:

<CustomAction Id="SetSqlProperties"
              Property="SqlProperties"
              Value="SQL_LOGIN_ID=[SQL_LOGIN_ID];SQL_PASSWORD=[SQL_PASSWORD];
                     SQL_AUTH_TYPE=[SQL_AUTH_TYPE];SQL_SERVERS=[SQL_SERVERS]" />
<CustomAction Id="SetServerProperties"
              Property="ServerProperties"
              Value="Domain=[DOMAIN];ComputerName=[COMPUTER_NAME];
                     FullServerName=[FULLCOMPUTERNAME];Version=[ProductVersion];
                     ServerType=[SERVER_TYPE];SrvMode=[SrvMode]" />

<CustomAction Id="SetPropertiesConfigReplace"
              Property="ConfigReplace"
              Value="InstallFolder=[INSTALLFOLDER];[ServerProperties];[SqlProperties]" />

在此示例中,我将使用 属性 [ConfigReplace] 包含来自 SQL 服务器和本地服务器的所有值。

关于ICE03,在文档中可以找到:

The string's length is greater than the column width specified by the column definition. Note that the installer does not internally limit the column width to the specified value. See Column Definition Format. MSDN