mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #3881 -- skip saving session when response status is 500
Saving session data is somewhat likely to lead into error when the status code is 500. It is guaranteed to lead into error if the reason for the 500 code is query error on PostgreSQL.
This commit is contained in:
		| @@ -33,6 +33,8 @@ class SessionMiddleware(object): | |||||||
|                     expires_time = time.time() + max_age |                     expires_time = time.time() + max_age | ||||||
|                     expires = cookie_date(expires_time) |                     expires = cookie_date(expires_time) | ||||||
|                 # Save the session data and refresh the client cookie. |                 # Save the session data and refresh the client cookie. | ||||||
|  |                 # Skip session save for 500 responses, refs #3881. | ||||||
|  |                 if response.status_code != 500: | ||||||
|                     request.session.save() |                     request.session.save() | ||||||
|                     response.set_cookie(settings.SESSION_COOKIE_NAME, |                     response.set_cookie(settings.SESSION_COOKIE_NAME, | ||||||
|                             request.session.session_key, max_age=max_age, |                             request.session.session_key, max_age=max_age, | ||||||
|   | |||||||
| @@ -409,6 +409,22 @@ class SessionMiddlewareTests(unittest.TestCase): | |||||||
|         self.assertNotIn('httponly', |         self.assertNotIn('httponly', | ||||||
|                          str(response.cookies[settings.SESSION_COOKIE_NAME])) |                          str(response.cookies[settings.SESSION_COOKIE_NAME])) | ||||||
|  |  | ||||||
|  |     def test_session_save_on_500(self): | ||||||
|  |         request = RequestFactory().get('/') | ||||||
|  |         response = HttpResponse('Horrible error') | ||||||
|  |         response.status_code = 500 | ||||||
|  |         middleware = SessionMiddleware() | ||||||
|  |  | ||||||
|  |         # Simulate a request the modifies the session | ||||||
|  |         middleware.process_request(request) | ||||||
|  |         request.session['hello'] = 'world' | ||||||
|  |  | ||||||
|  |         # Handle the response through the middleware | ||||||
|  |         response = middleware.process_response(request, response) | ||||||
|  |  | ||||||
|  |         # Check that the value wasn't saved above. | ||||||
|  |         self.assertNotIn('hello', request.session.load()) | ||||||
|  |  | ||||||
|  |  | ||||||
| class CookieSessionTests(SessionTestsMixin, TestCase): | class CookieSessionTests(SessionTestsMixin, TestCase): | ||||||
|  |  | ||||||
|   | |||||||
| @@ -177,6 +177,12 @@ autocommit behavior was never restored. This bug is now fixed in 1.5. While | |||||||
| this is only a bug fix, it is worth checking your applications behavior if | this is only a bug fix, it is worth checking your applications behavior if | ||||||
| you are using PostgreSQL together with the autocommit option. | you are using PostgreSQL together with the autocommit option. | ||||||
|  |  | ||||||
|  | Session not saved on 500 responses | ||||||
|  | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|  | Django's session middleware will skip saving the session data if the | ||||||
|  | response's status code is 500. | ||||||
|  |  | ||||||
| Miscellaneous | Miscellaneous | ||||||
| ~~~~~~~~~~~~~ | ~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -423,6 +423,9 @@ cookie will be sent on every request. | |||||||
| Similarly, the ``expires`` part of a session cookie is updated each time the | Similarly, the ``expires`` part of a session cookie is updated each time the | ||||||
| session cookie is sent. | session cookie is sent. | ||||||
|  |  | ||||||
|  | .. versionchanged:: 1.5 | ||||||
|  |   The session is not saved if the response's status code is 500. | ||||||
|  |  | ||||||
| Browser-length sessions vs. persistent sessions | Browser-length sessions vs. persistent sessions | ||||||
| =============================================== | =============================================== | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user