好了,所以我写了使用mod_rewrite和PHP一个REST API的实现。我接受查询字符串通过HTTP的身体DELETE请求(...的集体呻吟?)。关于这两个以前的声明一旁的智慧争论,什么我发现是,PHP不自动解析DELETE请求的请求体(即$ _ POST是空的,尽管出现在请求体形式编码的查询字符串)。这并没有特别让我感到吃惊。我确实发现令人意外的是,我一直无法找到解析查询字符串内置PHP函数?难道我只是忽略了什么?我可以这样做:

public function parseQS($queryString, &$postArray){
  $queryArray = explode('&', $queryString);
  for($i = 0; $i < count($queryArray); $i++) {
    $thisElement = split('=', $queryArray[$i]);
    $postArray[$thisElement[0]] = htmlspecialchars(urldecode($thisElement[1]));
  }
}

...它只是似乎很奇怪,就不会有一个PHP内置处理这个问题。另外,我怀疑我不应该使用htmlspecialcharacters&urldecode擦洗形式编码值......这是一种不同的编码方式,但我也有,我应该使用解码表单编码的数据,PHP函数难以分辨

任何建议将不胜感激。

有帮助吗?

解决方案

parse_str 。糟糕的名字,但你想要做什么。并通知它没有返回值,第二个参数是由引用传递。

其他提示

有是做它的功能 - http://php.net/parse_str 。由于PHP必须为自己做到这一点,我们没有理由不还打开它的API使用。

  

将字符串到变量空隙   parse_str(字符串$ STR [,数组&$ ARR])

     

解析STR就好像它是该查询   串通过URL和传递套   变量在当前范围。

<?php
$str = "first=value&arr[]=foo+bar&arr[]=baz";

parse_str($str, $output);
echo $output['first'];  // value
echo $output['arr'][0]; // foo bar
echo $output['arr'][1]; // baz

parse_str href="http://codepad.org/s4w6DSh9" rel="nofollow">吮吸

parse_str是对简单的东西,但它是不一样的PHP内置创建$_GET魔术变量的方式。为什么?!?我不知道。我已经开发了我自己的版本,我认为PHP的解析完全匹配(让我知道如果你能找到证明,否则任何实例)。

function betterParseStr( $string )
{
    return array_reduce( explode( "&", $string ), function( $array, $string_piece ) {
        if( $string_piece === "" ) return $array;
        $equal_offset = strpos( $string_piece, "=" );
        if( $equal_offset === FALSE ) {
            $key = urldecode( $string_piece );
            $value = "";
        } else {
            $key = urldecode( substr( $string_piece, 0, $equal_offset ) );
            $value = urldecode( substr( $string_piece, $equal_offset + 1 ) );
        }
        if( preg_match( "/^([^\[]*)\[([^\]]*)](.*)$/", $key, $matches ) ) {
            $key_path = array( $matches[1], $matches[2] );
            $rest = $matches[3];
            while( preg_match( "/^\[([^\]]*)](.*)$/", $rest, $matches ) ) {
                $key_path[] = $matches[1];
                $rest = $matches[2];
            }
        } else {
            //replace first [ for _
            //why?!? idk ask PHP it does
            //Example: ?key[[=value -> array( "key_[" => "value" )
            $key_path = array( preg_replace('/\[/', '_', $key, 1 ) );
        }
        if( strlen( $key_path[0] ) > 0 && substr( $key_path[0], 0, 1 ) !== "[" ) {
            $current_node = &$array;
            $last_key = array_pop( $key_path );
            $resolve_key = function( $key, array $array ) {
                if( $key === "" || $key === " " ) {
                    $int_array = array_filter( array_keys( $array ), function( $key ) { return is_int( $key ); } );
                    $key = $int_array ? max( $int_array ) + 1 : 0;
                }
                return $key;
            };
            foreach( $key_path as $key_path_piece ) {
                $key_path_piece = $resolve_key( $key_path_piece, $current_node );
                if( ! array_key_exists( $key_path_piece, $current_node ) || ! is_array( $current_node[$key_path_piece] ) ) {
                    $current_node[$key_path_piece] = array();
                }
                $current_node = &$current_node[$key_path_piece];
            }
            $current_node[$resolve_key( $last_key, $current_node )] = $value;
        }
        return $array;
    }, array() );
}

可以使用 parse_str功能

parse_str($queryString, $args);

http://us2.php.net/manual/en /function.parse-url.php

parse_url将帮助您抓住DOCUMENT_URI的包含实际查询的部分。

可以然后传递部分关闭以parse_str提取从查询单个元素。

http://us2.php.net/manual/en /function.parse-str.php

我已经建立了一个简单的库来解析查询字符串过滤,排序,然后选择字段我的REST API。天真的版本的OData的。 转化的查询字符串到对象和或对象的阵列。 用于离:

过滤器:

www.example.com/resource?@filters=filedName operator 'the value'

可用运算当量,NE,GT,LT,等,ILIKE,LE,GE

$filtersResult = $parser->filters();

$filtersResult[0]->field // name
$filtersResult[0]->operator // eq
$filtersResult[0]->getOperator() // "="
$filtersResult[0]->value // 'what ever'

要进行排序:

//name is asc , surname desc
@orderby=name,-surname
$sorts = $parser->orderBy() // you can set defaults if u want
$sorts[0]->filed //name 
$sorts[0]->direction //asc

$sorts[1]->filed //surname 
$sorts[1]->direction //desc

有嵌入:

@embed=resourceOne(@fields=name,code)(@filters=nameembed eq 'what ever'),mobiles(@orderby=sortFieldOne)

$embedResult = $parser->embed(); //return array of embed each              
//object contains filters , sort , fields | empty array 

$embedResult[0]->resource // resourceOne
$embedResult[0]->fields // array of fields  [name,code]
$embedResult[0]->filters // array of filters or empty array 

$embedResult[1]->resource // mobiles
$embedResult[1]->orderBy // array of order by objects

easyparser

public function parseQS($queryString, &$postArray){
  parse_str($queryString, $postArray);
}

- )

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top