Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2008.10.12;
Скачать: CL | DM;

Вниз

Автозапуск через Реестр   Найти похожие ветки 

 
Ilshat   (2008-01-09 05:48) [0]

Собственно проблема не в Делфи, ключ реестра устанавливается прекрасно, работает, но по непонятным мне причинам на программу начинает ругаться Касперский Интернет Секьюрити 7(мониторинг реестра отключен, работает только проактивная защита). Программа пустая, есть только процедура для автозапуска.


procedure DoAppToRun(RunName, AppName: string);
var
 Reg: TRegistry;
begin
 Reg := TRegistry.Create;
 with Reg do
 begin
   RootKey := HKEY_LOCAL_MACHINE;
   OpenKey("Software\Microsoft\Windows\CurrentVersion\Run", True);
   if ReadString(RunName) <> AppName then
     WriteString(RunName, AppName);
   CloseKey;
   Free;
 end;
end;


Все сторонние программы спокойно устанавливают себя в автозапуск... кстати и вирусы тоже... А моей почему-то нельзя. В чем хитрость?


 
Loginov Dmitry ©   (2008-01-09 07:57) [1]

Не только Касперский на такое ругается. AVG на подобный код у меня также ругался, причем без вопросов снес все exe-шки и dll-ки, где такой код увидел! К чему бы это? :)

Скорее всего не нравится строка "Software\Microsoft\Windows\CurrentVersion\Run". Попробуй сформировать ее динамически.


 
Ilshat   (2008-01-09 09:01) [2]

Моему строка нравится. Ему перестает нравиться только когда пытаешься установить себя в автозапуск, то есть ему не нравится интерпретация кода, а не его внешний вид. Тест на поиск вирусов программа проходит... А вот дальше проблема...


 
Игорь Шевченко ©   (2008-01-09 14:15) [3]

а зачем вирусам через реестр запускаться ? Незачем


 
KilkennyCat ©   (2008-01-10 00:39) [4]

Может, программа не для пользователя написана?..


 
maxistent ©   (2008-01-10 00:42) [5]

а попробуй изменить
RootKey := HKEY_LOCAL_MACHINE;
на
RootKey := HKEY_CURRENT_USER;
и

OpenKey("Software\Microsoft\Windows\CurrentVersion\Run", True);
...

на

if OpenKey("Software\Microsoft\Windows\CurrentVersion\Run", FALSE) then
...


 
PZ   (2008-01-11 14:41) [6]

Вот у меня работает нормально следующий код:
procedure TOptionFrm.AutoRunChekBoxClick(Sender: TObject);
Var
 Reg : tRegistry;
begin
 Reg := tRegistry.Create;
 Reg.RootKey := HKEY_LOCAL_MACHINE;
 Reg.OpenKey("SOFTWARE\Microsoft\Windows\CurrentVersion\Run", False);
 If AutoRunChekBox.Checked then
   Reg.WriteString(Application.Title, ParamStr(0))
 else
   Reg.DeleteValue(Application.Title);
 FreeAndNil(Reg);
end;


 
KilkennyCat ©   (2008-01-11 20:32) [7]


> PZ


тоже пользователей игнорируем?


 
PZ   (2008-01-12 09:42) [8]

Вообще-то в качестве пользователя выступаю я сам. А в чем, собственно, игнорирование?


 
Loginov Dmitry ©   (2008-01-12 10:20) [9]

> Вообще-то в качестве пользователя выступаю я сам. А в чем,
> собственно, игнорирование?



> Reg.OpenKey("SOFTWARE\Microsoft\Windows\CurrentVersion\Run",
> False);
> If AutoRunChekBox.Checked then
>   Reg.WriteString(Application.Title, ParamStr(0))
> else
>   Reg.DeleteValue(Application.Title);


Данный код сработает только под учетной записью администратора. Если текущая учетная запись - "пользователь с ограниченными правами", то Reg.OpenKey() не сработает и Reg.WriteString() приведет к AV. Нужно проверять результат работы Reg.OpenKey(), как это сделано в [5]


 
PZ   (2008-01-12 18:56) [10]

>  [9] Loginov Dmitry ©   (12.01.08 10:20)

Спасибо за разъяснение.
Поскольку я у себя и пользователь и администратор неприятностей не возникало.



Страницы: 1 вся ветка

Текущий архив: 2008.10.12;
Скачать: CL | DM;

Наверх




Память: 0.49 MB
Время: 0.017 c
1-1199816989
Wolf
2008-01-08 21:29
2008.10.12
Как установить лимит по времени на некую процедуру ?


2-1220256443
Q123
2008-09-01 12:07
2008.10.12
Универсальный метод для сортировки масивов.


2-1220611069
Mundrik
2008-09-05 14:37
2008.10.12
Защита от перезаписи кодав памяти


6-1193900716
Sergl
2007-11-01 10:05
2008.10.12
Не пойму где ошибка(сокеты)...


1-1198176914
Dronishe
2007-12-20 21:55
2008.10.12
Анимация формы окна