struts2传递大数据的方法
最近在写一个personal blog,出现了一个无法传输大数据的问题。
在写完文章然后传到struts2里面的action时,会因为文章内容过长而导致无法跳转,最后发现的原因是因为struts2的form跳转进action时,会把输入的内容以键值对的方式传输,也就是在url中体现传值。这种方式首先会因为文章内容过长而导致url无法保存这个字符串,最后就无法正常传值了。
在查了很多资料之后,我才发现原因出在了form的method里。
最开始我在form里面没有写明method的方法,于是就出现了上述用url的键值对方法来传值的极值。
<form action="changePassword.action">
<div id="modal-changePassword" class="modal" style="width: 400px">
<div class="modal-content">
<h4 style="text-align: center">Change Password</h4>
<input name="userName" value="<%=userName%>" placeholder="User Name" required type="text" class="validate">
<input name="password" placeholder="password" required type="password" class="validate">
<input name="newPassword" placeholder="new Password" required type="password" class="validate">
</div>
<div class="modal-footer">
<input type="reset" value="Cancel!" class="modal-action modal-close btn-flat">
<input type="submit" value="Change!" class=" btn-flat">
</div>
</div>
</form>
后来我写明了form的method为post之后,就不再出现这种情况,而且可以正常的跳转了。
<div class="row" style="margin-top: 40px;">
<form class="col s12" action="writeArticle.action" method="post">
<div class="row">
<div class="input-field col s6">
<input name="m_article.author" id="author" value="<%=userName%>" required type="text" class="validate">
<label for="author">author</label>
</div>
</div>
<div class="row">
<div class="input-field col s6">
<input name="m_article.date" id="date" value="" required type="date" class="validate">
</div>
</div>
<div class="row">
<div class="input-field col s6">
<input name="m_article.title" id="title" required type="text" class="validate">
<label for="title">Title</label>
</div>
</div>
<div class="row">
<div class="input-field col s6">
<input name="m_article.description" id="description" type="text" required class="validate">
<label for="description">Description</label>
</div>
</div>
<div class="row">
<div id="test-editormd">
<textarea style="display:none;" name="m_article.content"></textarea>
</div>
</div>
<button class="btn waves-effect waves-light" type="submit" name="action" style="float: right">Finish!
<i class="material-icons right">send</i>
</button>
</form>
那么原因是什么呢?问题就出现form中。
原因
form的默认执行方法是get,这种方法适用于获取小数据且不太敏感的数据。浏览器会与表单处理服务器建立连接,然后直接在一个传输步骤中发送所有的表单数据:浏览器会将数据直接附在表单的 action URL 之后。这两者之间用问号进行分隔。
而form的post方法中,浏览器将会按照下面两步来发送数据。首先,浏览器将与 action 属性中指定的表单处理服务器建立联系,一旦建立连接之后,浏览器就会按分段传输的方法将数据发送给服务器。
在服务器端,一旦 POST 样式的应用程序开始执行时,就应该从一个标志位置读取参数,而一旦读到参数,在应用程序能够使用这些表单值以前,必须对这些参数进行解码。用户特定的服务器会明确指定应用程序应该如何接受这些参数。
那么,POST 还是 GET?
如果表单处理服务器既支持 POST 方法又支持 GET 方法,那么你该选择哪
种方法呢?下面是有关这方面的一些规律:
- 如果希望获得最佳表单传输性能,可以采用 GET 方法发送只有少数简短字段的小表单。
- 一些服务器操作系统在处理可以立即传递给应用程序的命令行参数时,会限制其数目和长度,在这种情况下,对那些有许多字段或是很长的文本域的表单来说,就应该采用 POST 方法来发送。
- 如果你在编写服务器端的表单处理应用程序方面经验不足,应该选择 GET 方法。如果采用 POST 方法,就要在读取和解码方法做些额外的工作,也许这并不很难,但是也许你不太愿意去处理这些问题。
- 如果安全性是个问题,那么我们建议选用 POST 方法。GET 方法将表单参数直接放在应用程序的 URL 中,这样网络窥探者可以很轻松地捕获它们,还可以从服务器的日志文件中进行摘录。如果参数中包含了信用卡帐号这样的敏感信息,就会在不知不觉中危及用户的安全。而 POST 应用程序就没有安全方面的漏洞,在将参数作为单独的事务传输给服务器进行处理时,至少还可以采用加密的方法。
- 如果想在表单之外调用服务器端的应用程序,而且包括向其传递参数的过程,就要采用 GET 方法,因为该方法允许把表单这样的参数包括进来作为 URL 的一部分。而另一方面,使用 POST 样式的应用程序却希望在 URL 后还能有一个来自浏览器额外的传输过程,其中传输的内容不能作为传统
<a>
标签的内容。
于是问题就解决了。