|
I have debugged the code by creating sample DLL and an application uses it
now what i have faced that when am trying to debug the function called from another dll.The debugger avoids it and gives the result of the function and continue proceed further.
not fired any error as like you.
Knock out 'T' from CAN'T
You 'CAN' if you think you 'CAN'
-- modified at 1:03 Saturday 6th May, 2006
|
|
|
|
|
Hello,
Is there a way for me to change the timeouts
assoicated with the CSocket class? In paticular I need to modify the
timeout used for Connect(). In my case, it takes about 15 secs for it to timeout now, and i'm working with around 25 sockets, so the time could add up if i'm unable to connect to any of them...
Note: I was using CAsyncSockets before, and all my connects came back with 'wsaewouldblock', which was ok, but the problem I was having is, after closing all the sockets (even one's that were not connected), and when the destructor cleans up, my program was crashing in 'sockcore.cpp' (Assertion failure). I do not see this problem switching to CSocket, thus the reason for the switch.
Thanks
|
|
|
|
|
arunkk1 wrote: I need to modify the
timeout used for Connect()
My socket is a little rusty so I may be wrong. I think timeouts are TCP/IP stack configuration settings. So they effect the entire machine. I don't think there is an API to change them directly. It is possible that there are registry keys and values that are OS dependent that contain the configuration. I also vagely remember the connection Timeout is not a straight time based mechanism but involves retry configuration that might be something like TcpMaxConnectRetransmissions.
Anyway if you do not get more specific answers here there are surly MSDN articles and Knowledge Base stuff on that.
"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
|
|
|
|
|
Hey folks:
Right now we have an ASCII tab-delimited data file that is used in our applications. We really don't want the user accessing this file as they could really mess up the application by screwing up the data file.
Simply by making the file hidden is security by obfuscation, and we want someway of hiding the data.
Ideally, we wouldn't have to encrypt file, perhaps there's a way of preventing the USER from modifying this file, and only allowing our application to access it... someway of locking the file from the user?
I'm a C++/Win32 API newbie, so please make the answers appropriate for someone of my skill. Hopefully there is some easy way of doing this,
David
|
|
|
|
|
chasetoys wrote: someway of hiding the data
1) Host the data file in some directory where the user wouldn't easily find. For example: C:\WINDOWS\system32\foobar\data\
2) Rather than to store data in files, storing the data in the registry.
3) Use some fake name, for example "foobar.DLL", to name the data files.
4) ......
Maxwell Chen
|
|
|
|
|
Another alternative would by to put the data in the .EXE as a resource.
Steve
|
|
|
|
|
Stephen Hewitt wrote: Another alternative would by to put the data in the .EXE as a resource.
1) If the data is increasing, the EXE increases the size then? (I guess YES.)
2) Personally I think that if the data size is relative too large (for ex: 800 MB), it would be not suitable to merge in EXE.
Maxwell Chen
|
|
|
|
|
I think yes increasing and I suggest use from one algorithm coding
|
|
|
|
|
My point is:
Let's say the EXE is now 800 MB as we use a smart algorithm to manage the resource in EXE.
But launching the program might take maybe 5 seconds because we used to have the anti-virus installed. And there is the On-Access scan.
Maxwell Chen
|
|
|
|
|
but why should exe file 800 MB?
you can break this exe file to a little files ( I suggest dll) I think that its not idea exe 800 MB, right?
|
|
|
|
|
You did not follow our discussion.
Stephen suggested to put the original poster's data in the resource portion inside the EXE.
Let's say,
the real executable code of the EXE is just 2M in size (which should be average);
user keeps adding data (thus into the EXE) (for example: all those TEL numbers from a phone book). It results in a 800 MB sized EXE file.
Maxwell Chen
|
|
|
|
|
yes I see suggestion Stephen and I agree with you that we have increasing
oh yes you said if we enter data to resource we have a big file
|
|
|
|
|
Stephen Hewitt wrote: Another alternative would by to put the data in the .EXE as a resource.
Another issue is: We have to export the data (separate the data from EXE) before we upgrade / replace the EXE.
Maxwell Chen
|
|
|
|
|
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
|
|
|
|