4 апреля 2012 г. 13:14 пользователь Xinchen Hui <larue...@php.net> написал:
> Commit:    efd671f242e87e3301a1b3e76179955f26119feb
> Author:    Xinchen Hui <larue...@gmail.com>         Wed, 4 Apr 2012 16:14:28 
> +0800
> Parents:   3ea9fa1b4626f6125f25d8b0bcffac7becc1d092
> Branches:  PHP-5.4
>
> Link:       
> http://git.php.net/?p=php-src.git;a=commitdiff;h=efd671f242e87e3301a1b3e76179955f26119feb
>
> Log:
> Fixed bug Fixed bug #61605 (header_remove() does not remove all headers)
>
> Bugs:
> https://bugs.php.net/61605
>
> Changed paths:
>  M  NEWS
>  M  main/SAPI.c
>  A  sapi/cgi/tests/bug61605.phpt
>
>
> Diff:
> diff --git a/NEWS b/NEWS
> index 6fc9126..b8b28b1 100644
> --- a/NEWS
> +++ b/NEWS
> @@ -9,6 +9,8 @@ PHP                                                           
>              NEWS
>   . "Connection: close" instead of "Connection: closed" (Gustavo)
>
>  - Core:
> +  . Fixed bug Fixed bug #61605 (header_remove() does not remove all headers).
> +    (Laruence)

Double Fixed bug (maybe you fixed it twice :) )

>   . Fixed bug #61374 (html_entity_decode tries to decode code points that 
> don't
>     exist in ISO-8859-1). (Gustavo)
>   . Fixed bug #61273 (call_user_func_array with more than 16333 arguments
> diff --git a/main/SAPI.c b/main/SAPI.c
> index 74fdbb2..0d3b4ef 100644
> --- a/main/SAPI.c
> +++ b/main/SAPI.c
> @@ -587,10 +587,36 @@ static void sapi_update_response_code(int ncode 
> TSRMLS_DC)
>        SG(sapi_headers).http_response_code = ncode;
>  }
>
> -static int sapi_find_matching_header(void *element1, void *element2)
> -{
> -       int len = strlen((char*)element2);
> -       return strncasecmp(((sapi_header_struct*)element1)->header, 
> (char*)element2, len) == 0 && ((sapi_header_struct*)element1)->header[len] == 
> ':';
> +/*
> + * since zend_llist_del_element only remove one matched item once,
> + * we should remove them by ourself
> + */
> +static void sapi_remove_header(zend_llist *l, char *name, uint len) {
> +       sapi_header_struct *header;
> +       zend_llist_element *next;
> +       zend_llist_element *current=l->head;
> +
> +       while (current) {
> +               header = (sapi_header_struct *)(current->data);
> +               next = current->next;
> +               if (header->header_len > len && header->header[len] == ':'
> +                               && !strncasecmp(header->header, name, len)) {
> +                       if (current->prev) {
> +                               current->prev->next = next;
> +                       } else {
> +                               l->head = next;
> +                       }
> +                       if (next) {
> +                               next->prev = current->prev;
> +                       } else {
> +                               l->tail = current->prev;
> +                       }
> +                       sapi_free_header(header);
> +                       efree(current);
> +                       --l->count;
> +               }
> +               current = next;
> +       }
>  }
>
>  SAPI_API int sapi_add_header_ex(char *header_line, uint header_line_len, 
> zend_bool duplicate, zend_bool replace TSRMLS_DC)
> @@ -621,7 +647,7 @@ static void sapi_header_add_op(sapi_header_op_enum op, 
> sapi_header_struct *sapi_
>                                char sav = *colon_offset;
>
>                                *colon_offset = 0;
> -                               
> zend_llist_del_element(&SG(sapi_headers).headers, sapi_header->header, 
> (int(*)(void*, void*))sapi_find_matching_header);
> +                       sapi_remove_header(&SG(sapi_headers).headers, 
> sapi_header->header, strlen(sapi_header->header));
>                                *colon_offset = sav;
>                        }
>                }
> @@ -703,7 +729,7 @@ SAPI_API int sapi_header_op(sapi_header_op_enum op, void 
> *arg TSRMLS_DC)
>                        sapi_header.header_len = header_line_len;
>                        sapi_module.header_handler(&sapi_header, op, 
> &SG(sapi_headers) TSRMLS_CC);
>                }
> -               zend_llist_del_element(&SG(sapi_headers).headers, 
> header_line, (int(*)(void*, void*))sapi_find_matching_header);
> +               sapi_remove_header(&SG(sapi_headers).headers, header_line, 
> header_line_len);
>                efree(header_line);
>                return SUCCESS;
>        } else {
> diff --git a/sapi/cgi/tests/bug61605.phpt b/sapi/cgi/tests/bug61605.phpt
> new file mode 100644
> index 0000000..c6e4cf2
> --- /dev/null
> +++ b/sapi/cgi/tests/bug61605.phpt
> @@ -0,0 +1,34 @@
> +--TEST--
> +Bug #61605 (header_remove() does not remove all headers)
> +--SKIPIF--
> +<?php include "skipif.inc"; ?>
> +--GET--
> +foo=bar
> +--FILE--
> +<?php
> +header("A: first");
> +header("A: second", TRUE);
> +$headers1 = headers_list();
> +header("A: third", FALSE);
> +$headers2 = headers_list();
> +header_remove("A");
> +$headers3 = headers_list();
> +print_r($headers1);
> +print_r($headers2);
> +print_r($headers3);
> +--EXPECTF--
> +Array
> +(
> +    [0] => X-Powered-By: %s
> +    [1] => A: second
> +)
> +Array
> +(
> +    [0] => X-Powered-By: %s
> +    [1] => A: second
> +    [2] => A: third
> +)
> +Array
> +(
> +    [0] => X-Powered-By: %s
> +)
>
>
> --
> PHP CVS Mailing List (http://www.php.net/)
> To unsubscribe, visit: http://www.php.net/unsub.php
>



-- 
Regards,
Shein Alexey

--
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to