Lin*_*han 6 virus exe inno-setup
早上好,
我用Innosetup创建的exe被视为病毒!!!
真的很烦,因为我无法发送给他们帮助。有人遇到过这个问题吗?
我使用的是InnoSetup 5.5,我实际上并没有复制文件,我只需要生成一些命令即可处理证书。
提前致谢
[编辑]
Inno脚本
因此,这有点复杂,因为我需要使用psexec进行管理,删除先前的证书,然后安装新的证书。
#define MyAppName "Update Certificate"
#define MyAppVersion "1.0" 
#define MyAppPublisher "kkk"
#define MyAppExeName "updateBase"
#define installConf "installConfig.exe"  
#define uninstallCert "unCert.exe"
#define psexec "psexec.exe"
#define passAdmin "password"
[Setup]
AppName={#MyAppName}
AppVersion={#MyAppVersion}
AppPublisher={#MyAppPublisher}
DefaultDirName={localappdata}
DisableDirPage=yes
DisableReadyPage=yes
DisableWelcomePage=yes
PrivilegesRequired=none
CreateAppDir=no   
CreateUninstallRegKey = no    
OutputBaseFilename={#MyAppExeName}
Compression=lzma
SolidCompression=yes     
SetupIconFile=favicon.ico
[Languages]
Name: "english"; MessagesFile: "compiler:Default.isl"
[Files]
Source: "{#installConf}"; Flags: dontcopy
Source: "{#psexec}";  Flags: dontcopy
Source: "{#uninstallCert}"; Flags: dontcopy
[Code]
var
  ResultCode: Integer;
  Page: TWizardPage;
  CustomPageID: Integer;
  InstallRadioButton: TNewRadioButton;
  DeleteRadioButton: TNewRadioButton;   
  UpdateRadioButton: TNewRadioButton;
procedure ExitProcess(exitCode:integer);
  external 'ExitProcess@kernel32.dll stdcall';
unCert.exe正在处理证书以将其删除
// Uninstall previous certificate 
function UninstallCertificat(): Boolean;var 
  arg: String;
begin   
      ExtractTemporaryFile('{#uninstallCert}');  
      ExtractTemporaryFile('{#psexec}');      
     arg :=  ' /accepteula -u Administrateur -p {#passAdmin} -i ' + AddQuotes(ExpandConstant('{tmp}\{#uninstallCert}')) ; 
     Result := Exec(AddQuotes(ExpandConstant('{tmp}\{#psexec}')),arg,'', SW_SHOW, ewWaitUntilTerminated, ResultCode);
     Log(AddQuotes(ExpandConstant('{tmp}\{#psexec}'))); 
     Log(AddQuotes(ExpandConstant('{tmp}\{#uninstallCert}')));
      if ResultCode <> 0 then begin
        MsgBox('InitializeSetup:' #13#13 'Certificat Uninstall Failed', mbError, MB_OK);
        ExitProcess(2);
      end else  begin;
          MsgBox('InitializeSetup:' #13#13 'Certificat Uninstall Done', mbInformation, MB_OK);
      end;
 end;          
 // Géneration des Mots de passe pour le certificats
function getPassWord(): string;
var
  computerName: string;
  V: string;
begin
  // Something to generate the password
end;
// Certificate installation 
function InstallCertificat(): Boolean;var 
  arg: String;
  Filename: string;
  pass: string;
begin
  pass := getPassWord();;                
  ExtractTemporaryFile('{#psexec}');      
  Filename := ExpandConstant('{tmp}\cert.p12');
  FileCopy(ExpandConstant('{src}\cert.p12'),ExpandConstant('{tmp}\cert.p12'), False);
     arg :=  ' /accepteula -u Administrateur -p {#passAdmin} -i ' + GetSystemDir() +'\certutil.exe -p ' + pass + ' -importPFX ' + Filename + ' NoExport'; 
     Result := Exec(AddQuotes(ExpandConstant('{tmp}\{#psexec}')),arg,'', SW_SHOW, ewWaitUntilTerminated, ResultCode);
      if ResultCode <> 0 then begin
        Log( SysErrorMessage(ResultCode));
        MsgBox('InitializeSetup:' #13#13 'Certificat Installation Failed', mbError, MB_OK);
        ExitProcess(2);
      end else  begin;
          MsgBox('InitializeSetup:' #13#13 'Certificat Installation Done' , mbInformation, MB_OK);
      end;
 end;
| 归档时间: | 
 | 
| 查看次数: | 3191 次 | 
| 最近记录: |