TranslateIP For StoreFront V2
- by Froyo
- 10/26/2019 at 20:21:23
Translate for Storefront从最初发布到现在已经过去了超过5年时间,目前仍然时不时有人来咨询具体的使用问题,所以决定对过去收集到的一些问题进行集中处理,过程中由于系统以及StoreFront的一些限制,于是重构了所有代码以及配置文件,以便后续的维护和使用。
旧版本中存在的一些限制和问题
- 对于通过WebHelper方式调用的浏览器或者终端无法进行修改。比如Chrome浏览器就是使用的这种方式,在点击应用的时候,Storefront会返回一个链接(而不是常规的ICA文件),而后调用Receiver的过程中传递过去,Receiver再来通过链接下载ICA文件。
- 由于IIS Module权限的问题,导致配置文件以及写日志文件存在权限问题,配置过程中较为复杂,所以,在最开始的时候就决定不引入日志,从而导致后续出问题后troubleshooting比较困难。
Translate IP for StoreFront v2 部署方法如下
- 复制 StoreCustomization_Launch.dll 到对应Store的Bin目录:
12# 比如默认Store站点路径如下:C:inetpubwwwrootCitrixStoreBin
- 复制并替换完成后,默认会立即重新加载,不需要iisreset或者重启服务器就会生效
- 修改StoreWeb.config,并添加Translate规则配置
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
# 默认Store的配置文件路径如下:
C:inetpubwwwrootCitrixStoreweb.config
# 搜索<appSettings/>
# 然后替换<appSettings/>为如下的内容
# 每条规则对应一条add
<appSettings>
<add key="VDA_IP1" value="Translate_Rule1">
<add key="VDA_IP2" value="Translate_Rule2">
</appSettings>
# 下面是一个完整的示例
<appSettings>
<!-- 替换172.16.10.20:1494为1.1.1.1:1495,同时替换*:2598为*:2599 -->
<add key="172.16.10.20" value="172.16.10.20:1494,1.1.1.1:1495,*:2596,*:2599">
<!-- 替换172.16.10.21:1494为2.2.2.2:1496 -->
<add key="172.16.10.21" value="172.16.10.21:1494,2.2.2.2:1496">
<!-- 替换*:2598为*:2600 -->
<add key="172.16.10.22" value="*:2598,*:2600">
<!-- 一些高级用法,比如替换TWIMode=On为TWIMode=Off可以修改ICA配置来启用Window Mode -->
<add key="172.16.10.23" value="TWIMode=On,TWIMode=Off">
</appSettings>
|
注意:
- 对于每个ICA请求,只有Add Key指定的IP地址匹配了ICA文件中Address中的IP才会进行修改,否则跳过
- Value中规则以英文逗号分隔,分割后参数个数应为双数,也就是每两个一组。针对每一组,在ICA文件中搜索第一部分字符,然后替换为第二部分。所以,可以看到在示例中,第一条指定两组(4个逗号分隔的字符串),分别用来处理1494和2598两个端口。
- 同理,最后一条规则,根据字符串替换的原理,可以用来替换任何ICA文件中的设置
Troubleshooting
排错的话,主要使用的工具为DebugView。
- 下载DbgView之后,在Storefront上打开并运行
- 菜单Capture中勾选Capture Global Win32。否则的话,无法看到任何日志
- 通过快捷键CRTL+L打开Filter设置,然后输入TranslateIP并点击OK,或者如下图所示
操作。
CRTL+X清除之前的日志
到此一切设置完成,重现问题即可。示例日志如下: