|
chasetoys wrote: someway of locking the file from the user?
Sure there are potentially many ways to do that. While I would not advocate using any of them I can discuss it.
One technique would be to use a Database type design for your application. You would build a Windows Service to do all the file IO and use IPC to communicate between the application and the Service. This way the Service is always running and has the file opened without sharing so no other process can access it. Of course the user can always stop the service and then access the file.
The user does control the computer and if they know how the can access the file regardless of what you might do. About all you can do is make it harder for them. Of course doing that makes it harder to develop the application since more work must go into it. More analysis, design, testing, maintenance, support etc.
You might want to reconsider and stick with hidden folder and file attributes.
"What classes are you using ? You shouldn't call stuff if you have no idea what it does" Christian Graus in the C# forum
led mike
|
|
|
|
|
After reading all this, I think you should:
A) Just make the File Read-Only after your program closes it. This will keep a casual user from accidently damaging editing it. If they actually reset the read-only flag and then edit it, then they are determined and sophisticated enough that they can damage anything if they want to.
B) Make a backup copy of the file when you close your program. Put it in the Windows/System folder or somewhere similar. Yes, this will take up an additional 800 MB of extra data, but if you're worried about data integrity and safety there really is no substitute for making a backup and HD space is cheap. When your program starts back up, check the data file against the copy, if you see any differences then you know someones been messing with it and can take action.
I never cared much for trying to use Hidden files. I tried it a couple times in the past, and inevitably got a tech support call later and when I needed them to go look for, find and tell me something about that hidden file I had a heck of a time explaining to them how to "unhide" that file. (imagine a 5 second question over the phone "You're out of disk space? What's the size of the MYDATA.DAT file?" becoming a 30 minute long lesson in Windows File attributes and how to change them)
Good luck, don't forget...KISS.
|
|
|
|
|
Great advice Phil thanks! A couple of clairifications:
1) Would you advocate combining methods both A & B?
2) Would you just replace the tampered file with the one you have in the Windows directory?
3) Does Windows allow you to use the WriteFile API to write in the Windows directory? I tried to do that once but couldn't... i.e. where would you put the bacakup file, and are you sure Windows lets you do that?
4) Is there a simple API to encrypt/decrypt an ASCII text file? Or is KISS more important here?
Thanks!
|
|
|
|
|
chasetoys wrote: 1) Would you advocate combining methods both A & B?
It's by design. Feel free to use what you prefer.
chasetoys wrote: 2) Would you just replace the tampered file with the one you have in the Windows directory?
Please elaborate more detail. Not really understand what you mean.
chasetoys wrote: 3) Does Windows allow you to use the WriteFile API to write in the Windows directory? I tried to do that once but couldn't... i.e. where would you put the bacakup file, and are you sure Windows lets you do that?
A) It may be the privilege issue. The program is run as the role of "User" instead of "Administrator".
B) Or maybe you did something wrong. Show us your code snipet about creating / writing files.
chasetoys wrote: 4) Is there a simple API to encrypt/decrypt an ASCII text file?
Yes, there are some algorithms for this job, for example: DES, 3DES, AES, RSA, BlowFish, SawFish, etc. You can find those source code of the algorithms by Googling.
Maxwell Chen
|
|
|
|
|
1)From what you described as your requirements I'd do A and B, yes.
2)That depends on what you anticipate the reason for the tempering. I'd probably start out with a messagebox to the user if you detect something wrong. something like:
The database appears to have been changed or corrupted since the program was last run. Rebuilding Database, MB_OKCANCEL
This way, the user at least has an option and has been warned that he may have completely screwed things up when he fooled around with your file. As I said, if he's sophisticated and determined enough to set the read-only attribute to false, then edit the file and finally to ignore the warning message you gave him, there isn't much you can do to stop him and there may be a legitimate reason for him to do it so you can only do so much.
3) Yeah, you're right, I think there is some permission thing that XP has. OK fine, don't put it in Windows\System, but I think there's another separate "Application Data" folder somewhere that's been designated for this type of use. You should be able to find a place, just putting the copy in a completely different folder goes a long way to making thngs more secure both from a tampering issue and crash-proofing.
4) I think someone else already answered this, yes there are ways. Personally I wouldn't bother. You mentioned that your data file can get fairly large. Whatever you do to encrypt/decrypt it will cause things to slow down, introduce bugs and will probably have a lot of other drawbacks too. ie. what if YOU want to edit the file to check for bugs, problems during development? If the thing is unreadable you are only making things harder on yourself. On the other hand, if you really really don't want anyone to see what's inside (prevent unwanted reverse engineering for example) then maybe it's worth all the extra time and trouble. This one is really something only you can answer.
Good luck
|
|
|
|
|
|
Dear friends,
I am a semi-beginner in VC++ and I use MFC for writing a Robot control based application, Although I am a beginner Windows Programmer but It's been several years that I program in C.
I have a dialog based MFC application and I want to have another window without focus(modal) beside it which i can draw some graphics in(updated by some inervals by main dialog routines). If someone please give me some keywords to search and some howtos for this subject I would really appreciate it. in simple words:
1. I wanna open a new dialog from the main dialog.(I know how to do it , but I don't know how to make it in-modal)
2. I wanna draw some graphics on the new dialog.(If somebody please refer me a good article to start simple graphics in MFC , I would really appreciate it)
3.I wanna update some graphics on the window , time by time.
Thanx a lot.
PS. I am so sticky to a subject , Just show me the way and I will go beyond it to the end.
Mani Monajjemi
www.manionline.org
|
|
|
|
|
1) I don't know exactly what you are looking for. A modeless dialog or a modal dialog ? A modeless dialog is a dialog that lets the 'parent' dialog still reacts to events (and doesn't block the main 'loop'). A modal dialog is a dialog that will receive all the focus (the user won't be able to interract with the parent window anymore) and will block also the main 'program flow' (the program will block until the dialog closes). There is a good article here on CP about modeless dialogs.
2) What kind of graphics do you want to do exactly ? You can perhaps find an existing control that does what you want. Othrewise, it can be a little bit confusing to start from scratch (but still feasible, depends also of the complexity of what you want to achieve)
3) That's easy, you can simply use a timer (you'll find documentation in MSDN and it is easy to use).
Provide perhaps more information in order for us to help.
|
|
|
|
|
Hi,
could some one help me here!!
i want to acces to the bits of my Bitmap Picture but i dont know how?
i made those:
CBitmap m_bmpBitmap;
HBITMAP hBitmap // handler.
So!!
Thank you Verry Much
|
|
|
|
|
GetDIBits will give you a DIB. then use a bit of pointer arithmetic (and a whole lot of accounting for different bit depths) to get at the actual pixels.
Cleek | Image Toolkits | Thumbnail maker
|
|
|
|
|
|
I'm using the library "psapi.h" but there's an error ([Linker Error] Undefined Reference to 'EnumProcesses@12'). Someone told me I must link to psapi.lib. How can I do it??? (in one of these IDE's: Borland C++6 , Visual C++ 2005 or Dev-C++)
Thiago
|
|
|
|
|
#pragma comment( lib, "psapi")
"What classes are you using ? You shouldn't call stuff if you have no idea what it does" Christian Graus in the C# forum
led mike
|
|
|
|
|
The pragma did'nt work but here is the code:
#include <cstdlib>
#include <windows.h>
#include <tlhelp32.h>
#include <psapi.h>
#include <iostream>
#pragma comment( lib, "psapi")
using namespace std;
int main(int argc, char *argv[])
{
DWORD* t;
DWORD* returned;
DWORD tam= 40;
bool temp = EnumProcesses(t,tam,returned);
cout<<"Numero de Processos na memória: "<< *returned/sizeof(DWORD);
system("PAUSE");
return EXIT_SUCCESS;
}
Thiagooo
|
|
|
|
|
ThiagoFragoso wrote: The pragma did'nt work
Ambiguous Clarify with a professional and specific statement.
"What classes are you using ? You shouldn't call stuff if you have no idea what it does" Christian Graus in the C# forum
led mike
|
|
|
|
|
ThiagoFragoso wrote: DWORD* t;
DWORD* returned;
DWORD tam= 40;
bool temp = EnumProcesses(t,tam,returned);
Unless you have allocated sufficient memory for t and returned , your code will not work. Use:
DWORD t[150];
DWORD returned;
BOOL temp = EnumProcesses(&t,tam,&returned);
"Let us be thankful for the fools. But for them the rest of us could not succeed." - Mark Twain
"We will be known forever by the tracks we leave." - Native American Proverb
|
|
|
|
|
You might want to drop the & on the first parameter.
|
|
|
|
|
In VC2k5 you can write this code:
#pragma comment (lib, "psapi.lib")
on the header of your project (however this can be everywhere I always put it in header of main file of project)
OR (two way)
you click "Project/Project_name properties" on menu and there is "Configuraction Properties/Linker/Input" and you add this library ("psapi.lib") in "Additional Dependencies" and you can build the project
hmm but I don't know how do it in BC++ or DevC++
-----------------------------------------------------------------
Surely without war there would be no loss
Hence no mourning, no grief, no pain, no misery
No sleepless nights missing the dead... Oh, no more
No more war
[Sleepless - Cradle of Filth]
|
|
|
|
|
Thanks a lot. This solution worked for Borland C++
|
|
|
|
|
Hi,
I create a service with the following instruction:
newService = CreateService(
scm, //scm database
ServiceName, //service name
ServiceName, //display name
SERVICE_ALL_ACCESS, //access rights to the service
//SERVICE_WIN32_OWN_PROCESS, //service type first attempt
SERVICE_WIN32_OWN_PROCESS | SERVICE_INTERACTIVE_PROCESS, //second attempt
SERVICE_AUTO_START, //service start type
SERVICE_ERROR_NORMAL, //error control type
szBuffer, //service path
NULL, //no load ordering group
NULL, //no tag identifier
NULL, //no dependencies
NULL, //LocalSystem account
NULL); //no password
and inside the thread I call the GetForegroundWindow() but the result is... NULL!!!
What can I do please?
Thank you anywhere.
Alksindrs
|
|
|
|
|
Alksindrs wrote: NULL, //LocalSystem account
That account has no Desktop and therefore no windows.
"What classes are you using ? You shouldn't call stuff if you have no idea what it does" Christian Graus in the C# forum
led mike
|
|
|
|
|
ok led mike, I saw my error,
so how can I get the foreground Window with a thread if I don't now the password of the account? (not mine, of course)
|
|
|
|
|
Well I have no idea what your overall objective is but to see what is possible and how from a Windows Service you might start here[^]
"What classes are you using ? You shouldn't call stuff if you have no idea what it does" Christian Graus in the C# forum
led mike
|
|
|
|
|
Hi Ppl,
On installing projects/packages on XP I get this error mssg missing mfc7xxxxx.dll (where x varies)
Where can I get an installable copy of these runtime, or the component dll files,
for XP?
Tnx
|
|
|
|
|
See here. While it is specific to MFC v4.2, it may help to point you in the right direction.
"Let us be thankful for the fools. But for them the rest of us could not succeed." - Mark Twain
"We will be known forever by the tracks we leave." - Native American Proverb
|
|
|
|