最近在编译的时候发现如果在Post build Event 调用 signtool 去给编译出来的二进制文件进行签名时,如果发生时间戳超时的情况就会post-build event failed with code -1
时间戳超时是经常发生的事情,因为权威的时间戳服务器都在国外。
是不是你签名时retry几次,应该就没问题了?只要保证 Errorlevel 为 0 就好了
可以使用类似的批处理:
for /L %%a in (1,1,10) do (
REM try to timestamp the file...
signtool.exe timestamp /t %timestamp_server% %1
if errorlevel 0 if not errorlevel 1 GOTO succeeded
REM wait 2 seconds...
ping -n 2 127.0.0.1 > nul
)
but,只要你有一次超时 Visual Studio也会显示编译失败
原来Visual Studio 判定Post build Event 是失败不仅跟返回值有关,还跟控制台输出的错误的信息有关,一旦有关键字 SignTool error : An error occurred
扫描二维码关注公众号,回复:
3983910 查看本文章
Visual Studio 判定Post build Event 是失败的。。
感觉有点脑残啊~~
不过知道问题了我们就有解决办法了
可以加上 2>nul 来屏蔽出错信息,这样就可以成功retry啦,哈哈哈哈