Invalid Postback or Callback argument error in ASP.Net
First of all I will give a brief overview of Postback and Callback. When ever you register a control’s server side event, ASP.Net register a JavaScript which will submit the form’s details and on the server it fires the event which is registered for the control.
ASP.net register __doPostBack javascript function. Syntax for the script is __doPostBack(‘Event Target’,'Event Argument’); Here Event Target can be a control or it can be a function created by developer. You can also generate a postback script reference for a control by using GetPostBackScript function. Now ASP.Net page always handle the PostBack event by it self.
For Callback you have to impliment a ICallBackEventHandler interface. After implimenting ICallBackEventHandler a page must contain two events, RaiseCallBackEvent with return type void and GetCallBackResult with return type string. Your code logic will be contained in the RaiseCallBackEvent function code block and the result of the Callback will be contained returned by GetCallBackResult. Function GetCallBackResult will call the client side callback result function. I will explain CallBack in detail in my future post.
Many of ASP.Net users are facing a problem with invalid Postback or Callback argument error. Invalid PostBack or CallBack argument error is basically raise because of Event Validation feature. The EventValidation feature is a new feature in ASP.NET 2.0, and provides an additional level of checks to verify that a postback from a control on the client is really from that control and not from someone malicious using something like a cross-site script injection to try and manipulate things. It is part of our overall strategy of increasingly adding security in depth levels to the programming model — so that developers can be secure by default even if they forget to add security checks of their own.
Now, Invalid PostBack or CallBack argument error may occur when you are firing click event and the object is rebinding or its properties are changed in Page_Load event or someone is trying to hack into your system with cross site scripting. Each time .Net Framework render a page then it associate a unique Guid for all the controls. When binding a gridview or repeater, on each databind framework will associate a new guid for the contorl. So every time when you are firing event make sure Page_Load event does not change the control, because if the control changed the it will have a different Guid which have acutally fired the event for postback. Here are some scenario with this error.
1) Invalid Postback or Callback argument in GridView Problem may be: You are binding data in Page_Load event with either Object Data Source or Manual Binding with function call. This will make your GridView bind data on every event fire of any control. When you are firing any GridView command with OnRowCommand, before RowCommand fire your GridView will rebind and all control within it will be assigned to new id. So RowCommand could not get the item which have fired the event. for Invalid Postback or Callback argument in GridView: You can bind your data within this if condition
if (!IsPostBack)
{
//Your code for Bind data
}
This code will definitely give you solution if this not work then check whether any other control is not giving error.
2) Invalid Postback or Callback argument while submitting form. Problem may be: You have many textboxes and textareas and when user is entering “<” or “>” char then it is giving error. This is because of .Net framework is giving facility to validate request. This function will allow user not to submit script or html code directly so it is blocked. Solution for Invalid Postback or Callback argument while submitting form: You can replace this char with javascript before submitting the form replace “<” with “<” and “>” with “>” the javascript code is here
function ReplaceChar(obj)
{
//Here obj is your textbox object
var Textvalue = obj.value;
Textvalue = Textvalue.replace("<","<");
Textvalue = Textvalue.replace(">",">");
obj.value = Textvalue;
}
The other solution for both of this issue is to set enableEventValidation=false You can set this option declaration <@ Page > or even you can put this code in your web. config file in block
//set it true if you want to validate your each request. If you do not validate the request then your security of data will be decrease so this is not the perfect solution If both of this solution not work then you can contact me on my email and if you find any new solution please post it comment.
Resize a picture to a fixed size
This function creates a thumbnail that is exactly as big as the size you give it. The image is resized to best fit the size of the thumbnail. If it does not fit exactly in both directions, it’s centered in the thumnail.
The Function:
function thumbnail_box($img, $box_w, $box_h) {
//create the image, of the required size
$new = imagecreatetruecolor($box_w, $box_h);
if($new === false) {
//creation failed -- probably not enough memory
return null;
}
//Fill the image with a light grey color
//(this will be visible in the padding around the image,
//if the aspect ratios of the image and the thumbnail do not match)
//Replace this with any color you want, or comment it out for black.
//I used grey for testing =)
$fill = imagecolorallocate($new, 200, 200, 205);
imagefill($new, 0, 0, $fill);
//compute resize ratio
$hratio = $box_h / imagesy($img);
$wratio = $box_w / imagesx($img);
$ratio = min($hratio, $wratio);
//if the source is smaller than the thumbnail size,
//don't resize -- add a margin instead
//(that is, dont magnify images)
if($ratio > 1.0)
$ratio = 1.0;
//compute sizes
$sy = floor(imagesy($img) * $ratio);
$sx = floor(imagesx($img) * $ratio);
//compute margins
//Using these margins centers the image in the thumbnail.
//If you always want the image to the top left,
//set both of these to 0
$m_y = floor(($box_h - $sy) / 2);
$m_x = floor(($box_w - $sx) / 2);
//Copy the image data, and resample
//If you want a fast and ugly thumbnail,
//replace imagecopyresampled with imagecopyresized
if(!imagecopyresampled($new, $img, $m_x, $m_y, 0, 0, $sx, $sy, imagesx($img), imagesy($img))) {
//copy failed
imagedestroy($new);
return null;
}
//copy successful
return $new;
}
Example Usage:
$i = imagecreatefromjpeg("img.jpg");
$thumb = thumbnail_box($i, 210, 150);
imagedestroy($i);
if(is_null($thumb)) {
/* image creation or copying failed */
header('HTTP/1.1 500 Internal Server Error');
exit();
}
header('Content-Type: image/jpeg');
imagejpeg($thumb);
Becoming a Better Developer
The following list are some things I am doing to become a better developer:
1. Find/Rediscover Your Passion
I’ve always believed that to be a great developer you have to have the passion. What is passion? You know, it’s that itch you get as you sit on the couch with your wife (or your husband) watching crappy reality TV and you can’t break your thoughts away from sneaking off to write some code. It’s that desire you feel to know all there is to know about your language, the framework, emerging new technologies, etc – just because it is fun to know it. It’s that code that is always in your head, just dying to get out. You’re not content with put in 8 hours a day writing code, you just have to find that extra time to do it just because you enjoy it. So, how do you rediscover that (or find it if you’ve never had it?). I think the rest of this list will help with that.
2. Remove Distractions
There’s always things to get in your way of improving yourself and staying focused on your goals. If you work at your home, like me, turn off the TV, shut the office door, establish a “work mode” that separates itself from “home mode”. I find it helps to turn off notification sound from Yahoo Messenger or whatever messenger do you use as well as other distracting notifications. I found that my eyes would automatically shift to the bottom right corner of my monitor every time that “ping” sound would occur. I think part of “removing distractions” involved establishing routine to some degree.
3. Blog
I’ve taken the first step here with reviving my fathir.com blog. My belief is that, while you can learn a lot from reading from other blogs, you’ll learn 10x that by writing posts yourself. The process of thinking through a topic enough to write about it is far more valuable than just reading about that same topic. Any time you can “teach” others, you’ll end up growing as a developer by leaps and bounds. This has been my experience throughout my entire career, and I do love teaching others.
4. Learn a New Technology Each Month
For me, this is something that without questions comes out when i see something. The problem is that there are just so many things I want to really learn well and I need some focus or I won’t learn enough of any of them.
5. Read and Write
the best thing you can do to be a better programmer is read. Not reading books, but reading other people’s code. I’ll take that one a step further. Not only does reading other people’s code help you become a better programmer, but getting involved in writing the code as well will take you even further.
Well, there you go. My thoughts on ways to improve myself as a developer. Wish me luck and hope you’ll find this helpful.
Customizing the Calendar control in ASP.NET
Recently I had to work on customizing an ASP.NET Calendar control by adding text to the day cells for my team’s Logon Message project. This proved to be not as straight-forward as I thought so here is what I did in case someone else might want to do the same.
The best place to modify the text in a cell seems to be the DayRender event handler. So the first thing I tried was to just modify the e.Cell.Text property like this:
void Calendar1_DayRender(object sender, DayRenderEventArgs e)
{
e.Cell.Text += “My text”;
}
The main problem was that after adding text to a day cell in the control I wasn’t able to select that day by clicking on the day number. Here is what you can do if you still want the select day functionality:
void Calendar1_DayRender(object sender, DayRenderEventArgs e)
{
AddTextToDayCell(e, Datetime.Today, “MyText“);
}
void AddTextToDayCell(DayRenderEventArgs e, Datetime d, string text)
{
if(e.Day.Date == d.Date)
{
string ID = ((System.TimeSpan)(e.Day.Date - new DateTime(2000, 1, 1))).Days.ToString();
e.Cell.Text = "<a href=\"javascript:__doPostBack('Calendar1','" + ID + "')\" style=\"color:#663399\">" + e.Day.DayNumberText; //assuming the name of the calendar control is Calendar1.
e.Cell.Text +=text;
}
}
If you want your new text to act as a link to some other URL, you could modify the AddTextToCell function as follows:
private void Calendar1_DayRender(object sender, System.Web.UI.WebControls.DayRenderEventArgs e)
{
AddTextToDayCell(e, DateTime.Today, "MyText", "<a href="http://fathir.com/">http://fathir.com</a>"); //this will add the MyText link to <a href="http://fathir.com/">http://fathir.com</a> to the current day's cell
}
void AddTextToDayCell(DayRenderEventArgs e, DateTime d, string text, string URL)
{
if(e.Day.Date == d.Date)
{
string ID = ((System.TimeSpan)(e.Day.Date - new DateTime(2000, 1, 1))).Days.ToString();
e.Cell.Text = "<a href=\"javascript:__doPostBack('Calendar1','" + ID + "')\" style=\"color:#663399\">" + e.Day.DayNumberText;
e.Cell.Text += "<br /> <a href=\""+ URL + "\">" + text;
}
}
Hope you’ll find this helpful.
Editing the Windows Registry
In this tutorial, I’m going to go through the code required to edit the Windows registry using C#. This will include creating new keys and values as well as modifying existing ones.
The registry is a great way to save information between application launches. Many applications use the registry to save information about dialog sizes and placements. That way the user doesn’t have to resize and move dialogs every time the program starts.
Let’s start by creating a new registry key. The first thing we need to decide is where to put our new key. If you bring up the Registry Editor – type “regedit” in the run bar, you’ll notice the registry looks a lot like a file explorer. “Computer” is the root node with several child folders branching from it.
Most software packages will have a registry key inside
HKEY_LOCAL_MACHINE->SOFTWARE
These keys are available no matter who is logged in and is a good place to stick general application values. Let’s put a key in this folder called “My Registry Key”.
Registry is a class located in the Microsoft.Win32 namespace. Registry.LocalMachine means where going to be modifying the HKEY_LOCAL_MACHINE registry key. We passed in “SOFTWARE\\My Registry Key” to CreateSubKey because we wanted our new key created inside the “SOFTWARE” key. CreateSubKey has the option to take more arguments – mostly dealing with access and security, but they’re not important for this tutorial.
If you open the Registry Editor again, you’ll now see you’re new key. A key without any values is pretty useless, so let’s add a string value to it.
myKey.SetValue(“My String Value”, “Test Value”, RegistryValueKind.String);
The OpenSubKey method is called to get a reference to our newly created key. It takes the path to the key, which is the same as when creating it, and it takes a boolean indicating whether or not we want to open it writable. Since we want to add a new value to this key, we want to set this to true.
Next, we simply call SetValue to create our new value. The SetValue function takes the name of the value as the first argument, the actual value as the second, and the type of value as the third. The RegistryValueKind enumeration has lots of different kinds of data, so most primitive types can be stored in the registry. If the value you’re trying to set doesn’t exist yet (like in this case), SetValue will create it for you.
Now let’s look at how to get values back out of the registry. It’s very similar to setting values and equally as easy.
string myValue = (string)myKey.GetValue(“My String Value”);
//myValue now equals “Test Value”
We get a reference to our key exactly like we did before except this time we pass false for the writable argument. A call to GetValue is then made to retrieve the value from the registry. This function returns an object, so it must first be cast to your desired type – in this case string. It’s always wise to check that the return value is not null before casting it since it is possible that the registry value you’re trying to read doesn’t exist.
How to Minimize an Application to the Taskbar Tray in C#
One very convenient features in windows is the Taskbar. To make it even better, those little icons can make something so “out of the way” that you can forget what is even down there. But, sometimes you want your applications to hang down there, out of the way, doing something that requires little attention. You can even make some notification bubbles show up if you want.
Today I am going to be using Visual Studio Express 2008, and luckily this makes things really easy. I am assuming that you know how to create a new project, so once you have one open, we can get started. I named my “HideTaskBar”, but as always, any name is fine.
This whole process revolves around an object named NotifyIcon. Like most .NET objects, this one is designed to make the job easier. With it we can give our application its very own cute icon in the taskbar, and notify our users of important information. Of course, to start you need to add the object to your form, so go ahead and do that. The object is a common control.
The NotifyIcon’s Properties
The first thing you absolutely must do is set the Icon property. This can be found in the properties window when you have the NotifyIcon object selected. If you don’t, nothing will show up in the taskbar tray.
Moving on to our code, the first thing we need to do is “hide” the form when we minimize it. To do this, we simply tie the action to the resize event. This is crude at best, but for this tutorial it gets the point across:
Hide();
As I stated above, this simple code goes in the resize event of the form. We are checking to see if the form is minimized, if it is, we hide it. It’s that simple. Now we have to setup an “un-minimize” event that will show our app when we double click the icon. If you take a look at the NotifyIcon object, you will notice a DoubleClick event. How convenient, huh?
What we have to do on the event is show the form, then set its WindowState to normal:
WindowState = FormWindowState.Normal;
Again, that simple. But, we can do a little more. How about adding a some notifications? Yeap, the NotifyIcon object can do that as well. Windows calls them bubbles, and you can access them through the object. Let’s go ahead and add one to notify us of the minimization of the app:
{
Hide();
notifyIcon1.BalloonTipTitle = “APP Hidden”;
notifyIcon1.BalloonTipText = “Your application has been minimized to the taskbar.”;
notifyIcon1.ShowBalloonTip(3000);
}
This will make a balloon tip pop up and notify us from the taskbar. As you can imagine the possibilities are pretty endless as far as the NotifyIcon object goes. You can use this pretty much anywhere, so any action can have a balloon tip. In fact, no one even said you have to use the notification icon for minimizing.
Now we know what is going on.
Make Transparent Effects in PowerPoint 2007
Sometimes we need a clip art image that appears transparent in our PowerPoint presentation. For example, as the background of a paragraph that mixed with the original background image.
To do the following steps:
- Click on the Insert ribbon tab and click the button on the Clip Art
- Click the Go button in the panel and select Clip Art Clip Art, and put in the presentation
- Make a right click on clip art and select Group -> Ungroup
- On the question “Do you want to convert …?” click Yes
- Do it again, right click on the clip art and select Group -> Ungroup
- In the clip art is still selected, open the Format ribbon click on the Shape Fill button and select More Fill Colors
- Select colors and transparency values that match your background and click the OK button
- If there is any area of the square with the clip art images, simply click on the area of a square and pressing the delete key
Installing and Using Add-in: Microsoft Save as PDF
How to install:
- Download file SaveAsPDF&XPS di www.microsoft.com link:
http://download.microsoft.com/download/b/5/3/b5370004-d59d-493f-b005-2299ffca8596/SaveAsPDF.exe - Then click 2 times on SaveAsPDF & XPS file in the folder where you save downloaded earlier
- License Agreement screen appears, click on “Click here to accept …” and click Continue
- Then wait until the installation is finished, and press OK
Then the steps to save the file to PDF from Microsoft Office 2007 are:
- Create a document with Microsoft Office or Microsoft Excel
- Once completed, click Home and then click continue to select Save As PDF or XPS
- Then you specify the file name and select the PDF file type. Click Publish. So your document in the form of PDF files.
Current WHO phase of pandemic alert
Current phase of alert in the WHO global influenza preparedness plan
In the 2009 revision of the phase descriptions, WHO has retained the use of a six-phased approach for easy incorporation of new recommendations and approaches into existing national preparedness and response plans. The grouping and description of pandemic phases have been revised to make them easier to understand, more precise, and based upon observable phenomena. Phases 1–3 correlate with preparedness, including capacity development and response planning activities, while Phases 4–6 clearly signal the need for response and mitigation efforts. Furthermore, periods after the first pandemic wave are elaborated to facilitate post pandemic recovery activities.
The current WHO phase of pandemic alert is 5.

In nature, influenza viruses circulate continuously among animals, especially birds. Even though such viruses might theoretically develop into pandemic viruses, in Phase 1 no viruses circulating among animals have been reported to cause infections in humans.
In Phase 2 an animal influenza virus circulating among domesticated or wild animals is known to have caused infection in humans, and is therefore considered a potential pandemic threat.
In Phase 3, an animal or human-animal influenza reassortant virus has caused sporadic cases or small clusters of disease in people, but has not resulted in human-to-human transmission sufficient to sustain community-level outbreaks. Limited human-to-human transmission may occur under some circumstances, for example, when there is close contact between an infected person and an unprotected caregiver. However, limited transmission under such restricted circumstances does not indicate that the virus has gained the level of transmissibility among humans necessary to cause a pandemic.
Phase 4 is characterized by verified human-to-human transmission of an animal or human-animal influenza reassortant virus able to cause “community-level outbreaks.” The ability to cause sustained disease outbreaks in a community marks a significant upwards shift in the risk for a pandemic. Any country that suspects or has verified such an event should urgently consult with WHO so that the situation can be jointly assessed and a decision made by the affected country if implementation of a rapid pandemic containment operation is warranted. Phase 4 indicates a significant increase in risk of a pandemic but does not necessarily mean that a pandemic is a forgone conclusion.
Phase 5 is characterized by human-to-human spread of the virus into at least two countries in one WHO region. While most countries will not be affected at this stage, the declaration of Phase 5 is a strong signal that a pandemic is imminent and that the time to finalize the organization, communication, and implementation of the planned mitigation measures is short.
Phase 6, the pandemic phase, is characterized by community level outbreaks in at least one other country in a different WHO region in addition to the criteria defined in Phase 5. Designation of this phase will indicate that a global pandemic is under way.
During the post-peak period, pandemic disease levels in most countries with adequate surveillance will have dropped below peak observed levels. The post-peak period signifies that pandemic activity appears to be decreasing; however, it is uncertain if additional waves will occur and countries will need to be prepared for a second wave.
Previous pandemics have been characterized by waves of activity spread over months. Once the level of disease activity drops, a critical communications task will be to balance this information with the possibility of another wave. Pandemic waves can be separated by months and an immediate “at-ease” signal may be premature.
In the post-pandemic period, influenza disease activity will have returned to levels normally seen for seasonal influenza. It is expected that the pandemic virus will behave as a seasonal influenza A virus. At this stage, it is important to maintain surveillance and update pandemic preparedness and response plans accordingly. An intensive phase of recovery and evaluation may be required.
source : http://www.who.int/csr/disease/avian_influenza/phase/en/index.html
How to open Firefox faster
Have you ever noticed on how fast IE loads compared to Firefox? That is because XP preloads IE on its start-up.
After some research i found that Firefox developers have chosen not to tie up system resources before they really need it, but if you want it to load fast it is possible to achieve that by doing the same thing as what IE does.
1. Put your Firefox shortcut onto you start menu. Easier way of doing this is if you have a shortcut on your desktop drag it onto you start button on your button left.
2. Right click on the shortcut in the start menu and then ‘Properties’. Find the target section which should contain something similar [ "C:\Program Files\Mozilla Firefox\firefox.exe" ] , add ‘/Prefetch:1′ next to the address (without the inverted commas). SO the target box should contain what is in the square brackets as follows [ "C:\Program Files\Mozilla Firefox\firefox.exe" /Prefetch:1 ]

Now by doing this Windows XP should preload Firefox on its start-up, so Firefox loads as fast as IE.
source : http://www.trap17.com/index.php/how-make-firefox-load-faster-known-firefox-tweaks_t39012.html