tony2001 Sun Jan 9 12:42:03 2005 EDT Modified files: /php-src/ext/session session.c Log: fix bug #31454 (session_set_save_handler crashes PHP when supplied non-existent object ref) http://cvs.php.net/diff.php/php-src/ext/session/session.c?r1=1.403&r2=1.404&ty=u Index: php-src/ext/session/session.c diff -u php-src/ext/session/session.c:1.403 php-src/ext/session/session.c:1.404 --- php-src/ext/session/session.c:1.403 Thu Dec 9 12:15:52 2004 +++ php-src/ext/session/session.c Sun Jan 9 12:42:02 2005 @@ -17,7 +17,7 @@ +----------------------------------------------------------------------+ */ -/* $Id: session.c,v 1.403 2004/12/09 17:15:52 tony2001 Exp $ */ +/* $Id: session.c,v 1.404 2005/01/09 17:42:02 tony2001 Exp $ */ #ifdef HAVE_CONFIG_H #include "config.h" @@ -1361,6 +1361,7 @@ zval **args[6]; int i; ps_user *mdata; + char *name; if (ZEND_NUM_ARGS() != 6 || zend_get_parameters_array_ex(6, args) == FAILURE) WRONG_PARAM_COUNT; @@ -1368,6 +1369,14 @@ if (PS(session_status) != php_session_none) RETURN_FALSE; + for (i = 0; i < 6; i++) { + if (!zend_is_callable(*args[i], 0, &name)) { + php_error_docref(NULL TSRMLS_CC, E_WARNING, "Argument %d is not a valid callback", i+1); + efree(name); + RETURN_FALSE; + } + } + zend_alter_ini_entry("session.save_handler", sizeof("session.save_handler"), "user", sizeof("user")-1, PHP_INI_USER, PHP_INI_STAGE_RUNTIME); mdata = emalloc(sizeof(*mdata));
-- PHP CVS Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php