有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

java如何更新按钮上更改的数据?

我想通过在文本框中输入新值来编辑用户的数据,比如他的名字,并在他的个人资料中显示这些更改。 我试图使用Ajax,但我不明白url应该在那里。 这是我的带有编辑表单和Ajax脚本的jsp文件:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib  uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<script type="text/javascript">
    $("edit").click(function() {
        var firstName = $(request.getParameter("firstname")).val();
        $.ajax({
            url: '',
            type: 'POST',
            data: {
                firstName: firstName
            }
        });
    });
</script>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>${title}</title>
</head>
<body>
<h4>To edit your information fill the fields, please.</h4>
    <form name='f' action="${pageContext.request.contextPath}/j_spring_security_check" method='POST'>
      <table>
         <tr>
            <td>First Name:</td>
            <td><input type='text' name='firstname' id='firstname' value='${firstname}'></td>
         </tr>
         <tr>
            <td><input name="edit" type="submit" value="Submit" /></td>
         </tr>      
      </table>
    </form> 

我在其中一个类中有更新和获取名字的方法:

public class UserInfoDAOImpl extends JdbcDaoSupport implements UserInfoDAO {    
    @Autowired
    public UserInfoDAOImpl(DataSource dataSource) {
        this.setDataSource(dataSource);
    }    
//.....other methods

@Override
public void editFirstName(String userName, String fName){
    String sql = "update Users set FirstName = ? where Username = ?";
    Object[] params = new Object[] {fName, userName};
    this.getJdbcTemplate().update(sql, params);
}

@Override
    public String getFirstName(String userName) {
        // TODO Auto-generated method stub      
        String sql = "select u.FirstName from Users u where u.Username = ? "; 
        Object[] params = new Object[] { userName };         
        String firstName = (String)getJdbcTemplate().queryForObject(sql, params, String.class);
        return firstName;
    }
}

因此,我并没有真正使用这些已经编写好的方法来更新数据,并在用户配置文件中获得这些更改。 我是阿贾克斯的新手,所以我很高兴能得到任何帮助


共 (0) 个答案