多语言展示
当前在线:1768今日阅读:126今日分享:42

excel报表工具FineReport之编码转换

报表已集成到Web页面中,通过在页面传递参数至报表中时,会发现有时某些参数值,传递到报表中是显示为问号(???)或乱码等等一系列不能正常显示的情况。
工具/原料

FineReport

1.问题原因
1

这是由于浏览器和报表服务器的编码不同,字符多次进行编码转换时出现错误导致字符的显示出现乱码,尤其是中日韩文和特殊字符更容易出现乱码问题。详细的编码原理,可参考编码文档END

2.解决方案

在给报表服务器发送请求之前,对URL或者只对URL里面的参数名字和参数值,进行cjkEncode的编码,该方式兼容了各种不同的字符集,如ISO8859-1、 UTF-8、 GBK、 ENU_JP,尤其对中日韩文的处理采取了统一的方案。END

3.javascript中FineReport字符转换原理
1

在给报表服务器发送请求之前,对URL或者只对URL里面的参数名字和参数值,进行cjkEncode的编码。源码如下:

2

function cjkEncode(text) {           if (text == null) {               return '';           }           var newText = '';           for (var i = 0; i < text.length; i++) {               var code = text.charCodeAt (i);                if (code >= 128 || code == 91 || code == 93) {//91 is '[', 93 is ']'.                   newText += '[' + code.toString(16) + ']';               } else {                   newText += text.charAt(i);               }           }           return newText;

3

经过编码的URL或者Form表单,报表服务器智能的将这些字符正确的转换过来。cjkEncode方法在FineReport的JS库中已经预先提供了,用户只要加载了FR的JS库,就可以使用FR.cjkEncode对中日韩文字符进行encode,如下示例:END

4.示例
1

4.1 对URL进行cjkEncode                       function frOpen() {         window.location=FR.cjkEncode('http://localhost:8075/WebReport/ReportServer?reportlet=doc/Primary/Parameter/Parameter.cpt&地区=华东');         }                   

2

4.2 对Form表单进行cjkEncode如果是以Form表单把参数提交到报表里面,也同样需要在提交前调用cjkEncode进行编码转换,如下例子                    

3

4.3 特殊符号处理如果在需要进行cjkEncode的URI的参数中包含特殊字符,比如%,#,$,=,&,/,?,+,@等字符时,需要在cjkEncode之后,再次调用javascript的encodeURIComponent对这些特殊字符进行编码。如参数值是”%华%“这样的字符,就需要写成encodeURIComponent(FR.cjkEncode('%华%')),一定要先进行cjkEncode,然后再进行encodeURIComponent,完整代码如下:                       function frOpen() {     window.location=FR.cjkEncode('http://localhost:8075/WebReport/ReportServer?reportlet=doc/Primary/Parameter/Parameter.cpt&地区=') +encodeURIComponent(FR.cjkEncode('%华%'));            }                   

推荐信息