为ExtJS树控件准备多维数组

时间:2011-03-23 06:11:57

标签: php javascript extjs

请不要将此问题视为重复一个.......... 我是php的新手。 我正在开发extjs中的一个树网格。我需要以树格式显示字段。因此前端我需要发送编码数据。 我想要2个函数来编码和解码字符串变量,多维数组,带有一组分隔符的变量。 例如,如果我有一个数组.........

array(
array( "task" => "rose",
"duration" => 1.25,
"user" => 15
),
array( "task" => "daisy",
"duration" => 0.75,
"user" => 25,
),
array( "task" => "orchid",
"duration" => 1.15,
"user" => 7
),
array( "task" => "sunflower",
"duration" => 1.50,
"user" => 70
)

);

我想将所有数组字段或单个字段编码为..........

array(
array( "task" => "rose",
"duration" => 1.25,
"user" => 15
),
array( "task" => "daisy",
"duration" => 0.75,
"user" => 25$sbaa,
),
array( "task" => "orchid",
"duration" => 1.15,
"user" => 7$!ass,
),
array( "task" => "sunflower",
"duration" => 1.50,
"user" => 70$!abc
)

);

所以这样我只需要编码字符串,带分隔符的变量......... 以后所有的编码值在它回到结束之前要被解码.....为此我必须使用这个插件.......... encode.class.php ...........

<?php

/*-------------------------
Author: Jonathan Pulice
Date: July 26th, 2005
Name: JPEncodeClass v1
Desc: Encoder and decoder using patterns.
-------------------------*/

class Protector
{

var $Pattern = "";
var $PatternFlip = "";
var $ToEncode = "";
var $ToDecode = "";
var $Decoded = "";
var $Encoded = "";
var $Bug = false;
var $DecodePattern = "";

function Debug($on = true)
{
$this->Bug = $on;
}

function Encode()
{


$ar = explode(":", $this->Pattern);
$enc = $this->ToEncode;

if ($this->Bug) echo "<!-- BEGIN ENCODING -->\n";

foreach ($ar as $num => $ltr)
{
switch ($ltr)
{
case "E":
$enc = base64_encode($enc);
break;
case "D":
$enc = base64_decode($enc);
break;
case "R":
$enc = strrev($enc);
break;
case "I":
$enc = $this->InvertCase($enc);
break;
}
if ($this->Bug) echo "<!-- {$ltr}: {$enc} -->\n";
}

if ($this->Bug) echo "<!-------------------->\n\n";

@$this->Encoded = ($enc == $this->Str) ? "<font color='red'>No Encoding/Decoding Pattern Detected!</font>" : $enc;

return $this->Encoded;

}

function Decode()
{

$pattern = ($this->DecodePattern != "") ? $this->DecodePattern : $this->Pattern;

//Reverse the pattern
$this->PatternFlip($pattern);

//make into an array
$ar = explode(":", $this->PatternFlip);

$t = ($this->Encoded == "") ? $this->ToDecode : $this->Encoded;

if ($this->Bug) echo "<!-- BEGIN DECODING -->\n";

foreach ($ar as $num => $ltr)
{
switch ($ltr)
{
case "E":
$t = base64_encode($t);
break;
case "D":
$t = base64_decode($t);
break;
case "R":
$t = strrev($t);
break;
case "I":
$t = $this->InvertCase($t);
break;
}
if ($this->Bug) echo "<!-- {$ltr}: {$t} -->\n";
}

if ($this->Bug) echo "<!-------------------->\n\n";

$this->Decoded = ($t == $this->Encoded) ? "<font color='red'>No Encoding/Decoding Pattern Detected!</font>" : $t;

return $this->Decoded;

}

function MakePattern($len = 10)
{
//possible letters
// E - Base64 Encode
// R - Reverse String
// I - Inverse Case
$poss = array('E','R', 'I');

//generate a string
for ( $i = 0 ; $i < $len ; $i++ )
{
$tmp[] = $poss[ rand(0,2) ];
}

//echo $str. "<br>";
//fix useless pattern section RR II
$str = implode(":", $tmp);

//fix
$str = str_replace( 'R:R:R:R:R:R' , 'R:E:R:E:R:E' , $str );
$str = str_replace( 'R:R:R:R:R' , 'R:E:R:E:R' , $str );
$str = str_replace( 'R:R:R:R' , 'R:E:R:E' , $str );
$str = str_replace( 'R:R:R' , 'R:E:R' , $str );
$str = str_replace( 'R:R' , 'R:E' , $str );

//fix
$str = str_replace( 'I:I:I:I:I:I' , 'I:E:I:E:I:E' , $str );
$str = str_replace( 'I:I:I:I:I' , 'I:E:I:E:I' , $str );
$str = str_replace( 'I:I:I:I' , 'I:E:I:E' , $str );
$str = str_replace( 'I:I:I' , 'I:E:I' , $str );
$str = str_replace( 'I:I' , 'I:E' , $str );

//string is good, set as pattern
$this->Pattern = $str;
return $this->Pattern; //if we need it

}

function PatternFlip($pattern)
{
//reverse the pattern
$str = strrev($pattern);

$ar = explode(":", $str);

foreach ($ar as $num => $ltr)
{
switch ($ltr)
{
case "E":
$tmp[] = "D";
break;
case "D":
$tmp[] = "E";
break;
case "R":
$tmp[] = "R";
break;
case "I":
$tmp[] = "I";
break;
}

}

$rev = implode(":", $tmp);

$this->PatternFlip = $rev;

return $this->PatternFlip;
}

// This is my custom Case Invertor!
// if you would like to use this in a script, please credit it to me, thank you
function InvertCase($str)
{
//Do initial conversion
$new = strtoupper( $str );

//spluit into arrays
$s = str_split( $str );
$n = str_split( $new );

//now we step through each letter, and if its the same as before, we swap it out
for ($i = 0; $i < count($s); $i++)
{
if ( $s[$i] === $n[$i] ) //SWAP THE LETTER
{
//ge the letter
$num = ord( $n[$i] );

//see if the ord is in the alpha ranges ( 65 - 90 | 97 - 122 )
if ( ( $num >= 65 AND $num <= 90 ) OR ( $num >= 97 AND $num <= 122 ) )
{
if ($num < 97 ) { $num = $num + 32; }
else { $num = $num - 32; }

$newchr = chr($num);

$n[$i] = $newchr;
}
}
}

//join the new string back together
$newstr = implode("", $n);

return $newstr;

}

}

&GT?; ............ 从这个插件我需要使用编码和解码功能为我的功能......... 如果有人能帮我这个.......这对我来说非常有用.......

2 个答案:

答案 0 :(得分:0)

为什么不使用json_encode?只是做

$str=json_encode($array);

然后,发送数据,在另一端做

$array=json_decode($str);

答案 1 :(得分:0)

好的,让我们解决这个问题。

你有一个阵列。数组中的每个元素都是一个哈希值。哈希中的一个(或多个)值使用库的可怕憎恶进行编码。但是库无法处理数组。

我们必须自己处理数组。

<rant>
在开始之前,我想再次表达“Protector”代码设计的可怕程度。它是为PHP4编写的,实际上是一个包含在类中的意大利面条代码。它错误地使用了属性,几乎就像用户对 Java的实例变量如何工作有某种错误记忆一样,并且以某种方式认为以相同的方式使用PHP是合适的或理智的。如果代码的作者现在完全不屑地回顾那令人反感的大块字节,那么他就会出现严重错误。
</rant>

我将在this copy of it上了解这个课程的知识,因为你提供的课程格式比原版更差。

首先,让我们创建一个需要编码的内部数组键列表。

$keys_to_encode = array( 'user' );

您的示例编码仅列出user密钥作为可编码。如果您需要编码其他元素,只需向该数组添加更多元素即可。

现在,让我们准备好“保护者”。它似乎希望您指定一个模式,或使用MakePattern方法创建一个模式。 我们将手动指定一个,因为MakePattern可以提供有效无用的组合。

$stupid = new Protector();
$stupid->Pattern = 'E:I:E:R:D:I:E';

这将是base64编码,翻转案例,再次base64,反转它,un-base64,翻转案例,然后重新base64。请注意,PHP的base64解码器“正确”忽略了错误的填充和意外字符,这是base64-reverse-unbase64的工作原理的唯一原因。对于那些不知道base64看起来像什么的人来说,结果字符串看起来会像乱码,而对于知道base64看起来像什么的人来说,un-base64就是乱码。

如果您需要以某种方式对值进行编码,只需更改模式即可。重要的是要么对模式进行硬编码,要么将其存储在数据的某个地方,因为没有它,你将很难进行解码。 (我的意思是,它可以通过手工完成,但你不想这样做。)我希望你的老板会给你关于模式的具体说明,因为你没有选择在课堂上使用这种彻头彻尾的失败。

现在是时候处理我们的数据了。让我们假装$in包含您的原始数组。

$out = array();
foreach($in as $k => $target) {
    foreach($keys_to_encode as $target_key) {
        $stupid->ToEncode = $target[ $target_key ];
        $target[ $target_key ] = $stupid->Encode();
    }
    $out[$k] = $target;
}

这循环遍历散列数组,然后在每个散列内部,只编码我们想要编码的键。编码的哈希放在一个新数组$out中。这是您传递给树小部件的内容。

解码同样容易。您已经说过,您的目标是让用户编辑树窗口小部件中的某些数据,而您似乎想要保护基础密钥。这告诉我你可能只需要一次处理其中一个哈希值。因此,我将仅使用一个值$whatever来编写此解码示例。

$stupidest = new Protector();
$stupidest->Pattern = 'E:I:E:R:D:I:E'; // SAME PATTERN!
$stupidest->ToDecode = $whatever;
$decoded = $stupidest->Decode();

再次, critical 你在这里使用相同的解码模式。

至于与树小部件的实际交互,你可以自己在那里。我只知道ExtJS知道它存在并且它的GUI创建者真的很有趣。