字符串长度不同于Javascript到Java代码

时间:2009-01-20 17:53:53

标签: java javascript string carriage-return

我有一个JSP页面,其中包含一段Javascript验证码,限制了提交时的一定数量的字符。我正在使用<textarea>,所以我不能简单地使用<input type="text">中的长度属性。

我使用document.getElementById("text").value.length来获取字符串长度。我在Windows上运行Firefox 3.0(但我也用IE 6测试了这种行为)。表单将提交给J2EE servlet。在我的Java servlet中,参数的字符串长度大于2000!

我注意到这可以通过在<textarea>中添加回车来轻松复制。我使用Firebug来断言<textare>的长度,它实际上是2000个字符长。但是在Java方面,回车符转换为UNIX样式(\r\n而不是\n),因此字符串长度不同!

我错过了一些明显的东西或者什么?如果没有,您将如何可靠(跨平台/浏览器)确保<textarea>有限。

3 个答案:

答案 0 :(得分:26)

这不是一个JavaScript(或Java)问题 - 两个层都报告了他们正在处理的字符串的准确长度。您遇到的问题是在HTTP传输过程中字符串会被转换。

如果绝对必须确保字符串不超过一定长度,则可以通过将“\ n”的每个实例替换为“\ n \ r”来模拟客户端上的此转换 - 但仅用于长度验证目的:

textarea.value.replace(/\n/g, "\r\n").length

答案 1 :(得分:9)

您是否特别关注使用哪种线路结尾?为什么不让Java将“\ r \ n”转换为“\ n”? (请注意,“\ r \ n”是Windows样式;“\ n”是Unix样式。)

或者,在检查JavaScript中的长度时,请执行相反的操作。

答案 2 :(得分:1)

您是否将其限制为2000个字符,以便它适合数据库中的nvarchar(2000)列?否则可能只允许2%的溢出在Java端具有灵活性。

Java应该使用Unicode UTF16来表示字符串。 /r必须在其他地方进入,也许在提交时在网络浏览器中进行转换?你尝试过不同的浏览器吗?在不同的平台上?您可能只需删除/r s。