Welcome to WebmasterWorld Guest from 54.196.127.58

Forum Moderators: open

Message Too Old, No Replies

validate yyyy-mm-dd

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

Full Member

10+ Year Member

joined:Jan 27, 2005
posts: 229
votes: 0


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>
6:11 pm on Sept 15, 2008 (gmt 0)

Senior Member

WebmasterWorld Senior Member 10+ Year Member

joined:Mar 29, 2007
posts:1147
votes: 0


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.

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

Senior Member from US 

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

joined:Oct 17, 2005
posts:5003
votes: 20


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. :)

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

Senior Member

WebmasterWorld Senior Member 10+ Year Member

joined:Mar 29, 2007
posts:1147
votes: 0


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!
}
 

Join The Conversation

Moderators and Top Contributors

Hot Threads This Week

Featured Threads

Free SEO Tools

Hire Expert Members