Torna indietro   Hardware Upgrade Forum > Software > Programmazione

OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
Abbiamo partecipato all'OVHcloud Summit 2025, conferenza annuale in cui l'azienda francese presenta le sue ultime novità. Abbiamo parlato di cloud pubblico e privato, d'intelligenza artificiale, di computer quantistici e di sovranità. Che forse, però, dovremmo chiamare solo "sicurezza"
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Abbiamo potuto mettere le mani in anteprima sul nuovo monitor MSI dedicato ai giocatori: un mostro che adotta un pannello QD-OLED da 26,5 pollici con risoluzione 2560 x 1440 pixel, frequenza di aggiornamento fino a 500 Hz e tempo di risposta di 0,03 ms GtG
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI aggiorna la sua linea di droni ultraleggeri con Neo 2, un quadricottero da 160 grammi che mantiene la compattezza del predecessore ma introduce una stabilizzazione meccanica a due assi, sensori omnidirezionali e un sistema LiDAR
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 21-06-2009, 15:27   #1
uReverendo
Member
 
L'Avatar di uReverendo
 
Iscritto dal: May 2006
Messaggi: 69
[C#] Bloccare un computer con WinXP32

Devo scrivere un programma che una volta eseguito, magari all'avvio del sistema, blocchi il computer.
In pratica l'utente interagirà solo con il mio programma. Se si verificano delle condizioni il programma sbloccherà il computer e permetterà all'utente di utilizzarlo. Se durante l'utilizzo queste condizioni vengono meno, il computer sarà nuovamente bloccato.

Per comodità e per mancanza di tempo, il programma per verificare le condizioni intendo scriverlo in C# e quindi escluderei (per ora) un GINA, a meno che non mi diciate come far interagire il mio GINA con C#.

Mi interessa soprattutto capire a livello teorico come muovermi e come organizzare il lavoro inquanto sono quasi completamente a digiuno sull'argomento.
Qualche consiglio?
uReverendo è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2009, 16:48   #2
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Stando a questo documento direi che puoi usare solo il buon caro vecchio C/C++ per personalizzare il logon:
http://support.microsoft.com/default...oduct=NETFrame
Generalmente si personalizza GINA.dll per procedue di accesso custom es. lettori di impronte digitali o token USB.

In ogni caso una volta effettuato il logon, per bloccare l'utente, dovresti richiamare LockWorkStation, da un applicativo che non sia un servizio, ma che può essere tranquillamente un applicativo C#.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2009, 12:07   #3
uReverendo
Member
 
L'Avatar di uReverendo
 
Iscritto dal: May 2006
Messaggi: 69
Utilizzare LockWorkStation è la soluzione più razionale, ma purtroppo implica la scrittura di un GINA.

Infatti dopo aver bloccato il compuer, credo che l'unico modo per sbloccarlo al verificarsi delle condizioni sia far restituire WLX_SAS_ACTION_UNLOCK_WKSTA alla funzione WlxWkstaLockedSAS di GINA. Quindi la verifica delle condizioni deve avvenire in quella funzione di GINA percui non posso usare C#.

Preferisco usare C# inquanto devo collegarmi ad un'istanza di SQLSERVER 2005 EXPRESS ed eseguire strored procedure con parametri (sia di input che di output). Utilizzando il C/C++ non saprei da dove iniziare.

Esiste un modo per ottenere un risultato simile a LockWorkStation ma che permetta alla mia applicazione C# di gestire il tutto?

In pratica quando il computer è bloccato l'utente vedrà solo la mia interfaccia.
uReverendo è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2009, 19:40   #4
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
be', se il problema del C++ é che non sai come accedere al database posso indicarti OLE DB: http://msdn.microsoft.com/en-us/libr...84(VS.85).aspx

altrimenti non potresti sviluppare parte dell'applicazione in C# e parte in C++? in C# é possibile importare funzioni dalle DLL native, oppure puoi anche sfruttare l'interoperabilitá di COM ma in questo caso é piu difficile, penso che a te basti una DLL nativa che esporta qualche funzione.
fero86 è offline   Rispondi citando il messaggio o parte di esso
Old 23-06-2009, 11:48   #5
uReverendo
Member
 
L'Avatar di uReverendo
 
Iscritto dal: May 2006
Messaggi: 69
Leggendo la prima riga del link mi è sorto un dubbio:
Quote:
Originariamente inviato da MSDN
OLE DB is a set of COM-based interfaces that expose data from a variety of sources.
Essendo OLE DB un set di interfacce COM posso utilizzarle in GINA?
Stando al documento linkatomi da tomminno no. Non vorrei perdere tempo a studiarmi qualche cosa che non posso utilizzare. Hai info a riguardo?

Quote:
Originariamente inviato da fero86 Guarda i messaggi
altrimenti non potresti sviluppare parte dell'applicazione in C# e parte in C++?
Se devo scrivere un GINA no, devo fare tutto in C/C++.
Se riesco a fare a meno del GINA certo che si... il punto è come bloccare il computer senza l'ausilio di LockWorkStation e GINA.
uReverendo è offline   Rispondi citando il messaggio o parte di esso
Old 23-06-2009, 17:30   #6
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
Quote:
Originariamente inviato da uReverendo Guarda i messaggi
Leggendo la prima riga del link mi è sorto un dubbio:

Essendo OLE DB un set di interfacce COM posso utilizzarle in GINA?
Stando al documento linkatomi da tomminno no. Non vorrei perdere tempo a studiarmi qualche cosa che non posso utilizzare. Hai info a riguardo?
non mi ero accorto di questo problema perché non avevo letto il link di tomminno; non ho altre informazioni a riguardo ma il fatto é che se anche ipoteticamente OLE DB funzionasse senza problemi quando usato da un GINA (che é possibilissimo) potrebbe smettere di funzionare non appena il sistema subisce un aggiornamento oppure potrebbe non funzionare affatto su versioni future del sistema operativo.
come spiegato eloquentemente dal link, i frameworks elencati non sono stati progettati per essere usati in "core processes" del sistema operativo; quando Microsoft modifica l'architettura di quelle parti del sistema quei frameworks probabilmente non li testa neanche.

quindi direi che quello che puoi fare é sviluppare una DLL GINA che apre una named pipe e tramite di essa comunica con un servizio che accede al database; il servizio puoi scriverlo interamente in C# (vedi http://msdn.microsoft.com/en-us/libr...ceprocess.aspx). come meccanismo di IPC ti consiglio la named pipe perché secondo me é il piu adatto dovendo utilizzare solo API C Win32 nude e crude, inoltre ti consiglio di usare un GUID come nome della named pipe.


Quote:
Se devo scrivere un GINA no, devo fare tutto in C/C++.
Se riesco a fare a meno del GINA certo che si... il punto è come bloccare il computer senza l'ausilio di LockWorkStation e GINA.
é possibilissimo ma qualunque soluzione ti venga in mente fará sicuramente accapponare la pelle; da quanto ho capito quello che devi fare tu é proprio di scrivere un GINA, peró non é escluso che tu possa sviluppare l'applicazione in piu parti comunicanti (vedi sopra).
fero86 è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2009, 11:52   #7
uReverendo
Member
 
L'Avatar di uReverendo
 
Iscritto dal: May 2006
Messaggi: 69
Quote:
Originariamente inviato da fero86 Guarda i messaggi
quindi direi che quello che puoi fare é sviluppare una DLL GINA che apre una named pipe e tramite di essa comunica con un servizio che accede al database; il servizio puoi scriverlo interamente in C# (vedi http://msdn.microsoft.com/en-us/libr...ceprocess.aspx). come meccanismo di IPC ti consiglio la named pipe perché secondo me é il piu adatto dovendo utilizzare solo API C Win32 nude e crude, inoltre ti consiglio di usare un GUID come nome della named pipe.
Se implementerò un GINA seguirò il tuo consiglio.

Nel frattempo ho trovato una soluzione alternativa molto semplice:
- creo un nuovo desktop (CreateDesktop());
- eseguo sul desktop appena creato il mio programma (CreateProcess());
- attivo il nuovo desktop (SwitchDesktop()).

Tutto qui, tre API richiamabili tramite interop che riproducono il comportamento che voglio, permettere all'utente di interagire solo con il mio programma.

Dici che fa accapponare la pelle come soluzione?
uReverendo è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2009, 13:23   #8
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
Quote:
Originariamente inviato da uReverendo Guarda i messaggi
Dici che fa accapponare la pelle come soluzione?
si: é sufficiente che l'utente esegua una chiamata SwitchDesktop in qualche modo, per esempio tramite un programma registrato su un CD con Autorun oppure se il programma é un programma "a tempo" messo in esecuzione dall'utente prima che la workstation venisse bloccata.

una soluzione potrebbe essere quella di modificare la DACL del desktop iniziale ("Default") e togliere all'utente il permesso necessario per fare lo switch, ma resta il fatto che l'utente é proprietario del desktop di default, e il proprietario di un oggetto puó sempre cambiare i permessi dell'oggetto.

un'altra soluzione orripilante sarebbe invece quella di installare un low level hook sia per il mouse che per la tastiera che non faccia altro che restituire 1 senza chiamare CallNextHookEx; chiaramente fa schifo anche questa ma perlomeno in questo caso, visto che i debug hook non possono intercettare i low level hooks, non riesco a trovare alcuna scappatoia ammettendo che il tuo programma venga avviato prima di ogni altro possibile programma messo in esecuzione dall'utente.

comunque la soluzione migliore é sempre quella del GINA.
fero86 è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2009, 14:01   #9
uReverendo
Member
 
L'Avatar di uReverendo
 
Iscritto dal: May 2006
Messaggi: 69
Grazie mille, sei stato molto chiaro.

Scriverò un GINA.
uReverendo è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI C...
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro DJI Neo 2 in prova: il drone da 160 grammi guada...
L'IA "seria" di Appian è diversa: inserita nei processi e rispetta dati e persone L'IA "seria" di Appian è divers...
Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Windows 11 è un disastro: ha biso...
BYD domina in Italia tra le elettriche: ...
Li abbiamo scovati nel catalogo Amazon: ...
Samsung Galaxy S26: la ricarica wireless...
Quale sarà il prezzo della Steam ...
Xiaomi 17 Ultra è sempre pi&ugrav...
Prezzi alle stelle della memoria RAM, se...
Torna MacBook Air con chip M4 scontato d...
Torna a soli 25,40€ il caricatore multip...
L'India chiede ai produttori di smartpho...
Apple cambia tutto sull'intelligenza art...
AWS Transform si evolve: agenti IA per m...
I social network hanno stancato gli ital...
Star Citizen supera i 900 milioni di dol...
Netflix ha eliminato la funzione Cast pe...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 09:58.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v