Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
U
UserAdminV2
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
庄欣
UserAdminV2
Commits
0a2c61ec
Commit
0a2c61ec
authored
Nov 10, 2011
by
Taylor Otwell
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
refactoring error handling.
parent
0dc43490
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
99 additions
and
137 deletions
+99
-137
application/config/error.php
+17
-21
laravel/bootstrap/core.php
+1
-0
laravel/bootstrap/errors.php
+0
-111
laravel/laravel.php
+81
-5
No files found.
application/config/error.php
View file @
0a2c61ec
...
@@ -36,29 +36,22 @@ return array(
...
@@ -36,29 +36,22 @@ return array(
| Error Handler
| Error Handler
|--------------------------------------------------------------------------
|--------------------------------------------------------------------------
|
|
| Because of the various ways of managing error logging, you get complete
| Because of the various ways of managing errors, you get complete freedom
| flexibility in Laravel to manage all error logging as you see fit.
| to manage errors as you desire. Any error that occurs in your application
| will be sent to this Closure.
|
|
|
This function will be called when an error occurs in your application.
|
By default, when error detail is disabled, a generic error page will be
|
You are free to handle the exception any way you want. The severity
|
rendered by the handler. After this handler is complete, the framework
| will
be a human-readable severity level such as "Parsing Error"
.
| will
stop processing the request and "exit" will be called
.
|
|
*/
*/
'handler'
=>
function
(
$exception
,
$
severity
,
$message
,
$
config
)
'handler'
=>
function
(
$exception
,
$config
)
{
{
if
(
$config
[
'detail'
])
if
(
!
$config
[
'detail'
])
{
$data
=
compact
(
'exception'
,
'severity'
,
'message'
);
$response
=
Response
::
view
(
'error.exception'
,
$data
)
->
status
(
500
);
}
else
{
{
$response
=
Response
::
error
(
'500'
);
Response
::
error
(
'500'
)
->
send
(
);
}
}
$response
->
send
();
},
},
/*
/*
...
@@ -71,15 +64,18 @@ return array(
...
@@ -71,15 +64,18 @@ return array(
| be called anytime an error occurs within your application and error
| be called anytime an error occurs within your application and error
| logging is enabled.
| logging is enabled.
|
|
| You may log the error message however you like; however, a simple logging
| You may log the error message however you like; however, a simple log
| solution has been setup for you which will log all error messages to a
| solution has been setup for you which will log all error messages to
| single text file within the application storage directory.
| a single text file within the application storage directory.
|
| Of course, you are free to implement more complex solutions including
| e-mailing the exceptions details to your team, etc.
|
|
*/
*/
'logger'
=>
function
(
$exception
,
$
severity
,
$message
,
$
config
)
'logger'
=>
function
(
$exception
,
$config
)
{
{
$message
=
date
(
'Y-m-d H:i:s'
)
.
'
'
.
$severity
.
' - '
.
$message
.
PHP_EOL
;
$message
=
date
(
'Y-m-d H:i:s'
)
.
'
- '
.
$exception
->
getMessage
()
.
PHP_EOL
;
File
::
append
(
STORAGE_PATH
.
'log.txt'
,
$message
);
File
::
append
(
STORAGE_PATH
.
'log.txt'
,
$message
);
}
}
...
...
laravel/bootstrap/core.php
View file @
0a2c61ec
...
@@ -59,6 +59,7 @@ require SYS_PATH.'autoloader'.EXT;
...
@@ -59,6 +59,7 @@ require SYS_PATH.'autoloader'.EXT;
*/
*/
Config
::
load
(
'application'
);
Config
::
load
(
'application'
);
Config
::
load
(
'session'
);
Config
::
load
(
'session'
);
Config
::
load
(
'error'
);
/**
/**
* Bootstrap the application inversion of control container. The IoC
* Bootstrap the application inversion of control container. The IoC
...
...
laravel/bootstrap/errors.php
deleted
100644 → 0
View file @
0dc43490
<?php
namespace
Laravel
;
/**
* Define a closure that will return the formatted error message when
* when given an exception. This function will be used by all of error
* handlers to create a more readable message.
*/
$message
=
function
(
$e
)
{
$search
=
array
(
APP_PATH
,
SYS_PATH
);
$replace
=
array
(
'APP_PATH/'
,
'SYS_PATH/'
);
$file
=
str_replace
(
$search
,
$replace
,
$e
->
getFile
());
return
rtrim
(
$e
->
getMessage
(),
'.'
)
.
' in '
.
$file
.
' on line '
.
$e
->
getLine
()
.
'.'
;
};
/**
* Define a closure that will return a more readable version of the
* severity of an exception. This function will be used by the error
* handler when parsing exceptions.
*/
$severity
=
function
(
$e
)
{
$levels
=
array
(
0
=>
'Error'
,
E_ERROR
=>
'Error'
,
E_WARNING
=>
'Warning'
,
E_PARSE
=>
'Parsing Error'
,
E_NOTICE
=>
'Notice'
,
E_CORE_ERROR
=>
'Core Error'
,
E_CORE_WARNING
=>
'Core Warning'
,
E_COMPILE_ERROR
=>
'Compile Error'
,
E_COMPILE_WARNING
=>
'Compile Warning'
,
E_USER_ERROR
=>
'User Error'
,
E_USER_WARNING
=>
'User Warning'
,
E_USER_NOTICE
=>
'User Notice'
,
E_STRICT
=>
'Runtime Notice'
,
);
$code
=
$e
->
getCode
();
return
(
array_key_exists
(
$code
,
$levels
))
?
$levels
[
$code
]
:
$code
;
};
/**
* Create the exception handler function. All of the error handlers
* registered by the framework call this closure to avoid duplicate
* code. Each of the formatting closures defined above will be
* passed into the handler for convenient use.
*/
$handler
=
function
(
$e
)
use
(
$message
,
$severity
)
{
$config
=
Config
::
get
(
'error'
);
if
(
$config
[
'log'
])
{
call_user_func
(
$config
[
'logger'
],
$e
,
$severity
(
$e
),
$message
(
$e
),
$config
);
}
call_user_func
(
$config
[
'handler'
],
$e
,
$severity
(
$e
),
$message
(
$e
),
$config
);
exit
(
1
);
};
/**
* Register the PHP exception handler. The framework throws exceptions
* on every error that cannot be handled. All of those exceptions will
* fall into this closure for processing.
*/
set_exception_handler
(
function
(
$e
)
use
(
$handler
)
{
$handler
(
$e
);
});
/**
* Register the PHP error handler. All PHP errors will fall into this
* handler, which will convert the error into an ErrorException object
* and pass the exception into the common exception handler.
*/
set_error_handler
(
function
(
$number
,
$error
,
$file
,
$line
)
use
(
$handler
)
{
$handler
(
new
\ErrorException
(
$error
,
$number
,
0
,
$file
,
$line
));
});
/**
* Register the PHP shutdown handler. This function will be called at
* the end of the PHP script or on a fatal PHP error. If an error has
* occurred, we will convert it to an ErrorException and pass it to
* the common exception handler.
*/
register_shutdown_function
(
function
()
use
(
$handler
)
{
if
(
!
is_null
(
$error
=
error_get_last
()))
{
extract
(
$error
,
EXTR_SKIP
);
$handler
(
new
\ErrorException
(
$message
,
$type
,
0
,
$file
,
$line
));
}
});
/**
* Turn off all PHP error reporting and display. Since the framework
* will be displaying the exception messages, we don't want PHP to
* display any ugly error information.
*/
error_reporting
(
-
1
);
ini_set
(
'display_errors'
,
'Off'
);
\ No newline at end of file
laravel/laravel.php
View file @
0a2c61ec
...
@@ -8,15 +8,91 @@
...
@@ -8,15 +8,91 @@
require
'bootstrap/core.php'
;
require
'bootstrap/core.php'
;
/**
/**
* Register the
framework error handling methods and set the error
* Register the
default timezone for the application. This will be
*
reporting levels. This file will register handlers for exceptions,
*
the default timezone used by all date / timezone functions in
*
errors, and the shutdown event
.
*
the entire application
.
*/
*/
require
SYS_PATH
.
'bootstrap/errors'
.
EXT
;
date_default_timezone_set
(
Config
::
$items
[
'application'
][
'timezone'
]);
date_default_timezone_set
(
Config
::
$items
[
'application'
][
'timezone'
]);
/**
/**
* Create the exception handler function. All of the error handlers
* registered by the framework call this closure to avoid duplicate
* code. This Closure will determine if the logging Closure should
* be called, and will pass the exception to the developer defined
* handler in the configuration file.
*/
$handler
=
function
(
$exception
)
{
$config
=
Config
::
get
(
'error'
);
if
(
$config
[
'log'
])
{
call_user_func
(
$config
[
'logger'
],
$exception
,
$config
);
}
call_user_func
(
$config
[
'handler'
],
$exception
,
$config
);
if
(
!
$config
[
'detail'
])
{
exit
(
1
);
}
};
/**
* Register the PHP exception handler. The framework throws exceptions
* on every error that cannot be handled. All of those exceptions will
* be sent through this closure for processing.
*/
set_exception_handler
(
function
(
$exception
)
use
(
$handler
)
{
$handler
(
$exception
);
});
/**
* Register the PHP error handler. All PHP errors will fall into this
* handler, which will convert the error into an ErrorException object
* and pass the exception into the common exception handler.
*/
set_error_handler
(
function
(
$number
,
$error
,
$file
,
$line
)
use
(
$handler
)
{
$handler
(
new
\ErrorException
(
$error
,
$number
,
0
,
$file
,
$line
));
});
/**
* Register the PHP shutdown handler. This function will be called
* at the end of the PHP script or on a fatal PHP error. If an error
* has occured, we will convert it to an ErrorException and pass it
* to the common exception handler for the framework.
*/
register_shutdown_function
(
function
()
use
(
$handler
)
{
if
(
!
is_null
(
$error
=
error_get_last
()))
{
extract
(
$error
,
EXTR_SKIP
);
$handler
(
new
\ErrorException
(
$message
,
$type
,
0
,
$file
,
$line
));
}
});
/**
* Setting the PHP error reporting level to -1 essentially forces
* PHP to report every error, and is guranteed to show every error
* on future versions of PHP.
*/
error_reporting
(
-
1
);
/**
* If error detail is turned off, we will turn off all PHP error
* reporting and display since the framework will be displaying a
* generic message and we don't want any sensitive details about
* the exception leaking into the views.
*/
if
(
!
Config
::
$items
[
'error'
][
'detail'
])
{
//ini_set('display_errors', 'Off');
}
/**
* Load the session and session manager instance. The session
* Load the session and session manager instance. The session
* payload will be registered in the IoC container as an instance
* payload will be registered in the IoC container as an instance
* so it can be retrieved easily throughout the application.
* so it can be retrieved easily throughout the application.
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment