I have a mssql database in which my primary keys are GUIDs. I am working on a web interface for inserting some data. I need a GUID, generated by php. I am using com_create_guid() function. So, before trying to insert I want to ensure that my parameters are valid. I can not find a way to check if a string(com_create_guid() returns string) is a valid GUID.
Advertisement
Answer
Considering a GUID is defined as something like this : “A98C5A1E-A742-4808-96FA-6F409E799937” (from what the wikipedia page says)
I suppose using a regex like this one would do :
$guid = 'A98C5A1E-A742-4808-96FA-6F409E799937';
if (preg_match('/^{?[A-Z0-9]{8}-[A-Z0-9]{4}-[A-Z0-9]{4}-[A-Z0-9]{4}-[A-Z0-9]{12}}?$/', $guid)) {
var_dump('ok');
} else {
var_dump('not ok');
}
It will match for
- 8 characters (both letters and numbers)
- 4 characters
- 4 characters
- 4 characters
- 12 characters
Each set of characters being separated by a ‘-‘
Considering you’re using com_create_guid, the regex check for optionnals } and { arround the guid, which means this would display ‘ok’ too :
$guid = '{A98C5A1E-A742-4808-96FA-6F409E799937}';
if (preg_match('/^{?[A-Z0-9]{8}-[A-Z0-9]{4}-[A-Z0-9]{4}-[A-Z0-9]{4}-[A-Z0-9]{12}}?$/', $guid)) {
var_dump('ok');
} else {
var_dump('not ok');
}