防止自动注册代码(from dotnetbips.com)

类别:.NET开发 点击:0 评论:0 推荐:
Preventing Automated Web Site Registrations Introduction

Many heavily trafficked public portals provide features such as free emailing services, on-line storage etc. Webmasters administrating these sites always want to make sure that the users registering with their sites are "real" users instead of automated one. Take an example of MSN registration, when you go to their registration page and fill in the details they display a small randomly generated image with some text. The user is supposed to enter the text in the textbox provided on the form which confirms that the person is physically registering with the site. In this article I will show you how to develop similar mechanism for your ASP.NET applications.

GDI+ and Random class

GDI+ classes allow you to easily generate graphics on the fly and display in the web pages. We will be using these classes along with Random class to develop our solution.

Generating random strings

First we need to device a mechanism that will give us a randomly generated string with each request to the page. Following routine does exactly the same.

public static string GetRandomString(int length) { int intZero=0, intNine=0, intA=0, intZ=0, intCount=0, intRandomNumber=0; string strRandomString; Random rRandom =new Random(System.DateTime.Now.Millisecond); intZero = '0'; intNine = '9'; intA = 'A'; intZ = 'Z'; strRandomString = ""; while (intCount < length) { intRandomNumber = rRandom.Next(intZero, intZ); if(((intRandomNumber >= intZero) && (intRandomNumber <= intNine) || (intRandomNumber >= intA) && (intRandomNumber <= intZ))) { strRandomString = strRandomString + (char)intRandomNumber; intCount = intCount + 1; } } return strRandomString; }

The function accepts the length of the string to be generated and constructs a random string using Random class. We will not go into details of the logic used as it is simple and clear from above routine.

You will find above function in the RandomString.cs file available in the download.

Generating and outputting image on the fly

Next step is to generate images on the fly and output on the response stream.

Bitmap bmp=new Bitmap(100,30); Graphics g=Graphics.FromImage(bmp); g.Clear(Color.Navy); string randomString=preventautopost.RandomString.GetRandomString(6); Session["randomstring"]=randomString; g.DrawString(randomString,new Font("Courier",16), new SolidBrush(Color.WhiteSmoke),2,2);

Here, we create an instance of Graphics class from an Image (represented by Bitmap class). We  then draw the randomly generated string on this bitmap and save the image to the Response.

You will find this code in the randomimagepage.aspx file available in the download.

Building the registration form

Finally you will develop a registration form which will display the randomly generated image in an Image control. You will find the code and markup in registrationform.aspx available in the download. One important to note in the web form markup is the following line:

<asp:Image id=Image1 runat="server" ImageUrl="randomimagepage.aspx" />

Note how the ImageUrl property is set to the previous web form that emits the dynamic image on the response stream. Once the user submits the form we check the entered random code against what was generated.

string str=(string)Session["randomstring"]; if(str!=TextBox4.Text) { Label5.Text="Random string verification failed!"; } else { Label5.Text="Validation successful!"; //do database insert here } Source Code Download

Complete source code in C# is including web forms and image generation logic is available along with the article.

Summary

Automated form submission is a matter of concern for many large portals - specially offering services such as free email. If you are developing such a web site it would be nice to provide some way in your application that will ensure that users are filling the registration forms themselves rather than an automated system. In this article we accomplished this goal using GDI+ classes and Random string generation logic.

About the author

Name :

Bipin Joshi

Email :

webmaster at dotnetbips.com

Profile :

Bipin Joshi is the webmaster of DotNetBips.com. He is the founder of BinaryIntellect Consulting (www.binaryintellect.com) - a company providing training and consulting services on .NET framework. He conducts intensive training programs in Thane/Mumbai for developers. He is also a Microsoft MVP (ASP.NET) and a member of ASPInsiders.

本文地址:http://com.8s8s.com/it/it42113.htm