How to find client information in asp.net
There are several different approaches you can take.
One approach should be to register each IP address. The problem is that there are a lot of people behind the routers. If you prevent users from voting by ip address, you can block people who have not yet voted.
A second approach is to require the user to log in. This is the most reliable way to prevent users from voting more than once. It is also the most active part. You can reduce the workload by using the ASP.NET Membership Provider.
A third approach is to set a cookie on the user's computer. They can easily delete a cookie, but most users don't know what they are and don't care.
source to share
It's tricky and I'm sure you'll have to compromise in some way.
-
Check the IP address in how to find client information in asp.net and HTTP_FORWARDED, the problem is that any IP address is easily spoofed and two people can use the same computer and / or have a dynamic IP: s
-
Send a confirmation email
-
User must register in your system
-
Require OpenId
I would go to number 4
source to share
Get the MAC address from the remote computer and track it.
want to get the MAC address of the remote PC
However, this would be more complicated in C # as I am pretty sure you cannot do it with .NET since you will need to use ManagementObjects which probably won't work.
However, if you are doing this from asp.net, you can do the Java thing by inserting it into an asp.net page and calling it as needed.
source to share
If you want a simple and reliable solution, just use the cookie mechanism .
You need to try reading Cookie first: http://msdn.microsoft.com/en-us/library/aa287533%28VS.71%29.aspx
HttpCookie myCookie = new HttpCookie("MyTestCookie");
myCookie = Request.Cookies["MyTestCookie"];
if (myCookie != null)
//User has already voted.
else
//User can vote.
If the cookie doesn't exist you allow voting, after voting you just write a cookie in response: http://msdn.microsoft.com/en-us/library/aa287547%28VS.71%29.aspx .
HttpCookie myCookie = new HttpCookie("MyTestCookie");
Response.Cookies.Add(myCookie);
source to share