Welcome to WebmasterWorld Guest from 54.167.0.111

Forum Moderators: open

Message Too Old, No Replies

validate yyyy-mm-dd

     

matthewamzn

1:36 am on Sep 15, 2008 (gmt 0)

10+ Year Member



I'm storing dates in a mysql database (varchar field). When someone edits a date how can I validate that the format is yyyy-mm-dd?

<form action="index.php?id=5" method="post">
Date: <input type="text" name="date" id="date" value="<?php echo $water["date"]; ?>" /><br/>
Alkalinity: <input type="text" name="alkalinity" id="alkalinity" value="<?php echo $water["alkalinity"]; ?>" /><br/>
<input type="submit" name="submit_edit" value="Submit" />
</form>

Dabrowski

6:11 pm on Sep 15, 2008 (gmt 0)

WebmasterWorld Senior Member 5+ Year Member



You really need to validate on the backend. Javascript is not 100% reliable as some browsers don't fully support it, and some users disable it.

In a matter of life and death like this, you need to be sure so validate with your own server script.

Fotiman

6:29 pm on Sep 15, 2008 (gmt 0)

WebmasterWorld Senior Member fotiman is a WebmasterWorld Top Contributor of All Time 5+ Year Member Top Contributors Of The Month



I agree with Dabrowski. If the validation is crucial, then perform it on the server side. Once you have that in place you can certainly enhance your page to also perform client side validation, but make sure you're not relying on JavaScript alone.

I would think you could use a RegExp to validate the date. Something like:

myString.match(/^\d{4}-\d{2}-\d{2}$/);

I think that would work, but I haven't tested it. In that example, myString would contain the date value you wanted to test and it would return true if the value matched yyyy-mm-dd. However, that example doesn't validate that mm isn't greater than 12, etc. In other words, this would still validate:
9999-99-99

But maybe that will get you started. :)

Dabrowski

12:52 pm on Sep 16, 2008 (gmt 0)

WebmasterWorld Senior Member 5+ Year Member



To properly validate with Javascript, you'd first have to validate the string as Fotiman suggests.

Of course, that's if the used a '-' as a separator! What if they entered yyyy/mm/dd?

I prefer to use this, that way the user can enter either and it'll still work. This will change '/' to '-' first:

myString.replace( /\//, "-"); 
if( !(myString.match(/^\d{4}-\d{2}-\d{2}$/)) {
// return with error
}

Then you'd have to split the string:

myYMD = myString.split( "-");

An easy way of checking if the date is valid is trying to set the date you're given, then seeing if it's the same. If the date is invalid the Date function will 'wrap' it to the correct day/month. e.g., if you try to set the 40th of Jan, it will wrap to 9th Feb.

So:

// Bear in mind that months start at 0 
myYMD[1]--;
myDate = new Date( myYMD[0], myYMD[1], myYMD[2]);
if( myDate.getFullYear() != myYMD[0]
&& myDate.getMonth() != myYMD[1]
&& myDate.getDate() != myYMD[2]) {
// date entered was invalid!
}