在报表系统开发中,我没有使用Form作为提交参数给报表系统的方式,采用的是URL直接传递的方式传递参数给JSP,原因是
1、报表宿主的页面中可能不止一个Form,如果用户不慎重使用document.forms[xxx]方式访问Form就会出现混乱。
2、宿主页面中可能存在同名的Form
3、提交的时候需要完全刷新宿主页面。
5、附加的参数如果需要提交给JSP,需要设置Hidden。
6、如果在宿主页面中包含多个报表,则控件的命名是一个比较考究的问题。
所以我使用了最简单的URL方式传递参数。
URL传递参数的格式为url?param=value¶m=value
当参数中包含特殊字符的时候就会出现混乱甚至错误,例如空格,字符&等等。所以JavaScript提供了一个escape函数对字符串进行编码操作,可惜的是,这个编码操作对于JAVA来说,是不适合的,使用escape编码是以\u开头,而Java使用的Unicode编码则是二进制编码。而且更加令人失望的是,使用escape编码的字符串会使得服务端的JSP得不到值。
有强人搞了一个解决方案,使用两次escape,具体的原理也很简单,但是不得不佩服这些高人,能有这种招数,同时在服务端提供了一套函数解码
public static String unescape(String src)
{
StringBuffer tmp = new StringBuffer();
tmp.ensureCapacity(src.length());
int lastPos = 0,pos = 0;
char ch;
while(lastPos < src.length())
{
pos = src.indexOf("%",lastPos);
if(pos == lastPos)
{
if(src.charAt(pos + 1) == 'u')
{
ch = (char) Integer.parseInt(src.substring(pos + 2,pos + 6),16);
tmp.append(ch);
lastPos = pos + 6;
}
else
{
ch = (char) Integer.parseInt(src.substring(pos + 1,pos + 3),16);
tmp.
append(ch);
lastPos = pos + 3;
}
}
else
{
if(pos == -1)
{
tmp.append(src.substring(lastPos));
lastPos = src.length();
}
else
{
tmp.append(src.substring(lastPos,pos));
lastPos = pos;
}
}
}
return tmp.toString();
}
public static String escape(String src)
{
int i;
char j;
StringBuffer tmp = new StringBuffer();
tmp.ensureCapacity(src.length() * 6);
for(i = 0;i < src.length();i++)
{
j = src.charAt(i);
if(Character.isDigit(j) || Character.isLowerCase(j) || Character.isUpperCase(j))
{
tmp.append(j);
}
else if(j < 256)
{
tmp.append("%");
if(j < 16)
{
tmp.append("0");
}
tmp.append(Integer.toString(j,16));
}
else
{
tmp.append("%u");
tmp.append(Integer.toString(j,16));
}
}
return tmp.toString();
}
{
StringBuffer tmp = new StringBuffer();
tmp.ensureCapacity(src.length());
int lastPos = 0,pos = 0;
char ch;
while(lastPos < src.length())
{
pos = src.indexOf("%",lastPos);
if(pos == lastPos)
{
if(src.charAt(pos + 1) == 'u')
{
ch = (char) Integer.parseInt(src.substring(pos + 2,pos + 6),16);
tmp.append(ch);
lastPos = pos + 6;
}
else
{
ch = (char) Integer.parseInt(src.substring(pos + 1,pos + 3),16);
tmp.
append(ch);
lastPos = pos + 3;
}
}
else
{
if(pos == -1)
{
tmp.append(src.substring(lastPos));
lastPos = src.length();
}
else
{
tmp.append(src.substring(lastPos,pos));
lastPos = pos;
}
}
}
return tmp.toString();
}
public static String escape(String src)
{
int i;
char j;
StringBuffer tmp = new StringBuffer();
tmp.ensureCapacity(src.length() * 6);
for(i = 0;i < src.length();i++)
{
j = src.charAt(i);
if(Character.isDigit(j) || Character.isLowerCase(j) || Character.isUpperCase(j))
{
tmp.append(j);
}
else if(j < 256)
{
tmp.append("%");
if(j < 16)
{
tmp.append("0");
}
tmp.append(Integer.toString(j,16));
}
else
{
tmp.append("%u");
tmp.append(Integer.toString(j,16));
}
}
return tmp.toString();
}