java - 停止在页面重新加载时将表单的先前数据提交到jsp中的数据库

标签 java sql jsp refresh

我已经完成了以下编码 联系我们.jsp

<form action="contact1.jsp" method="post" id="contact_form">
                <div class="name">
                    <label for="name"></label> <input type="text" placeholder="My name is" name="name" id="name_input" required>
                </div>
                <div class="email">
                    <label for="email"></label> <input type="email"
                        placeholder="My e-mail is" name="email" id="email_input" required>
                </div>
                <div class="telephone">
                    <label for="name"></label>
                    <input type="text" placeholder="My number is" id="telephone_input" name="telephone" title="lenght of number should be 10 digits for valid number" pattern="[1-9]{1}[0-9]{9}" required/> 

                </div>

                <div class="message">
                    <label for="message"></label>
                    <textarea name="message" placeholder="I'd like to chat about"
                        id="message_input" cols="30" rows="5" required></textarea>
                </div>
                <div class="submit">
                    <input type="submit" value="Send Message" id="form_button" />
                </div>
            </form>

contact1.jsp 的代码是

String name=request.getParameter("name");
String email=request.getParameter("email");
String telephone=request.getParameter("telephone");
String message=request.getParameter("message");

Class.forName("com.mysql.jdbc.Driver");
Connection con = DriverManager.getConnection("jdbc:mysql://localhost/cinushi_university", "CinthiyaSingh", "Cinthiya@098");
Statement st=con.createStatement();
ResultSet rs;
int i=st.executeUpdate("insert into contact values('"+ name + "','"+ email + "','"+ telephone + "','"+ message + "');");
if (i > 0) {
    request.getSession().setAttribute("Message", "Sent Successfully!");
    request.getRequestDispatcher("ContactUs.jsp").forward(request, response);
}
else{
    request.getSession().setAttribute("Message", "Incomplete Process!");
    request.getRequestDispatcher("ContactUs.jsp").forward(request, response);   
}

//close connection
%>

将数据添加到表单并提交后,效果很好,但是当我单击刷新时在同一页面上发布它会重新提交数据,我希望在重定向响应时清除先前提交的数据到同一个 ContactUs.jsp ,如果可能的话请帮忙。

最佳答案

您可以使用java脚本History.replaceState () 函数来解决这个问题。

History.replaceState() 方法修改当前历史记录条目,将其替换为方法参数中传递的 stateObj、标题和 URL。

在jsp页面中添加此脚本-

<script>
    if ( window.history.replaceState ) {
        window.history.replaceState( null, null, window.location.href );
    }
</script>

或者, 如果提交数据不存在,则仅在表“用户”中插入数据。您必须检查唯一列。

关于java - 停止在页面重新加载时将表单的先前数据提交到jsp中的数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61804787/

相关文章:

java - Android 无法使用 attrs 值扩充布局文件

java - 删除 ctor 时通过反射设置私有(private)最终字段失败

sql - 如何根据sql中的当前日期获取上周的日期范围?

java - 出现错误 无法解析类型 java.util.Map$Entry

java - token 拦截器在 Struts 2 中如何工作

java - JUnit 模拟,我应该使用哪个工具?

java - Spring 4,@Resource注解字段为null

java - 在sql语句中使用java变量

sql - 为什么子查询和join这么慢

html - 如何在 <a href> 标签下对齐多个图像?