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';
Run Code Online (Sandbox Code Playgroud)
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;
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3191 次 |
| 最近记录: |