PHP Form Submission: Recognize Image Input Buttons

By  on  

As you probably know, you can recognize a form submission from a "submit" input type by placing the following code in the "processing" PHP script:

if(isset($_POST['submit'])) { /* do stuff */ }

Did you know, however, that when using an "image" input type to submit the form, the above wont work? You need to add a "_x" to the field name in PHP:

if(isset($_POST['submit_x'])) { /* do stuff */ }

Odd, huh? This works the same when using a form "GET" method.

Recent Features

  • By
    7 Essential JavaScript Functions

    I remember the early days of JavaScript where you needed a simple function for just about everything because the browser vendors implemented features differently, and not just edge features, basic features, like addEventListener and attachEvent.  Times have changed but there are still a few functions each developer should...

  • By
    Regular Expressions for the Rest of Us

    Sooner or later you'll run across a regular expression. With their cryptic syntax, confusing documentation and massive learning curve, most developers settle for copying and pasting them from StackOverflow and hoping they work. But what if you could decode regular expressions and harness their power? In...

Incredible Demos

  • By
    GitHub-Style Sliding Links

    GitHub seems to change a lot but not really change at all, if that makes any sense; the updates come often but are always fairly small. I spotted one of the most recent updates on the pull request page. Links to long branch...

  • By
    Display Images as Grayscale with CSS Filters

    CSS filters aren't yet widely supported but they are indeed impressive and a modern need for web imagery.  CSS filters allow you to modify the display of images in a variety of ways, one of those ways being displaying images as grayscale. Doing so requires the...

Discussion

  1. The _x and _y represent the coordinate location you clicked the image at.

  2. Think this is only an issue with IE.

  3. Yeah. The _x- and _y-coordinates are great for improving the security of a form! I’ve used this to determine if the form has been filled by a human. A spam-bot won’t submit any coordinates but a human has to click on the button and so there will always be coordinates (you’ll have to deactive submitting with the ENTER-button).

  4. @Matthias: Good point on the security enhancement — I’ve never though of that!

  5. Braxo

    @ Matthias

    Thanks for posting your comment. I think telling the user that the ENTER button has been deactivated for bot protection is easier than having the user type in a captcha.

    I’ll definitely be looking into that method and most likely incorporating it into my projects.

  6. @Braxo – Wait – “Enter button” is deactivated? How would this affect someone who cannot use a mouse/relies on accessibility tools to fill out forms and the like?

    Some sites cannot get away with it (coughtargetcough).

  7. You can save yourself the trouble and just give the input a name attribute and check for that. Saves from changing code in two places (the input and the PHP submit validation).

    <input type="image" src="image.png" name="submitted" value="Submit" />

  8. I should clarify that…

    It saves from changing code in 2 places should you want to change to/from an image submit or a standard submit.

Wrap your code in <pre class="{language}"></pre> tags, link to a GitHub gist, JSFiddle fiddle, or CodePen pen to embed!